| 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 #if V8_TARGET_ARCH_IA32 | 5 #if V8_TARGET_ARCH_IA32 |
| 6 | 6 |
| 7 #include "src/code-factory.h" | 7 #include "src/code-factory.h" |
| 8 #include "src/codegen.h" | 8 #include "src/codegen.h" |
| 9 #include "src/deoptimizer.h" | 9 #include "src/deoptimizer.h" |
| 10 #include "src/full-codegen/full-codegen.h" | 10 #include "src/full-codegen/full-codegen.h" |
| (...skipping 566 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 577 // it is present) and load it into kInterpreterBytecodeArrayRegister. | 577 // it is present) and load it into kInterpreterBytecodeArrayRegister. |
| 578 __ mov(eax, FieldOperand(edi, JSFunction::kSharedFunctionInfoOffset)); | 578 __ mov(eax, FieldOperand(edi, JSFunction::kSharedFunctionInfoOffset)); |
| 579 Label load_debug_bytecode_array, bytecode_array_loaded; | 579 Label load_debug_bytecode_array, bytecode_array_loaded; |
| 580 __ cmp(FieldOperand(eax, SharedFunctionInfo::kDebugInfoOffset), | 580 __ cmp(FieldOperand(eax, SharedFunctionInfo::kDebugInfoOffset), |
| 581 Immediate(DebugInfo::uninitialized())); | 581 Immediate(DebugInfo::uninitialized())); |
| 582 __ j(not_equal, &load_debug_bytecode_array); | 582 __ j(not_equal, &load_debug_bytecode_array); |
| 583 __ mov(kInterpreterBytecodeArrayRegister, | 583 __ mov(kInterpreterBytecodeArrayRegister, |
| 584 FieldOperand(eax, SharedFunctionInfo::kFunctionDataOffset)); | 584 FieldOperand(eax, SharedFunctionInfo::kFunctionDataOffset)); |
| 585 __ bind(&bytecode_array_loaded); | 585 __ bind(&bytecode_array_loaded); |
| 586 | 586 |
| 587 // Check whether we should continue to use the interpreter. |
| 588 Label switch_to_different_code_kind; |
| 589 __ Move(ecx, masm->CodeObject()); // Self-reference to this code. |
| 590 __ cmp(ecx, FieldOperand(eax, SharedFunctionInfo::kCodeOffset)); |
| 591 __ j(not_equal, &switch_to_different_code_kind); |
| 592 |
| 587 // Check function data field is actually a BytecodeArray object. | 593 // Check function data field is actually a BytecodeArray object. |
| 588 Label bytecode_array_not_present; | |
| 589 __ CompareRoot(kInterpreterBytecodeArrayRegister, | |
| 590 Heap::kUndefinedValueRootIndex); | |
| 591 __ j(equal, &bytecode_array_not_present); | |
| 592 if (FLAG_debug_code) { | 594 if (FLAG_debug_code) { |
| 593 __ AssertNotSmi(kInterpreterBytecodeArrayRegister); | 595 __ AssertNotSmi(kInterpreterBytecodeArrayRegister); |
| 594 __ CmpObjectType(kInterpreterBytecodeArrayRegister, BYTECODE_ARRAY_TYPE, | 596 __ CmpObjectType(kInterpreterBytecodeArrayRegister, BYTECODE_ARRAY_TYPE, |
| 595 eax); | 597 eax); |
| 596 __ Assert(equal, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry); | 598 __ Assert(equal, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry); |
| 597 } | 599 } |
| 598 | 600 |
| 599 // Push bytecode array. | 601 // Push bytecode array. |
| 600 __ push(kInterpreterBytecodeArrayRegister); | 602 __ push(kInterpreterBytecodeArrayRegister); |
| 601 // Push Smi tagged initial bytecode array offset. | 603 // Push Smi tagged initial bytecode array offset. |
| (...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 653 __ ret(0); | 655 __ ret(0); |
| 654 | 656 |
| 655 // Load debug copy of the bytecode array. | 657 // Load debug copy of the bytecode array. |
| 656 __ bind(&load_debug_bytecode_array); | 658 __ bind(&load_debug_bytecode_array); |
| 657 Register debug_info = kInterpreterBytecodeArrayRegister; | 659 Register debug_info = kInterpreterBytecodeArrayRegister; |
| 658 __ mov(debug_info, FieldOperand(eax, SharedFunctionInfo::kDebugInfoOffset)); | 660 __ mov(debug_info, FieldOperand(eax, SharedFunctionInfo::kDebugInfoOffset)); |
| 659 __ mov(kInterpreterBytecodeArrayRegister, | 661 __ mov(kInterpreterBytecodeArrayRegister, |
| 660 FieldOperand(debug_info, DebugInfo::kDebugBytecodeArrayIndex)); | 662 FieldOperand(debug_info, DebugInfo::kDebugBytecodeArrayIndex)); |
| 661 __ jmp(&bytecode_array_loaded); | 663 __ jmp(&bytecode_array_loaded); |
| 662 | 664 |
| 663 // If the bytecode array is no longer present, then the underlying function | 665 // If the shared code is no longer this entry trampoline, then the underlying |
| 664 // has been switched to a different kind of code and we heal the closure by | 666 // function has been switched to a different kind of code and we heal the |
| 665 // switching the code entry field over to the new code object as well. | 667 // closure by switching the code entry field over to the new code as well. |
| 666 __ bind(&bytecode_array_not_present); | 668 __ bind(&switch_to_different_code_kind); |
| 667 __ pop(edx); // Callee's new target. | 669 __ pop(edx); // Callee's new target. |
| 668 __ pop(edi); // Callee's JS function. | 670 __ pop(edi); // Callee's JS function. |
| 669 __ pop(esi); // Callee's context. | 671 __ pop(esi); // Callee's context. |
| 670 __ leave(); // Leave the frame so we can tail call. | 672 __ leave(); // Leave the frame so we can tail call. |
| 671 __ mov(ecx, FieldOperand(edi, JSFunction::kSharedFunctionInfoOffset)); | 673 __ mov(ecx, FieldOperand(edi, JSFunction::kSharedFunctionInfoOffset)); |
| 672 __ mov(ecx, FieldOperand(ecx, SharedFunctionInfo::kCodeOffset)); | 674 __ mov(ecx, FieldOperand(ecx, SharedFunctionInfo::kCodeOffset)); |
| 673 __ lea(ecx, FieldOperand(ecx, Code::kHeaderSize)); | 675 __ lea(ecx, FieldOperand(ecx, Code::kHeaderSize)); |
| 674 __ mov(FieldOperand(edi, JSFunction::kCodeEntryOffset), ecx); | 676 __ mov(FieldOperand(edi, JSFunction::kCodeEntryOffset), ecx); |
| 675 __ RecordWriteCodeEntryField(edi, ecx, ebx); | 677 __ RecordWriteCodeEntryField(edi, ecx, ebx); |
| 676 __ jmp(ecx); | 678 __ jmp(ecx); |
| (...skipping 2351 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3028 | 3030 |
| 3029 void Builtins::Generate_InterpreterOnStackReplacement(MacroAssembler* masm) { | 3031 void Builtins::Generate_InterpreterOnStackReplacement(MacroAssembler* masm) { |
| 3030 Generate_OnStackReplacementHelper(masm, true); | 3032 Generate_OnStackReplacementHelper(masm, true); |
| 3031 } | 3033 } |
| 3032 | 3034 |
| 3033 #undef __ | 3035 #undef __ |
| 3034 } // namespace internal | 3036 } // namespace internal |
| 3035 } // namespace v8 | 3037 } // namespace v8 |
| 3036 | 3038 |
| 3037 #endif // V8_TARGET_ARCH_IA32 | 3039 #endif // V8_TARGET_ARCH_IA32 |
| OLD | NEW |