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 |