Chromium Code Reviews| 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/assembler.h" | 5 #include "src/assembler.h" |
| 6 #include "src/code-stubs.h" | 6 #include "src/code-stubs.h" |
| 7 #include "src/compiler/linkage.h" | 7 #include "src/compiler/linkage.h" |
| 8 #include "src/compiler/linkage-impl.h" | 8 #include "src/compiler/linkage-impl.h" |
| 9 #include "src/zone.h" | 9 #include "src/zone.h" |
| 10 | 10 |
| 11 namespace v8 { | 11 namespace v8 { |
| 12 namespace internal { | 12 namespace internal { |
| 13 namespace compiler { | 13 namespace compiler { |
| 14 | 14 |
| 15 struct PPCLinkageHelperTraits { | 15 struct PPCLinkageHelperTraits { |
| 16 static Register ReturnValueReg() { return r3; } | 16 static Register ReturnValueReg() { return r3; } |
| 17 static Register ReturnValue2Reg() { return r4; } | 17 static Register ReturnValue2Reg() { return r4; } |
| 18 static Register JSCallFunctionReg() { return r4; } | 18 static Register JSCallFunctionReg() { return r4; } |
| 19 static Register ContextReg() { return cp; } | 19 static Register ContextReg() { return cp; } |
| 20 static Register RuntimeCallFunctionReg() { return r4; } | 20 static Register RuntimeCallFunctionReg() { return r4; } |
| 21 static Register RuntimeCallArgCountReg() { return r3; } | 21 static Register RuntimeCallArgCountReg() { return r3; } |
| 22 static RegList CCalleeSaveRegisters() { | 22 static RegList CCalleeSaveRegisters() { |
| 23 return r14.bit() | r15.bit() | r16.bit() | r17.bit() | r18.bit() | | 23 return r14.bit() | r15.bit() | r16.bit() | r17.bit() | r18.bit() | |
| 24 r19.bit() | r20.bit() | r21.bit() | r22.bit() | r23.bit() | | 24 r19.bit() | r20.bit() | r21.bit() | r22.bit() | r23.bit() | |
| 25 r24.bit() | r25.bit() | r26.bit() | r27.bit() | r28.bit() | | 25 r24.bit() | r25.bit() | r26.bit() | r27.bit() | r28.bit() | |
| 26 r29.bit() | r30.bit() | fp.bit(); | 26 r29.bit() | r30.bit() | fp.bit(); |
| 27 } | 27 } |
| 28 static RegList CCalleeSaveFPURegisters() { | |
| 29 // TODO(palfia): finish. | |
|
paul.l...
2015/06/15 23:05:17
I think the ppc callee saved are d14-d31.However,
akos.palfi.imgtec
2015/06/22 17:33:20
Acknowledged.
| |
| 30 return 0; | |
| 31 } | |
| 28 static Register CRegisterParameter(int i) { | 32 static Register CRegisterParameter(int i) { |
| 29 static Register register_parameters[] = {r3, r4, r5, r6, r7, r8, r9, r10}; | 33 static Register register_parameters[] = {r3, r4, r5, r6, r7, r8, r9, r10}; |
| 30 return register_parameters[i]; | 34 return register_parameters[i]; |
| 31 } | 35 } |
| 32 static int CRegisterParametersLength() { return 8; } | 36 static int CRegisterParametersLength() { return 8; } |
| 33 }; | 37 }; |
| 34 | 38 |
| 35 | 39 |
| 36 typedef LinkageHelper<PPCLinkageHelperTraits> LH; | 40 typedef LinkageHelper<PPCLinkageHelperTraits> LH; |
| 37 | 41 |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 61 | 65 |
| 62 | 66 |
| 63 CallDescriptor* Linkage::GetSimplifiedCDescriptor(Zone* zone, | 67 CallDescriptor* Linkage::GetSimplifiedCDescriptor(Zone* zone, |
| 64 const MachineSignature* sig) { | 68 const MachineSignature* sig) { |
| 65 return LH::GetSimplifiedCDescriptor(zone, sig); | 69 return LH::GetSimplifiedCDescriptor(zone, sig); |
| 66 } | 70 } |
| 67 | 71 |
| 68 } // namespace compiler | 72 } // namespace compiler |
| 69 } // namespace internal | 73 } // namespace internal |
| 70 } // namespace v8 | 74 } // namespace v8 |
| OLD | NEW |