OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/mips64/codegen-mips64.h" | 5 #include "src/mips64/codegen-mips64.h" |
6 | 6 |
7 #if V8_TARGET_ARCH_MIPS64 | 7 #if V8_TARGET_ARCH_MIPS64 |
8 | 8 |
9 #include "src/codegen.h" | 9 #include "src/codegen.h" |
10 #include "src/macro-assembler.h" | 10 #include "src/macro-assembler.h" |
11 #include "src/mips64/simulator-mips64.h" | 11 #include "src/mips64/simulator-mips64.h" |
12 | 12 |
13 namespace v8 { | 13 namespace v8 { |
14 namespace internal { | 14 namespace internal { |
15 | 15 |
16 | 16 |
17 #define __ masm. | 17 #define __ masm. |
18 | 18 |
19 | 19 |
20 #if defined(USE_SIMULATOR) | 20 #if defined(USE_SIMULATOR) |
21 byte* fast_exp_mips_machine_code = NULL; | 21 byte* fast_exp_mips_machine_code = nullptr; |
22 double fast_exp_simulator(double x) { | 22 double fast_exp_simulator(double x, Isolate* isolate) { |
23 return Simulator::current(Isolate::Current())->CallFP( | 23 return Simulator::current(isolate)->CallFP(fast_exp_mips_machine_code, x, 0); |
24 fast_exp_mips_machine_code, x, 0); | |
25 } | 24 } |
26 #endif | 25 #endif |
27 | 26 |
28 | 27 |
29 UnaryMathFunction CreateExpFunction() { | 28 UnaryMathFunctionWithIsolate CreateExpFunction(Isolate* isolate) { |
30 if (!FLAG_fast_math) return &std::exp; | |
31 size_t actual_size; | 29 size_t actual_size; |
32 byte* buffer = | 30 byte* buffer = |
33 static_cast<byte*>(base::OS::Allocate(1 * KB, &actual_size, true)); | 31 static_cast<byte*>(base::OS::Allocate(1 * KB, &actual_size, true)); |
34 if (buffer == NULL) return &std::exp; | 32 if (buffer == nullptr) return nullptr; |
35 ExternalReference::InitializeMathExpData(); | 33 ExternalReference::InitializeMathExpData(); |
36 | 34 |
37 MacroAssembler masm(NULL, buffer, static_cast<int>(actual_size)); | 35 MacroAssembler masm(nullptr, buffer, static_cast<int>(actual_size)); |
38 | 36 |
39 { | 37 { |
40 DoubleRegister input = f12; | 38 DoubleRegister input = f12; |
41 DoubleRegister result = f0; | 39 DoubleRegister result = f0; |
42 DoubleRegister double_scratch1 = f4; | 40 DoubleRegister double_scratch1 = f4; |
43 DoubleRegister double_scratch2 = f6; | 41 DoubleRegister double_scratch2 = f6; |
44 Register temp1 = a4; | 42 Register temp1 = a4; |
45 Register temp2 = a5; | 43 Register temp2 = a5; |
46 Register temp3 = a6; | 44 Register temp3 = a6; |
47 | 45 |
48 __ MovFromFloatParameter(input); | 46 __ MovFromFloatParameter(input); |
49 __ Push(temp3, temp2, temp1); | 47 __ Push(temp3, temp2, temp1); |
50 MathExpGenerator::EmitMathExp( | 48 MathExpGenerator::EmitMathExp( |
51 &masm, input, result, double_scratch1, double_scratch2, | 49 &masm, input, result, double_scratch1, double_scratch2, |
52 temp1, temp2, temp3); | 50 temp1, temp2, temp3); |
53 __ Pop(temp3, temp2, temp1); | 51 __ Pop(temp3, temp2, temp1); |
54 __ MovToFloatResult(result); | 52 __ MovToFloatResult(result); |
55 __ Ret(); | 53 __ Ret(); |
56 } | 54 } |
57 | 55 |
58 CodeDesc desc; | 56 CodeDesc desc; |
59 masm.GetCode(&desc); | 57 masm.GetCode(&desc); |
60 DCHECK(!RelocInfo::RequiresRelocation(desc)); | 58 DCHECK(!RelocInfo::RequiresRelocation(desc)); |
61 | 59 |
62 CpuFeatures::FlushICache(buffer, actual_size); | 60 CpuFeatures::FlushICache(buffer, actual_size); |
63 base::OS::ProtectCode(buffer, actual_size); | 61 base::OS::ProtectCode(buffer, actual_size); |
64 | 62 |
65 #if !defined(USE_SIMULATOR) | 63 #if !defined(USE_SIMULATOR) |
66 return FUNCTION_CAST<UnaryMathFunction>(buffer); | 64 return FUNCTION_CAST<UnaryMathFunctionWithIsolate>(buffer); |
67 #else | 65 #else |
68 fast_exp_mips_machine_code = buffer; | 66 fast_exp_mips_machine_code = buffer; |
69 return &fast_exp_simulator; | 67 return &fast_exp_simulator; |
70 #endif | 68 #endif |
71 } | 69 } |
72 | 70 |
73 | 71 |
74 #if defined(V8_HOST_ARCH_MIPS) | 72 #if defined(V8_HOST_ARCH_MIPS) |
75 MemCopyUint8Function CreateMemCopyUint8Function(MemCopyUint8Function stub) { | 73 MemCopyUint8Function CreateMemCopyUint8Function(MemCopyUint8Function stub) { |
76 #if defined(USE_SIMULATOR) | 74 #if defined(USE_SIMULATOR) |
(...skipping 1178 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1255 } | 1253 } |
1256 } | 1254 } |
1257 | 1255 |
1258 | 1256 |
1259 #undef __ | 1257 #undef __ |
1260 | 1258 |
1261 } // namespace internal | 1259 } // namespace internal |
1262 } // namespace v8 | 1260 } // namespace v8 |
1263 | 1261 |
1264 #endif // V8_TARGET_ARCH_MIPS64 | 1262 #endif // V8_TARGET_ARCH_MIPS64 |
OLD | NEW |