2 * Copyright (C) 2008 Apple Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 #ifndef MacroAssembler_h
27 #define MacroAssembler_h
29 #include <wtf/Platform.h>
34 #include "MacroAssemblerARMv7.h"
35 namespace JSC
{ typedef MacroAssemblerARMv7 MacroAssemblerBase
; };
37 #elif CPU(ARM_TRADITIONAL)
38 #include "MacroAssemblerARM.h"
39 namespace JSC
{ typedef MacroAssemblerARM MacroAssemblerBase
; };
42 #include "MacroAssemblerX86.h"
43 namespace JSC
{ typedef MacroAssemblerX86 MacroAssemblerBase
; };
46 #include "MacroAssemblerX86_64.h"
47 namespace JSC
{ typedef MacroAssemblerX86_64 MacroAssemblerBase
; };
50 #error "The MacroAssembler is not supported on this platform."
56 class MacroAssembler
: public MacroAssemblerBase
{
59 using MacroAssemblerBase::pop
;
60 using MacroAssemblerBase::jump
;
61 using MacroAssemblerBase::branch32
;
62 using MacroAssemblerBase::branch16
;
64 using MacroAssemblerBase::branchPtr
;
65 using MacroAssemblerBase::branchTestPtr
;
69 // Platform agnostic onvenience functions,
70 // described in terms of other macro assembly methods.
73 addPtr(Imm32(sizeof(void*)), stackPointerRegister
);
76 void peek(RegisterID dest
, int index
= 0)
78 loadPtr(Address(stackPointerRegister
, (index
* sizeof(void*))), dest
);
81 void poke(RegisterID src
, int index
= 0)
83 storePtr(src
, Address(stackPointerRegister
, (index
* sizeof(void*))));
86 void poke(Imm32 value
, int index
= 0)
88 store32(value
, Address(stackPointerRegister
, (index
* sizeof(void*))));
91 void poke(ImmPtr imm
, int index
= 0)
93 storePtr(imm
, Address(stackPointerRegister
, (index
* sizeof(void*))));
97 // Backwards banches, these are currently all implemented using existing forwards branch mechanisms.
98 void branchPtr(Condition cond
, RegisterID op1
, ImmPtr imm
, Label target
)
100 branchPtr(cond
, op1
, imm
).linkTo(target
, this);
103 void branch32(Condition cond
, RegisterID op1
, RegisterID op2
, Label target
)
105 branch32(cond
, op1
, op2
).linkTo(target
, this);
108 void branch32(Condition cond
, RegisterID op1
, Imm32 imm
, Label target
)
110 branch32(cond
, op1
, imm
).linkTo(target
, this);
113 void branch32(Condition cond
, RegisterID left
, Address right
, Label target
)
115 branch32(cond
, left
, right
).linkTo(target
, this);
118 void branch16(Condition cond
, BaseIndex left
, RegisterID right
, Label target
)
120 branch16(cond
, left
, right
).linkTo(target
, this);
123 void branchTestPtr(Condition cond
, RegisterID reg
, Label target
)
125 branchTestPtr(cond
, reg
).linkTo(target
, this);
128 void jump(Label target
)
130 jump().linkTo(target
, this);
135 // On 32-bit platforms (i.e. x86), these methods directly map onto their 32-bit equivalents.
136 // FIXME: should this use a test for 32-bitness instead of this specific exception?
138 void addPtr(RegisterID src
, RegisterID dest
)
143 void addPtr(Imm32 imm
, RegisterID srcDest
)
148 void addPtr(ImmPtr imm
, RegisterID dest
)
150 add32(Imm32(imm
), dest
);
153 void addPtr(Imm32 imm
, RegisterID src
, RegisterID dest
)
155 add32(imm
, src
, dest
);
158 void andPtr(RegisterID src
, RegisterID dest
)
163 void andPtr(Imm32 imm
, RegisterID srcDest
)
168 void orPtr(RegisterID src
, RegisterID dest
)
173 void orPtr(ImmPtr imm
, RegisterID dest
)
175 or32(Imm32(imm
), dest
);
178 void orPtr(Imm32 imm
, RegisterID dest
)
183 void subPtr(RegisterID src
, RegisterID dest
)
188 void subPtr(Imm32 imm
, RegisterID dest
)
193 void subPtr(ImmPtr imm
, RegisterID dest
)
195 sub32(Imm32(imm
), dest
);
198 void xorPtr(RegisterID src
, RegisterID dest
)
203 void xorPtr(Imm32 imm
, RegisterID srcDest
)
209 void loadPtr(ImplicitAddress address
, RegisterID dest
)
211 load32(address
, dest
);
214 void loadPtr(BaseIndex address
, RegisterID dest
)
216 load32(address
, dest
);
219 void loadPtr(void* address
, RegisterID dest
)
221 load32(address
, dest
);
224 DataLabel32
loadPtrWithAddressOffsetPatch(Address address
, RegisterID dest
)
226 return load32WithAddressOffsetPatch(address
, dest
);
229 void setPtr(Condition cond
, RegisterID left
, Imm32 right
, RegisterID dest
)
231 set32(cond
, left
, right
, dest
);
234 void storePtr(RegisterID src
, ImplicitAddress address
)
236 store32(src
, address
);
239 void storePtr(RegisterID src
, BaseIndex address
)
241 store32(src
, address
);
244 void storePtr(RegisterID src
, void* address
)
246 store32(src
, address
);
249 void storePtr(ImmPtr imm
, ImplicitAddress address
)
251 store32(Imm32(imm
), address
);
254 void storePtr(ImmPtr imm
, void* address
)
256 store32(Imm32(imm
), address
);
259 DataLabel32
storePtrWithAddressOffsetPatch(RegisterID src
, Address address
)
261 return store32WithAddressOffsetPatch(src
, address
);
265 Jump
branchPtr(Condition cond
, RegisterID left
, RegisterID right
)
267 return branch32(cond
, left
, right
);
270 Jump
branchPtr(Condition cond
, RegisterID left
, ImmPtr right
)
272 return branch32(cond
, left
, Imm32(right
));
275 Jump
branchPtr(Condition cond
, RegisterID left
, Address right
)
277 return branch32(cond
, left
, right
);
280 Jump
branchPtr(Condition cond
, Address left
, RegisterID right
)
282 return branch32(cond
, left
, right
);
285 Jump
branchPtr(Condition cond
, AbsoluteAddress left
, RegisterID right
)
287 return branch32(cond
, left
, right
);
290 Jump
branchPtr(Condition cond
, Address left
, ImmPtr right
)
292 return branch32(cond
, left
, Imm32(right
));
295 Jump
branchPtr(Condition cond
, AbsoluteAddress left
, ImmPtr right
)
297 return branch32(cond
, left
, Imm32(right
));
300 Jump
branchTestPtr(Condition cond
, RegisterID reg
, RegisterID mask
)
302 return branchTest32(cond
, reg
, mask
);
305 Jump
branchTestPtr(Condition cond
, RegisterID reg
, Imm32 mask
= Imm32(-1))
307 return branchTest32(cond
, reg
, mask
);
310 Jump
branchTestPtr(Condition cond
, Address address
, Imm32 mask
= Imm32(-1))
312 return branchTest32(cond
, address
, mask
);
315 Jump
branchTestPtr(Condition cond
, BaseIndex address
, Imm32 mask
= Imm32(-1))
317 return branchTest32(cond
, address
, mask
);
321 Jump
branchAddPtr(Condition cond
, RegisterID src
, RegisterID dest
)
323 return branchAdd32(cond
, src
, dest
);
326 Jump
branchSubPtr(Condition cond
, Imm32 imm
, RegisterID dest
)
328 return branchSub32(cond
, imm
, dest
);
336 #endif // ENABLE(ASSEMBLER)
338 #endif // MacroAssembler_h