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/crankshaft/s390/lithium-s390.h" | 5 #include "src/crankshaft/s390/lithium-s390.h" |
6 | 6 |
7 #include <sstream> | 7 #include <sstream> |
8 | 8 |
9 #include "src/crankshaft/hydrogen-osr.h" | 9 #include "src/crankshaft/hydrogen-osr.h" |
10 #include "src/crankshaft/lithium-inl.h" | 10 #include "src/crankshaft/lithium-inl.h" |
(...skipping 903 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
914 return DefineAsRegister(new (zone()) LContext); | 914 return DefineAsRegister(new (zone()) LContext); |
915 } | 915 } |
916 | 916 |
917 LInstruction* LChunkBuilder::DoDeclareGlobals(HDeclareGlobals* instr) { | 917 LInstruction* LChunkBuilder::DoDeclareGlobals(HDeclareGlobals* instr) { |
918 LOperand* context = UseFixed(instr->context(), cp); | 918 LOperand* context = UseFixed(instr->context(), cp); |
919 return MarkAsCall(new (zone()) LDeclareGlobals(context), instr); | 919 return MarkAsCall(new (zone()) LDeclareGlobals(context), instr); |
920 } | 920 } |
921 | 921 |
922 LInstruction* LChunkBuilder::DoCallWithDescriptor(HCallWithDescriptor* instr) { | 922 LInstruction* LChunkBuilder::DoCallWithDescriptor(HCallWithDescriptor* instr) { |
923 CallInterfaceDescriptor descriptor = instr->descriptor(); | 923 CallInterfaceDescriptor descriptor = instr->descriptor(); |
| 924 DCHECK_EQ(descriptor.GetParameterCount() + |
| 925 LCallWithDescriptor::kImplicitRegisterParameterCount, |
| 926 instr->OperandCount()); |
924 | 927 |
925 LOperand* target = UseRegisterOrConstantAtStart(instr->target()); | 928 LOperand* target = UseRegisterOrConstantAtStart(instr->target()); |
926 ZoneList<LOperand*> ops(instr->OperandCount(), zone()); | 929 ZoneList<LOperand*> ops(instr->OperandCount(), zone()); |
927 // Target | 930 // Target |
928 ops.Add(target, zone()); | 931 ops.Add(target, zone()); |
929 // Context | 932 // Context |
930 LOperand* op = UseFixed(instr->OperandAt(1), cp); | 933 LOperand* op = UseFixed(instr->OperandAt(1), cp); |
931 ops.Add(op, zone()); | 934 ops.Add(op, zone()); |
932 // Other register parameters | 935 // Load register parameters. |
933 for (int i = LCallWithDescriptor::kImplicitRegisterParameterCount; | 936 int i = 0; |
934 i < instr->OperandCount(); i++) { | 937 for (; i < descriptor.GetRegisterParameterCount(); i++) { |
935 op = | 938 op = UseFixed(instr->OperandAt( |
936 UseFixed(instr->OperandAt(i), | 939 i + LCallWithDescriptor::kImplicitRegisterParameterCount), |
937 descriptor.GetRegisterParameter( | 940 descriptor.GetRegisterParameter(i)); |
938 i - LCallWithDescriptor::kImplicitRegisterParameterCount)); | |
939 ops.Add(op, zone()); | 941 ops.Add(op, zone()); |
940 } | 942 } |
| 943 // Push stack parameters. |
| 944 for (; i < descriptor.GetParameterCount(); i++) { |
| 945 op = UseAny(instr->OperandAt( |
| 946 i + LCallWithDescriptor::kImplicitRegisterParameterCount)); |
| 947 AddInstruction(new (zone()) LPushArgument(op), instr); |
| 948 } |
941 | 949 |
942 LCallWithDescriptor* result = | 950 LCallWithDescriptor* result = |
943 new (zone()) LCallWithDescriptor(descriptor, ops, zone()); | 951 new (zone()) LCallWithDescriptor(descriptor, ops, zone()); |
944 if (instr->syntactic_tail_call_mode() == TailCallMode::kAllow) { | 952 if (instr->syntactic_tail_call_mode() == TailCallMode::kAllow) { |
945 result->MarkAsSyntacticTailCall(); | 953 result->MarkAsSyntacticTailCall(); |
946 } | 954 } |
947 return MarkAsCall(DefineFixed(result, r2), instr); | 955 return MarkAsCall(DefineFixed(result, r2), instr); |
948 } | 956 } |
949 | 957 |
950 LInstruction* LChunkBuilder::DoInvokeFunction(HInvokeFunction* instr) { | 958 LInstruction* LChunkBuilder::DoInvokeFunction(HInvokeFunction* instr) { |
(...skipping 1260 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2211 LInstruction* LChunkBuilder::DoLoadFieldByIndex(HLoadFieldByIndex* instr) { | 2219 LInstruction* LChunkBuilder::DoLoadFieldByIndex(HLoadFieldByIndex* instr) { |
2212 LOperand* object = UseRegister(instr->object()); | 2220 LOperand* object = UseRegister(instr->object()); |
2213 LOperand* index = UseTempRegister(instr->index()); | 2221 LOperand* index = UseTempRegister(instr->index()); |
2214 LLoadFieldByIndex* load = new (zone()) LLoadFieldByIndex(object, index); | 2222 LLoadFieldByIndex* load = new (zone()) LLoadFieldByIndex(object, index); |
2215 LInstruction* result = DefineSameAsFirst(load); | 2223 LInstruction* result = DefineSameAsFirst(load); |
2216 return AssignPointerMap(result); | 2224 return AssignPointerMap(result); |
2217 } | 2225 } |
2218 | 2226 |
2219 } // namespace internal | 2227 } // namespace internal |
2220 } // namespace v8 | 2228 } // namespace v8 |
OLD | NEW |