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>
33 #if PLATFORM_ARM_ARCH(7)
34 #include "MacroAssemblerARMv7.h"
35 namespace JSC
{ typedef MacroAssemblerARMv7 MacroAssemblerBase
; };
38 #include "MacroAssemblerX86.h"
39 namespace JSC
{ typedef MacroAssemblerX86 MacroAssemblerBase
; };
41 #elif PLATFORM(X86_64)
42 #include "MacroAssemblerX86_64.h"
43 namespace JSC
{ typedef MacroAssemblerX86_64 MacroAssemblerBase
; };
46 #error "The MacroAssembler is not supported on this platform."
52 class MacroAssembler
: public MacroAssemblerBase
{
55 using MacroAssemblerBase::pop
;
56 using MacroAssemblerBase::jump
;
57 using MacroAssemblerBase::branch32
;
58 using MacroAssemblerBase::branch16
;
60 using MacroAssemblerBase::branchPtr
;
61 using MacroAssemblerBase::branchTestPtr
;
65 // Platform agnostic onvenience functions,
66 // described in terms of other macro assembly methods.
69 addPtr(Imm32(sizeof(void*)), stackPointerRegister
);
72 void peek(RegisterID dest
, int index
= 0)
74 loadPtr(Address(stackPointerRegister
, (index
* sizeof(void*))), dest
);
77 void poke(RegisterID src
, int index
= 0)
79 storePtr(src
, Address(stackPointerRegister
, (index
* sizeof(void*))));
82 void poke(Imm32 value
, int index
= 0)
84 store32(value
, Address(stackPointerRegister
, (index
* sizeof(void*))));
87 void poke(ImmPtr imm
, int index
= 0)
89 storePtr(imm
, Address(stackPointerRegister
, (index
* sizeof(void*))));
93 // Backwards banches, these are currently all implemented using existing forwards branch mechanisms.
94 void branchPtr(Condition cond
, RegisterID op1
, ImmPtr imm
, Label target
)
96 branchPtr(cond
, op1
, imm
).linkTo(target
, this);
99 void branch32(Condition cond
, RegisterID op1
, RegisterID op2
, Label target
)
101 branch32(cond
, op1
, op2
).linkTo(target
, this);
104 void branch32(Condition cond
, RegisterID op1
, Imm32 imm
, Label target
)
106 branch32(cond
, op1
, imm
).linkTo(target
, this);
109 void branch32(Condition cond
, RegisterID left
, Address right
, Label target
)
111 branch32(cond
, left
, right
).linkTo(target
, this);
114 void branch16(Condition cond
, BaseIndex left
, RegisterID right
, Label target
)
116 branch16(cond
, left
, right
).linkTo(target
, this);
119 void branchTestPtr(Condition cond
, RegisterID reg
, Label target
)
121 branchTestPtr(cond
, reg
).linkTo(target
, this);
124 void jump(Label target
)
126 jump().linkTo(target
, this);
131 // On 32-bit platforms (i.e. x86), these methods directly map onto their 32-bit equivalents.
132 #if !PLATFORM(X86_64)
133 void addPtr(RegisterID src
, RegisterID dest
)
138 void addPtr(Imm32 imm
, RegisterID srcDest
)
143 void addPtr(ImmPtr imm
, RegisterID dest
)
145 add32(Imm32(imm
), dest
);
148 void addPtr(Imm32 imm
, RegisterID src
, RegisterID dest
)
150 add32(imm
, src
, dest
);
153 void andPtr(RegisterID src
, RegisterID dest
)
158 void andPtr(Imm32 imm
, RegisterID srcDest
)
163 void orPtr(RegisterID src
, RegisterID dest
)
168 void orPtr(ImmPtr imm
, RegisterID dest
)
170 or32(Imm32(imm
), dest
);
173 void orPtr(Imm32 imm
, RegisterID dest
)
178 void rshiftPtr(RegisterID shift_amount
, RegisterID dest
)
180 rshift32(shift_amount
, dest
);
183 void rshiftPtr(Imm32 imm
, RegisterID dest
)
188 void subPtr(RegisterID src
, RegisterID dest
)
193 void subPtr(Imm32 imm
, RegisterID dest
)
198 void subPtr(ImmPtr imm
, RegisterID dest
)
200 sub32(Imm32(imm
), dest
);
203 void xorPtr(RegisterID src
, RegisterID dest
)
208 void xorPtr(Imm32 imm
, RegisterID srcDest
)
214 void loadPtr(ImplicitAddress address
, RegisterID dest
)
216 load32(address
, dest
);
219 void loadPtr(BaseIndex address
, RegisterID dest
)
221 load32(address
, dest
);
224 void loadPtr(void* address
, RegisterID dest
)
226 load32(address
, dest
);
229 DataLabel32
loadPtrWithAddressOffsetPatch(Address address
, RegisterID dest
)
231 return load32WithAddressOffsetPatch(address
, dest
);
234 void setPtr(Condition cond
, RegisterID left
, Imm32 right
, RegisterID dest
)
236 set32(cond
, left
, right
, dest
);
239 void storePtr(RegisterID src
, ImplicitAddress address
)
241 store32(src
, address
);
244 void storePtr(RegisterID src
, BaseIndex address
)
246 store32(src
, address
);
249 void storePtr(RegisterID src
, void* address
)
251 store32(src
, address
);
254 void storePtr(ImmPtr imm
, ImplicitAddress address
)
256 store32(Imm32(imm
), address
);
259 void storePtr(ImmPtr imm
, void* address
)
261 store32(Imm32(imm
), address
);
264 DataLabel32
storePtrWithAddressOffsetPatch(RegisterID src
, Address address
)
266 return store32WithAddressOffsetPatch(src
, address
);
270 Jump
branchPtr(Condition cond
, RegisterID left
, RegisterID right
)
272 return branch32(cond
, left
, right
);
275 Jump
branchPtr(Condition cond
, RegisterID left
, ImmPtr right
)
277 return branch32(cond
, left
, Imm32(right
));
280 Jump
branchPtr(Condition cond
, RegisterID left
, Address right
)
282 return branch32(cond
, left
, right
);
285 Jump
branchPtr(Condition cond
, Address left
, RegisterID right
)
287 return branch32(cond
, left
, right
);
290 Jump
branchPtr(Condition cond
, AbsoluteAddress left
, RegisterID right
)
292 return branch32(cond
, left
, right
);
295 Jump
branchPtr(Condition cond
, Address left
, ImmPtr right
)
297 return branch32(cond
, left
, Imm32(right
));
300 Jump
branchPtr(Condition cond
, AbsoluteAddress left
, ImmPtr right
)
302 return branch32(cond
, left
, Imm32(right
));
305 Jump
branchTestPtr(Condition cond
, RegisterID reg
, RegisterID mask
)
307 return branchTest32(cond
, reg
, mask
);
310 Jump
branchTestPtr(Condition cond
, RegisterID reg
, Imm32 mask
= Imm32(-1))
312 return branchTest32(cond
, reg
, mask
);
315 Jump
branchTestPtr(Condition cond
, Address address
, Imm32 mask
= Imm32(-1))
317 return branchTest32(cond
, address
, mask
);
320 Jump
branchTestPtr(Condition cond
, BaseIndex address
, Imm32 mask
= Imm32(-1))
322 return branchTest32(cond
, address
, mask
);
326 Jump
branchAddPtr(Condition cond
, RegisterID src
, RegisterID dest
)
328 return branchAdd32(cond
, src
, dest
);
331 Jump
branchSubPtr(Condition cond
, Imm32 imm
, RegisterID dest
)
333 return branchSub32(cond
, imm
, dest
);
341 #endif // ENABLE(ASSEMBLER)
343 #endif // MacroAssembler_h