source: webkit/trunk/JavaScriptCore/assembler/MacroAssemblerX86.h@ 46059

Last change on this file since 46059 was 44526, checked in by [email protected], 16 years ago

2009-06-09 Gavin Barraclough <[email protected]>

Reviewed by Geoff Garen.

Enable JIT_OPTIMIZE_ARITHMETIC on ARMv7 platforms.

Temporarily split support for 'branchTruncateDoubleToInt32' onto its own switch
('supportsFloatingPointTruncate'). See comment in MacroAssemblerARMv7, we need
to work out wherther we are going to be able to support the current interface on
all platforms, or whether this should be refactored.

  • assembler/MacroAssemblerARMv7.h: (JSC::MacroAssemblerARMv7::supportsFloatingPoint):

Add implementation of supportsFloatingPointTruncate (returns true).

(JSC::MacroAssemblerARMv7::supportsFloatingPointTruncate):

Add implementation of supportsFloatingPointTruncate (returns false).

(JSC::MacroAssemblerARMv7::loadDouble):
(JSC::MacroAssemblerARMv7::storeDouble):
(JSC::MacroAssemblerARMv7::addDouble):
(JSC::MacroAssemblerARMv7::subDouble):
(JSC::MacroAssemblerARMv7::mulDouble):
(JSC::MacroAssemblerARMv7::convertInt32ToDouble):
(JSC::MacroAssemblerARMv7::branchDouble):

Implement FP code genertion operations.

  • assembler/MacroAssemblerX86.h: (JSC::MacroAssemblerX86::supportsFloatingPointTruncate):

Add implementation of supportsFloatingPointTruncate (returns true).

  • assembler/MacroAssemblerX86_64.h: (JSC::MacroAssemblerX86_64::supportsFloatingPointTruncate):

Add implementation of supportsFloatingPointTruncate (returns true).

  • jit/JITArithmetic.cpp: (JSC::JIT::emit_op_rshift):

Changed to call supportsFloatingPointTruncate().

(JSC::JIT::emitSlow_op_rshift):

Changed to call supportsFloatingPointTruncate().

  • wtf/Platform.h:

Change to enable JIT_OPTIMIZE_ARITHMETIC.

File size: 5.2 KB
Line 
1/*
2 * Copyright (C) 2008 Apple Inc. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
6 * are met:
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.
12 *
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.
24 */
25
26#ifndef MacroAssemblerX86_h
27#define MacroAssemblerX86_h
28
29#include <wtf/Platform.h>
30
31#if ENABLE(ASSEMBLER) && PLATFORM(X86)
32
33#include "MacroAssemblerX86Common.h"
34
35namespace JSC {
36
37class MacroAssemblerX86 : public MacroAssemblerX86Common {
38public:
39 MacroAssemblerX86()
40 : m_isSSE2Present(isSSE2Present())
41 {
42 }
43
44 static const Scale ScalePtr = TimesFour;
45
46 using MacroAssemblerX86Common::add32;
47 using MacroAssemblerX86Common::and32;
48 using MacroAssemblerX86Common::sub32;
49 using MacroAssemblerX86Common::or32;
50 using MacroAssemblerX86Common::load32;
51 using MacroAssemblerX86Common::store32;
52 using MacroAssemblerX86Common::branch32;
53 using MacroAssemblerX86Common::call;
54
55 void add32(Imm32 imm, RegisterID src, RegisterID dest)
56 {
57 m_assembler.leal_mr(imm.m_value, src, dest);
58 }
59
60 void add32(Imm32 imm, AbsoluteAddress address)
61 {
62 m_assembler.addl_im(imm.m_value, address.m_ptr);
63 }
64
65 void addWithCarry32(Imm32 imm, AbsoluteAddress address)
66 {
67 m_assembler.adcl_im(imm.m_value, address.m_ptr);
68 }
69
70 void and32(Imm32 imm, AbsoluteAddress address)
71 {
72 m_assembler.andl_im(imm.m_value, address.m_ptr);
73 }
74
75 void or32(Imm32 imm, AbsoluteAddress address)
76 {
77 m_assembler.orl_im(imm.m_value, address.m_ptr);
78 }
79
80 void sub32(Imm32 imm, AbsoluteAddress address)
81 {
82 m_assembler.subl_im(imm.m_value, address.m_ptr);
83 }
84
85 void load32(void* address, RegisterID dest)
86 {
87 m_assembler.movl_mr(address, dest);
88 }
89
90 void store32(Imm32 imm, void* address)
91 {
92 m_assembler.movl_i32m(imm.m_value, address);
93 }
94
95 void store32(RegisterID src, void* address)
96 {
97 m_assembler.movl_rm(src, address);
98 }
99
100 Jump branch32(Condition cond, AbsoluteAddress left, RegisterID right)
101 {
102 m_assembler.cmpl_rm(right, left.m_ptr);
103 return Jump(m_assembler.jCC(x86Condition(cond)));
104 }
105
106 Jump branch32(Condition cond, AbsoluteAddress left, Imm32 right)
107 {
108 m_assembler.cmpl_im(right.m_value, left.m_ptr);
109 return Jump(m_assembler.jCC(x86Condition(cond)));
110 }
111
112 Call call()
113 {
114 return Call(m_assembler.call(), Call::Linkable);
115 }
116
117 Call tailRecursiveCall()
118 {
119 return Call::fromTailJump(jump());
120 }
121
122 Call makeTailRecursiveCall(Jump oldJump)
123 {
124 return Call::fromTailJump(oldJump);
125 }
126
127
128 DataLabelPtr moveWithPatch(ImmPtr initialValue, RegisterID dest)
129 {
130 m_assembler.movl_i32r(initialValue.asIntptr(), dest);
131 return DataLabelPtr(this);
132 }
133
134 Jump branchPtrWithPatch(Condition cond, RegisterID left, DataLabelPtr& dataLabel, ImmPtr initialRightValue = ImmPtr(0))
135 {
136 m_assembler.cmpl_ir_force32(initialRightValue.asIntptr(), left);
137 dataLabel = DataLabelPtr(this);
138 return Jump(m_assembler.jCC(x86Condition(cond)));
139 }
140
141 Jump branchPtrWithPatch(Condition cond, Address left, DataLabelPtr& dataLabel, ImmPtr initialRightValue = ImmPtr(0))
142 {
143 m_assembler.cmpl_im_force32(initialRightValue.asIntptr(), left.offset, left.base);
144 dataLabel = DataLabelPtr(this);
145 return Jump(m_assembler.jCC(x86Condition(cond)));
146 }
147
148 DataLabelPtr storePtrWithPatch(ImmPtr initialValue, ImplicitAddress address)
149 {
150 m_assembler.movl_i32m(initialValue.asIntptr(), address.offset, address.base);
151 return DataLabelPtr(this);
152 }
153
154 Label loadPtrWithPatchToLEA(Address address, RegisterID dest)
155 {
156 Label label(this);
157 load32(address, dest);
158 return label;
159 }
160
161 bool supportsFloatingPoint() const { return m_isSSE2Present; }
162 // See comment on MacroAssemblerARMv7::supportsFloatingPointTruncate()
163 bool supportsFloatingPointTruncate() const { return m_isSSE2Present; }
164
165private:
166 const bool m_isSSE2Present;
167};
168
169} // namespace JSC
170
171#endif // ENABLE(ASSEMBLER)
172
173#endif // MacroAssemblerX86_h
Note: See TracBrowser for help on using the repository browser.