| 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" |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 64 #if !defined(USE_SIMULATOR) | 64 #if !defined(USE_SIMULATOR) |
| 65 return FUNCTION_CAST<UnaryMathFunctionWithIsolate>(buffer); | 65 return FUNCTION_CAST<UnaryMathFunctionWithIsolate>(buffer); |
| 66 #else | 66 #else |
| 67 fast_exp_mips_machine_code = buffer; | 67 fast_exp_mips_machine_code = buffer; |
| 68 return &fast_exp_simulator; | 68 return &fast_exp_simulator; |
| 69 #endif | 69 #endif |
| 70 } | 70 } |
| 71 | 71 |
| 72 | 72 |
| 73 #if defined(V8_HOST_ARCH_MIPS) | 73 #if defined(V8_HOST_ARCH_MIPS) |
| 74 MemCopyUint8Function CreateMemCopyUint8Function(MemCopyUint8Function stub) { | 74 MemCopyUint8Function CreateMemCopyUint8Function(Isolate* isolate, |
| 75 MemCopyUint8Function stub) { |
| 75 #if defined(USE_SIMULATOR) | 76 #if defined(USE_SIMULATOR) |
| 76 return stub; | 77 return stub; |
| 77 #else | 78 #else |
| 78 | 79 |
| 79 size_t actual_size; | 80 size_t actual_size; |
| 80 byte* buffer = | 81 byte* buffer = |
| 81 static_cast<byte*>(base::OS::Allocate(3 * KB, &actual_size, true)); | 82 static_cast<byte*>(base::OS::Allocate(3 * KB, &actual_size, true)); |
| 82 if (buffer == NULL) return stub; | 83 if (buffer == nullptr) return stub; |
| 83 | 84 |
| 84 // This code assumes that cache lines are 32 bytes and if the cache line is | 85 // This code assumes that cache lines are 32 bytes and if the cache line is |
| 85 // larger it will not work correctly. | 86 // larger it will not work correctly. |
| 86 MacroAssembler masm(NULL, buffer, static_cast<int>(actual_size), | 87 MacroAssembler masm(isolate, buffer, static_cast<int>(actual_size), |
| 87 CodeObjectRequired::kNo); | 88 CodeObjectRequired::kNo); |
| 88 | 89 |
| 89 { | 90 { |
| 90 Label lastb, unaligned, aligned, chkw, | 91 Label lastb, unaligned, aligned, chkw, |
| 91 loop16w, chk1w, wordCopy_loop, skip_pref, lastbloop, | 92 loop16w, chk1w, wordCopy_loop, skip_pref, lastbloop, |
| 92 leave, ua_chk16w, ua_loop16w, ua_skip_pref, ua_chkw, | 93 leave, ua_chk16w, ua_loop16w, ua_skip_pref, ua_chkw, |
| 93 ua_chk1w, ua_wordCopy_loop, ua_smallCopy, ua_smallCopy_loop; | 94 ua_chk1w, ua_wordCopy_loop, ua_smallCopy, ua_smallCopy_loop; |
| 94 | 95 |
| 95 // The size of each prefetch. | 96 // The size of each prefetch. |
| 96 uint32_t pref_chunk = 32; | 97 uint32_t pref_chunk = 32; |
| (...skipping 494 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 591 __ bne(a0, a3, &ua_smallCopy_loop); | 592 __ bne(a0, a3, &ua_smallCopy_loop); |
| 592 __ sb(v1, MemOperand(a0, -1)); // In delay slot. | 593 __ sb(v1, MemOperand(a0, -1)); // In delay slot. |
| 593 | 594 |
| 594 __ jr(ra); | 595 __ jr(ra); |
| 595 __ nop(); | 596 __ nop(); |
| 596 } | 597 } |
| 597 CodeDesc desc; | 598 CodeDesc desc; |
| 598 masm.GetCode(&desc); | 599 masm.GetCode(&desc); |
| 599 DCHECK(!RelocInfo::RequiresRelocation(desc)); | 600 DCHECK(!RelocInfo::RequiresRelocation(desc)); |
| 600 | 601 |
| 601 Assembler::FlushICacheWithoutIsolate(buffer, actual_size); | 602 Assembler::FlushICache(isolate, buffer, actual_size); |
| 602 base::OS::ProtectCode(buffer, actual_size); | 603 base::OS::ProtectCode(buffer, actual_size); |
| 603 return FUNCTION_CAST<MemCopyUint8Function>(buffer); | 604 return FUNCTION_CAST<MemCopyUint8Function>(buffer); |
| 604 #endif | 605 #endif |
| 605 } | 606 } |
| 606 #endif | 607 #endif |
| 607 | 608 |
| 608 UnaryMathFunctionWithIsolate CreateSqrtFunction(Isolate* isolate) { | 609 UnaryMathFunctionWithIsolate CreateSqrtFunction(Isolate* isolate) { |
| 609 #if defined(USE_SIMULATOR) | 610 #if defined(USE_SIMULATOR) |
| 610 return nullptr; | 611 return nullptr; |
| 611 #else | 612 #else |
| (...skipping 645 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1257 } | 1258 } |
| 1258 } | 1259 } |
| 1259 | 1260 |
| 1260 | 1261 |
| 1261 #undef __ | 1262 #undef __ |
| 1262 | 1263 |
| 1263 } // namespace internal | 1264 } // namespace internal |
| 1264 } // namespace v8 | 1265 } // namespace v8 |
| 1265 | 1266 |
| 1266 #endif // V8_TARGET_ARCH_MIPS64 | 1267 #endif // V8_TARGET_ARCH_MIPS64 |
| OLD | NEW |