source: webkit/trunk/Source/JavaScriptCore/jit/JITSubGenerator.cpp

Last change on this file was 281355, checked in by [email protected], 4 years ago

[JSC] Simplify moveIntsToDouble
https://bugs.webkit.org/show_bug.cgi?id=229351

Reviewed by Saam Barati.

MacroAssembler::moveIntsToDouble required scratch FPRReg. But it was only required for MacroAssemblerX86, and it is already removed.
This means that we no longer need this scratch FPRReg. This change makes a lot of IC code, property access code simpler.
This patch removes that scratch FPRReg, and removed scratch FPRReg of many arithmetic ICs. This patch is important for PutByVal modern
IC since some of property access requires FPRReg because of MacroAssembler::moveIntsToDouble, and it requires adding new m_scratch2FPR
to AccessCase. But after this simplification, this is no longer necessary.

  • assembler/MacroAssemblerARMv7.h:

(JSC::MacroAssemblerARMv7::moveIntsToDouble):

  • assembler/MacroAssemblerMIPS.h:

(JSC::MacroAssemblerMIPS::moveIntsToDouble):

  • dfg/DFGSpeculativeJIT.cpp:

(JSC::DFG::SpeculativeJIT::compileValueToInt32):
(JSC::DFG::SpeculativeJIT::compileDoubleRep):
(JSC::DFG::SpeculativeJIT::emitUntypedOrBigIntRightShiftBitOp):
(JSC::DFG::SpeculativeJIT::compileValueAdd):
(JSC::DFG::SpeculativeJIT::compileValueSub):
(JSC::DFG::SpeculativeJIT::compileMathIC):
(JSC::DFG::SpeculativeJIT::compileValueNegate):
(JSC::DFG::SpeculativeJIT::compileValueMul):
(JSC::DFG::SpeculativeJIT::speculateRealNumber):
(JSC::DFG::SpeculativeJIT::compileNormalizeMapKey):

  • dfg/DFGSpeculativeJIT.h:

(JSC::DFG::SpeculativeJIT::unboxDouble):

  • ftl/FTLLowerDFGToB3.cpp:

(JSC::FTL::DFG::LowerDFGToB3::compileBinaryMathIC):
(JSC::FTL::DFG::LowerDFGToB3::compileCompareStrictEq):

  • jit/AssemblyHelpers.cpp:

(JSC::AssemblyHelpers::emitConvertValueToBoolean):
(JSC::AssemblyHelpers::branchIfValue):

  • jit/AssemblyHelpers.h:

(JSC::AssemblyHelpers::unboxDoubleNonDestructive):
(JSC::AssemblyHelpers::unboxDouble):

  • jit/JITAddGenerator.cpp:

(JSC::JITAddGenerator::generateFastPath):

  • jit/JITAddGenerator.h:

(JSC::JITAddGenerator::JITAddGenerator):

  • jit/JITArithmetic.cpp:

(JSC::JIT::emitRightShiftFastPath):
(JSC::JIT::emitMathICFast):

  • jit/JITDivGenerator.cpp:

(JSC::JITDivGenerator::loadOperand):

  • jit/JITMulGenerator.cpp:

(JSC::JITMulGenerator::generateInline):
(JSC::JITMulGenerator::generateFastPath):

  • jit/JITMulGenerator.h:

(JSC::JITMulGenerator::JITMulGenerator):

  • jit/JITPropertyAccess.cpp:

(JSC::JIT::emitFloatTypedArrayPutByVal):

  • jit/JITPropertyAccess32_64.cpp:

(JSC::JIT::emitGenericContiguousPutByVal):

  • jit/JITRightShiftGenerator.cpp:

(JSC::JITRightShiftGenerator::generateFastPath):

  • jit/JITRightShiftGenerator.h:

(JSC::JITRightShiftGenerator::JITRightShiftGenerator):

  • jit/JITSubGenerator.cpp:

(JSC::JITSubGenerator::generateInline):
(JSC::JITSubGenerator::generateFastPath):

  • jit/JITSubGenerator.h:

(JSC::JITSubGenerator::JITSubGenerator):

