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 #if V8_TARGET_ARCH_PPC | 5 #if V8_TARGET_ARCH_PPC |
6 | 6 |
7 #include "src/ppc/constants-ppc.h" | 7 #include "src/ppc/constants-ppc.h" |
8 | 8 |
9 | 9 |
10 namespace v8 { | 10 namespace v8 { |
11 namespace internal { | 11 namespace internal { |
12 | 12 |
13 // These register names are defined in a way to match the native disassembler | 13 // These register names are defined in a way to match the native disassembler |
14 // formatting. See for example the command "objdump -d <binary file>". | 14 // formatting. See for example the command "objdump -d <binary file>". |
15 const char* Registers::names_[kNumRegisters] = { | 15 const char* Registers::names_[kNumRegisters] = { |
16 "r0", "sp", "r2", "r3", "r4", "r5", "r6", "r7", "r8", "r9", "r10", | 16 "r0", "sp", "r2", "r3", "r4", "r5", "r6", "r7", "r8", "r9", "r10", |
17 "r11", "r12", "r13", "r14", "r15", "r16", "r17", "r18", "r19", "r20", "r21", | 17 "r11", "ip", "r13", "r14", "r15", "r16", "r17", "r18", "r19", "r20", "r21", |
18 "r22", "r23", "r24", "r25", "r26", "r27", "r28", "r29", "r30", "fp"}; | 18 "r22", "r23", "r24", "r25", "r26", "r27", "r28", "r29", "r30", "fp"}; |
19 | 19 |
20 | 20 |
21 // List of alias names which can be used when referring to PPC registers. | 21 const char* DoubleRegisters::names_[kNumDoubleRegisters] = { |
22 const Registers::RegisterAlias Registers::aliases_[] = {{10, "sl"}, | |
23 {11, "r11"}, | |
24 {12, "r12"}, | |
25 {13, "r13"}, | |
26 {14, "r14"}, | |
27 {15, "r15"}, | |
28 {kNoRegister, NULL}}; | |
29 | |
30 | |
31 const char* Registers::Name(int reg) { | |
32 const char* result; | |
33 if ((0 <= reg) && (reg < kNumRegisters)) { | |
34 result = names_[reg]; | |
35 } else { | |
36 result = "noreg"; | |
37 } | |
38 return result; | |
39 } | |
40 | |
41 | |
42 const char* FPRegisters::names_[kNumFPRegisters] = { | |
43 "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7", "d8", "d9", "d10", | 22 "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7", "d8", "d9", "d10", |
44 "d11", "d12", "d13", "d14", "d15", "d16", "d17", "d18", "d19", "d20", "d21", | 23 "d11", "d12", "d13", "d14", "d15", "d16", "d17", "d18", "d19", "d20", "d21", |
45 "d22", "d23", "d24", "d25", "d26", "d27", "d28", "d29", "d30", "d31"}; | 24 "d22", "d23", "d24", "d25", "d26", "d27", "d28", "d29", "d30", "d31"}; |
46 | 25 |
47 | 26 |
48 const char* FPRegisters::Name(int reg) { | 27 int DoubleRegisters::Number(const char* name) { |
49 DCHECK((0 <= reg) && (reg < kNumFPRegisters)); | 28 for (int i = 0; i < kNumDoubleRegisters; i++) { |
50 return names_[reg]; | |
51 } | |
52 | |
53 | |
54 int FPRegisters::Number(const char* name) { | |
55 for (int i = 0; i < kNumFPRegisters; i++) { | |
56 if (strcmp(names_[i], name) == 0) { | 29 if (strcmp(names_[i], name) == 0) { |
57 return i; | 30 return i; |
58 } | 31 } |
59 } | 32 } |
60 | 33 |
61 // No register with the requested name found. | 34 // No register with the requested name found. |
62 return kNoRegister; | 35 return kNoRegister; |
63 } | 36 } |
64 | 37 |
65 | 38 |
66 int Registers::Number(const char* name) { | 39 int Registers::Number(const char* name) { |
67 // Look through the canonical names. | 40 // Look through the canonical names. |
68 for (int i = 0; i < kNumRegisters; i++) { | 41 for (int i = 0; i < kNumRegisters; i++) { |
69 if (strcmp(names_[i], name) == 0) { | 42 if (strcmp(names_[i], name) == 0) { |
70 return i; | 43 return i; |
71 } | 44 } |
72 } | 45 } |
73 | 46 |
74 // Look through the alias names. | |
75 int i = 0; | |
76 while (aliases_[i].reg != kNoRegister) { | |
77 if (strcmp(aliases_[i].name, name) == 0) { | |
78 return aliases_[i].reg; | |
79 } | |
80 i++; | |
81 } | |
82 | |
83 // No register with the requested name found. | 47 // No register with the requested name found. |
84 return kNoRegister; | 48 return kNoRegister; |
85 } | 49 } |
86 } // namespace internal | 50 } // namespace internal |
87 } // namespace v8 | 51 } // namespace v8 |
88 | 52 |
89 #endif // V8_TARGET_ARCH_PPC | 53 #endif // V8_TARGET_ARCH_PPC |
OLD | NEW |