| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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/compiler/code-generator.h" | 5 #include "src/compiler/code-generator.h" |
| 6 | 6 |
| 7 #include "src/arm64/macro-assembler-arm64.h" | 7 #include "src/arm64/macro-assembler-arm64.h" |
| 8 #include "src/compiler/code-generator-impl.h" | 8 #include "src/compiler/code-generator-impl.h" |
| 9 #include "src/compiler/gap-resolver.h" | 9 #include "src/compiler/gap-resolver.h" |
| 10 #include "src/compiler/node-matchers.h" | 10 #include "src/compiler/node-matchers.h" |
| (...skipping 869 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 880 | 880 |
| 881 // TODO(dcarney): increase stack slots in frame once before first use. | 881 // TODO(dcarney): increase stack slots in frame once before first use. |
| 882 static int AlignedStackSlots(int stack_slots) { | 882 static int AlignedStackSlots(int stack_slots) { |
| 883 if (stack_slots & 1) stack_slots++; | 883 if (stack_slots & 1) stack_slots++; |
| 884 return stack_slots; | 884 return stack_slots; |
| 885 } | 885 } |
| 886 | 886 |
| 887 | 887 |
| 888 void CodeGenerator::AssemblePrologue() { | 888 void CodeGenerator::AssemblePrologue() { |
| 889 CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); | 889 CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); |
| 890 int stack_slots = frame()->GetSpillSlotCount(); |
| 890 if (descriptor->kind() == CallDescriptor::kCallAddress) { | 891 if (descriptor->kind() == CallDescriptor::kCallAddress) { |
| 891 __ SetStackPointer(csp); | 892 __ SetStackPointer(csp); |
| 892 __ Push(lr, fp); | 893 __ Push(lr, fp); |
| 893 __ Mov(fp, csp); | 894 __ Mov(fp, csp); |
| 894 // TODO(dcarney): correct callee saved registers. | 895 // TODO(dcarney): correct callee saved registers. |
| 895 __ PushCalleeSavedRegisters(); | 896 __ PushCalleeSavedRegisters(); |
| 896 frame()->SetRegisterSaveAreaSize(20 * kPointerSize); | 897 frame()->SetRegisterSaveAreaSize(20 * kPointerSize); |
| 897 } else if (descriptor->IsJSFunctionCall()) { | 898 } else if (descriptor->IsJSFunctionCall()) { |
| 898 CompilationInfo* info = this->info(); | 899 CompilationInfo* info = this->info(); |
| 899 __ SetStackPointer(jssp); | 900 __ SetStackPointer(jssp); |
| 900 __ Prologue(info->IsCodePreAgingActive()); | 901 __ Prologue(info->IsCodePreAgingActive()); |
| 901 frame()->SetRegisterSaveAreaSize( | 902 frame()->SetRegisterSaveAreaSize( |
| 902 StandardFrameConstants::kFixedFrameSizeFromFp); | 903 StandardFrameConstants::kFixedFrameSizeFromFp); |
| 903 } else { | 904 } else if (stack_slots > 0) { |
| 904 __ SetStackPointer(jssp); | 905 __ SetStackPointer(jssp); |
| 905 __ StubPrologue(); | 906 __ StubPrologue(); |
| 906 frame()->SetRegisterSaveAreaSize( | 907 frame()->SetRegisterSaveAreaSize( |
| 907 StandardFrameConstants::kFixedFrameSizeFromFp); | 908 StandardFrameConstants::kFixedFrameSizeFromFp); |
| 908 } | 909 } |
| 909 int stack_slots = frame()->GetSpillSlotCount(); | |
| 910 | 910 |
| 911 if (info()->is_osr()) { | 911 if (info()->is_osr()) { |
| 912 // TurboFan OSR-compiled functions cannot be entered directly. | 912 // TurboFan OSR-compiled functions cannot be entered directly. |
| 913 __ Abort(kShouldNotDirectlyEnterOsrFunction); | 913 __ Abort(kShouldNotDirectlyEnterOsrFunction); |
| 914 | 914 |
| 915 // Unoptimized code jumps directly to this entrypoint while the unoptimized | 915 // Unoptimized code jumps directly to this entrypoint while the unoptimized |
| 916 // frame is still on the stack. Optimized code uses OSR values directly from | 916 // frame is still on the stack. Optimized code uses OSR values directly from |
| 917 // the unoptimized frame. Thus, all that needs to be done is to allocate the | 917 // the unoptimized frame. Thus, all that needs to be done is to allocate the |
| 918 // remaining stack slots. | 918 // remaining stack slots. |
| 919 if (FLAG_code_comments) __ RecordComment("-- OSR entrypoint --"); | 919 if (FLAG_code_comments) __ RecordComment("-- OSR entrypoint --"); |
| 920 osr_pc_offset_ = __ pc_offset(); | 920 osr_pc_offset_ = __ pc_offset(); |
| 921 DCHECK(stack_slots >= frame()->GetOsrStackSlotCount()); | 921 DCHECK(stack_slots >= frame()->GetOsrStackSlotCount()); |
| 922 stack_slots -= frame()->GetOsrStackSlotCount(); | 922 stack_slots -= frame()->GetOsrStackSlotCount(); |
| 923 } | 923 } |
| 924 | 924 |
| 925 if (stack_slots > 0) { | 925 if (stack_slots > 0) { |
| 926 Register sp = __ StackPointer(); | 926 Register sp = __ StackPointer(); |
| 927 if (!sp.Is(csp)) { | 927 if (!sp.Is(csp)) { |
| 928 __ Sub(sp, sp, stack_slots * kPointerSize); | 928 __ Sub(sp, sp, stack_slots * kPointerSize); |
| 929 } | 929 } |
| 930 __ Sub(csp, csp, AlignedStackSlots(stack_slots) * kPointerSize); | 930 __ Sub(csp, csp, AlignedStackSlots(stack_slots) * kPointerSize); |
| 931 } | 931 } |
| 932 } | 932 } |
| 933 | 933 |
| 934 | 934 |
| 935 void CodeGenerator::AssembleReturn() { | 935 void CodeGenerator::AssembleReturn() { |
| 936 CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); | 936 CallDescriptor* descriptor = linkage()->GetIncomingDescriptor(); |
| 937 int stack_slots = frame()->GetSpillSlotCount(); |
| 937 if (descriptor->kind() == CallDescriptor::kCallAddress) { | 938 if (descriptor->kind() == CallDescriptor::kCallAddress) { |
| 938 if (frame()->GetRegisterSaveAreaSize() > 0) { | 939 if (frame()->GetRegisterSaveAreaSize() > 0) { |
| 939 // Remove this frame's spill slots first. | 940 // Remove this frame's spill slots first. |
| 940 int stack_slots = frame()->GetSpillSlotCount(); | |
| 941 if (stack_slots > 0) { | 941 if (stack_slots > 0) { |
| 942 __ Add(csp, csp, AlignedStackSlots(stack_slots) * kPointerSize); | 942 __ Add(csp, csp, AlignedStackSlots(stack_slots) * kPointerSize); |
| 943 } | 943 } |
| 944 // Restore registers. | 944 // Restore registers. |
| 945 // TODO(dcarney): correct callee saved registers. | 945 // TODO(dcarney): correct callee saved registers. |
| 946 __ PopCalleeSavedRegisters(); | 946 __ PopCalleeSavedRegisters(); |
| 947 } | 947 } |
| 948 __ Mov(csp, fp); | 948 __ Mov(csp, fp); |
| 949 __ Pop(fp, lr); | 949 __ Pop(fp, lr); |
| 950 __ Ret(); | 950 __ Ret(); |
| 951 } else { | 951 } else if (descriptor->IsJSFunctionCall() || stack_slots > 0) { |
| 952 __ Mov(jssp, fp); | 952 __ Mov(jssp, fp); |
| 953 __ Pop(fp, lr); | 953 __ Pop(fp, lr); |
| 954 int pop_count = descriptor->IsJSFunctionCall() | 954 int pop_count = descriptor->IsJSFunctionCall() |
| 955 ? static_cast<int>(descriptor->JSParameterCount()) | 955 ? static_cast<int>(descriptor->JSParameterCount()) |
| 956 : 0; | 956 : 0; |
| 957 __ Drop(pop_count); | 957 __ Drop(pop_count); |
| 958 __ Ret(); | 958 __ Ret(); |
| 959 } else { |
| 960 __ Ret(); |
| 959 } | 961 } |
| 960 } | 962 } |
| 961 | 963 |
| 962 | 964 |
| 963 void CodeGenerator::AssembleMove(InstructionOperand* source, | 965 void CodeGenerator::AssembleMove(InstructionOperand* source, |
| 964 InstructionOperand* destination) { | 966 InstructionOperand* destination) { |
| 965 Arm64OperandConverter g(this, NULL); | 967 Arm64OperandConverter g(this, NULL); |
| 966 // Dispatch on the source and destination operand kinds. Not all | 968 // Dispatch on the source and destination operand kinds. Not all |
| 967 // combinations are possible. | 969 // combinations are possible. |
| 968 if (source->IsRegister()) { | 970 if (source->IsRegister()) { |
| (...skipping 163 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1132 } | 1134 } |
| 1133 } | 1135 } |
| 1134 MarkLazyDeoptSite(); | 1136 MarkLazyDeoptSite(); |
| 1135 } | 1137 } |
| 1136 | 1138 |
| 1137 #undef __ | 1139 #undef __ |
| 1138 | 1140 |
| 1139 } // namespace compiler | 1141 } // namespace compiler |
| 1140 } // namespace internal | 1142 } // namespace internal |
| 1141 } // namespace v8 | 1143 } // namespace v8 |
| OLD | NEW |