File size: 5.4 KB
Line 
1/*
2 * Copyright (C) 2015-2016 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#include "config.h"
27#include "JITSubGenerator.h"
28
29#include "ArithProfile.h"
30#include "JITMathIC.h"
31
32#if ENABLE(JIT)
33
34namespace JSC {
35
36JITMathICInlineResult JITSubGenerator::generateInline(CCallHelpers& jit, MathICGenerationState& state, const BinaryArithProfile* arithProfile)
37{
38 // We default to speculating int32.
39 ObservedType lhs = ObservedType().withInt32();
40 ObservedType rhs = ObservedType().withInt32();
41 if (arithProfile) {
42 lhs = arithProfile->lhsObservedType();
43 rhs = arithProfile->rhsObservedType();
44 }
45
46 if (lhs.isOnlyNonNumber() && rhs.isOnlyNonNumber())
47 return JITMathICInlineResult::DontGenerate;
48
49 if (lhs.isOnlyNumber() && rhs.isOnlyNumber()) {
50 if (!jit.supportsFloatingPoint())
51 return JITMathICInlineResult::DontGenerate;
52
53 if (!m_leftOperand.definitelyIsNumber())
54 state.slowPathJumps.append(jit.branchIfNotNumber(m_left, m_scratchGPR));
55 if (!m_rightOperand.definitelyIsNumber())
56 state.slowPathJumps.append(jit.branchIfNotNumber(m_right, m_scratchGPR));
57 state.slowPathJumps.append(jit.branchIfInt32(m_left));
58 state.slowPathJumps.append(jit.branchIfInt32(m_right));
59 jit.unboxDoubleNonDestructive(m_left, m_leftFPR, m_scratchGPR);
60 jit.unboxDoubleNonDestructive(m_right, m_rightFPR, m_scratchGPR);
61 jit.subDouble(m_rightFPR, m_leftFPR);
62 jit.boxDouble(m_leftFPR, m_result);
63
64 return JITMathICInlineResult::GeneratedFastPath;
65 }
66 if (lhs.isOnlyInt32() && rhs.isOnlyInt32()) {
67 ASSERT(!m_leftOperand.isConstInt32() || !m_rightOperand.isConstInt32());
68 state.slowPathJumps.append(jit.branchIfNotInt32(m_left));
69 state.slowPathJumps.append(jit.branchIfNotInt32(m_right));
70
71 jit.move(m_left.payloadGPR(), m_scratchGPR);
72 state.slowPathJumps.append(jit.branchSub32(CCallHelpers::Overflow, m_right.payloadGPR(), m_scratchGPR));
73
74 jit.boxInt32(m_scratchGPR, m_result);
75 return JITMathICInlineResult::GeneratedFastPath;
76 }
77
78 return JITMathICInlineResult::GenerateFullSnippet;
79}
80
81bool JITSubGenerator::generateFastPath(CCallHelpers& jit, CCallHelpers::JumpList& endJumpList, CCallHelpers::JumpList& slowPathJumpList, const BinaryArithProfile* arithProfile, bool shouldEmitProfiling)
82{
83 ASSERT(m_scratchGPR != InvalidGPRReg);
84 ASSERT(m_scratchGPR != m_left.payloadGPR());
85 ASSERT(m_scratchGPR != m_right.payloadGPR());
86#if USE(JSVALUE32_64)
87 ASSERT(m_scratchGPR != m_left.tagGPR());
88 ASSERT(m_scratchGPR != m_right.tagGPR());
89#endif
90
91 CCallHelpers::Jump leftNotInt = jit.branchIfNotInt32(m_left);
92 CCallHelpers::Jump rightNotInt = jit.branchIfNotInt32(m_right);
93
94 jit.move(m_left.payloadGPR(), m_scratchGPR);
95 slowPathJumpList.append(jit.branchSub32(CCallHelpers::Overflow, m_right.payloadGPR(), m_scratchGPR));
96
97 jit.boxInt32(m_scratchGPR, m_result);
98
99 endJumpList.append(jit.jump());
100
101 if (!jit.supportsFloatingPoint()) {
102 slowPathJumpList.append(leftNotInt);
103 slowPathJumpList.append(rightNotInt);
104 return true;
105 }
106
107 leftNotInt.link(&jit);
108 if (!m_leftOperand.definitelyIsNumber())
109 slowPathJumpList.append(jit.branchIfNotNumber(m_left, m_scratchGPR));
110 if (!m_rightOperand.definitelyIsNumber())
111 slowPathJumpList.append(jit.branchIfNotNumber(m_right, m_scratchGPR));
112
113 jit.unboxDoubleNonDestructive(m_left, m_leftFPR, m_scratchGPR);
114 CCallHelpers::Jump rightIsDouble = jit.branchIfNotInt32(m_right);
115
116 jit.convertInt32ToDouble(m_right.payloadGPR(), m_rightFPR);
117 CCallHelpers::Jump rightWasInteger = jit.jump();
118
119 rightNotInt.link(&jit);
120 if (!m_rightOperand.definitelyIsNumber())
121 slowPathJumpList.append(jit.branchIfNotNumber(m_right, m_scratchGPR));
122
123 jit.convertInt32ToDouble(m_left.payloadGPR(), m_leftFPR);
124
125 rightIsDouble.link(&jit);
126 jit.unboxDoubleNonDestructive(m_right, m_rightFPR, m_scratchGPR);
127
128 rightWasInteger.link(&jit);
129
130 jit.subDouble(m_rightFPR, m_leftFPR);
131 if (arithProfile && shouldEmitProfiling)
132 arithProfile->emitSetDouble(jit);
133
134 jit.boxDouble(m_leftFPR, m_result);
135
136 return true;
137}
138
139} // namespace JSC
140
141#endif // ENABLE(JIT)
Note: See TracBrowser for help on using the repository browser.