OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 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_ARM64 | 5 #if V8_TARGET_ARCH_ARM64 |
6 | 6 |
7 #include "src/base/bits.h" | 7 #include "src/base/bits.h" |
8 #include "src/base/division-by-constant.h" | 8 #include "src/base/division-by-constant.h" |
9 #include "src/bootstrapper.h" | 9 #include "src/bootstrapper.h" |
10 #include "src/codegen.h" | 10 #include "src/codegen.h" |
(...skipping 2651 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2662 Mov(code_reg, Operand(CodeObject())); | 2662 Mov(code_reg, Operand(CodeObject())); |
2663 Push(code_reg); | 2663 Push(code_reg); |
2664 Add(fp, jssp, InternalFrameConstants::kFixedFrameSizeFromFp); | 2664 Add(fp, jssp, InternalFrameConstants::kFixedFrameSizeFromFp); |
2665 // jssp[4] : lr | 2665 // jssp[4] : lr |
2666 // jssp[3] : fp | 2666 // jssp[3] : fp |
2667 // jssp[1] : type | 2667 // jssp[1] : type |
2668 // jssp[0] : [code object] | 2668 // jssp[0] : [code object] |
2669 } else if (type == StackFrame::WASM_COMPILED) { | 2669 } else if (type == StackFrame::WASM_COMPILED) { |
2670 DCHECK(csp.Is(StackPointer())); | 2670 DCHECK(csp.Is(StackPointer())); |
2671 Mov(type_reg, Smi::FromInt(type)); | 2671 Mov(type_reg, Smi::FromInt(type)); |
2672 Push(xzr, lr); | 2672 Push(lr, fp); |
2673 Push(fp, type_reg); | 2673 Mov(fp, csp); |
2674 Add(fp, csp, TypedFrameConstants::kFixedFrameSizeFromFp); | 2674 Push(type_reg, xzr); |
2675 // csp[3] for alignment | 2675 // csp[3] : lr |
2676 // csp[2] : lr | 2676 // csp[2] : fp |
2677 // csp[1] : fp | 2677 // csp[1] : type |
2678 // csp[0] : type | 2678 // csp[0] : for alignment |
2679 } else { | 2679 } else { |
2680 DCHECK(jssp.Is(StackPointer())); | 2680 DCHECK(jssp.Is(StackPointer())); |
2681 Mov(type_reg, Smi::FromInt(type)); | 2681 Mov(type_reg, Smi::FromInt(type)); |
2682 Push(lr, fp); | 2682 Push(lr, fp); |
2683 Push(type_reg); | 2683 Push(type_reg); |
2684 Add(fp, jssp, TypedFrameConstants::kFixedFrameSizeFromFp); | 2684 Add(fp, jssp, TypedFrameConstants::kFixedFrameSizeFromFp); |
2685 // jssp[2] : lr | 2685 // jssp[2] : lr |
2686 // jssp[1] : fp | 2686 // jssp[1] : fp |
2687 // jssp[0] : type | 2687 // jssp[0] : type |
2688 } | 2688 } |
2689 } | 2689 } |
2690 | 2690 |
2691 | 2691 |
2692 void MacroAssembler::LeaveFrame(StackFrame::Type type) { | 2692 void MacroAssembler::LeaveFrame(StackFrame::Type type) { |
2693 DCHECK(jssp.Is(StackPointer())); | 2693 if (type == StackFrame::WASM_COMPILED) { |
2694 // Drop the execution stack down to the frame pointer and restore | 2694 DCHECK(csp.Is(StackPointer())); |
2695 // the caller frame pointer and return address. | 2695 Mov(csp, fp); |
2696 Mov(jssp, fp); | 2696 AssertStackConsistency(); |
2697 AssertStackConsistency(); | 2697 Pop(fp, lr); |
2698 Pop(fp, lr); | 2698 } else { |
| 2699 DCHECK(jssp.Is(StackPointer())); |
| 2700 // Drop the execution stack down to the frame pointer and restore |
| 2701 // the caller frame pointer and return address. |
| 2702 Mov(jssp, fp); |
| 2703 AssertStackConsistency(); |
| 2704 Pop(fp, lr); |
| 2705 } |
2699 } | 2706 } |
2700 | 2707 |
2701 | 2708 |
2702 void MacroAssembler::ExitFramePreserveFPRegs() { | 2709 void MacroAssembler::ExitFramePreserveFPRegs() { |
2703 PushCPURegList(kCallerSavedFP); | 2710 PushCPURegList(kCallerSavedFP); |
2704 } | 2711 } |
2705 | 2712 |
2706 | 2713 |
2707 void MacroAssembler::ExitFrameRestoreFPRegs() { | 2714 void MacroAssembler::ExitFrameRestoreFPRegs() { |
2708 // Read the registers from the stack without popping them. The stack pointer | 2715 // Read the registers from the stack without popping them. The stack pointer |
(...skipping 1969 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4678 } | 4685 } |
4679 | 4686 |
4680 | 4687 |
4681 #undef __ | 4688 #undef __ |
4682 | 4689 |
4683 | 4690 |
4684 } // namespace internal | 4691 } // namespace internal |
4685 } // namespace v8 | 4692 } // namespace v8 |
4686 | 4693 |
4687 #endif // V8_TARGET_ARCH_ARM64 | 4694 #endif // V8_TARGET_ARCH_ARM64 |
OLD | NEW |