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