1 // Copyright 2015 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #if V8_TARGET_ARCH_S390
6 
7 #include "src/s390/constants-s390.h"
8 
9 namespace v8 {
10 namespace internal {
11 
12 Instruction::OpcodeFormatType Instruction::OpcodeFormatTable[] = {
13     // Based on Figure B-3 in z/Architecture Principles of
14     // Operation.
15     TWO_BYTE_OPCODE,           // 0x00
16     TWO_BYTE_OPCODE,           // 0x01
17     TWO_BYTE_DISJOINT_OPCODE,  // 0x02
18     TWO_BYTE_DISJOINT_OPCODE,  // 0x03
19     ONE_BYTE_OPCODE,           // 0x04
20     ONE_BYTE_OPCODE,           // 0x05
21     ONE_BYTE_OPCODE,           // 0x06
22     ONE_BYTE_OPCODE,           // 0x07
23     ONE_BYTE_OPCODE,           // 0x08
24     ONE_BYTE_OPCODE,           // 0x09
25     ONE_BYTE_OPCODE,           // 0x0a
26     ONE_BYTE_OPCODE,           // 0x0b
27     ONE_BYTE_OPCODE,           // 0x0c
28     ONE_BYTE_OPCODE,           // 0x0d
29     ONE_BYTE_OPCODE,           // 0x0e
30     ONE_BYTE_OPCODE,           // 0x0f
31     ONE_BYTE_OPCODE,           // 0x10
32     ONE_BYTE_OPCODE,           // 0x11
33     ONE_BYTE_OPCODE,           // 0x12
34     ONE_BYTE_OPCODE,           // 0x13
35     ONE_BYTE_OPCODE,           // 0x14
36     ONE_BYTE_OPCODE,           // 0x15
37     ONE_BYTE_OPCODE,           // 0x16
38     ONE_BYTE_OPCODE,           // 0x17
39     ONE_BYTE_OPCODE,           // 0x18
40     ONE_BYTE_OPCODE,           // 0x19
41     ONE_BYTE_OPCODE,           // 0x1a
42     ONE_BYTE_OPCODE,           // 0x1b
43     ONE_BYTE_OPCODE,           // 0x1c
44     ONE_BYTE_OPCODE,           // 0x1d
45     ONE_BYTE_OPCODE,           // 0x1e
46     ONE_BYTE_OPCODE,           // 0x1f
47     ONE_BYTE_OPCODE,           // 0x20
48     ONE_BYTE_OPCODE,           // 0x21
49     ONE_BYTE_OPCODE,           // 0x22
50     ONE_BYTE_OPCODE,           // 0x23
51     ONE_BYTE_OPCODE,           // 0x24
52     ONE_BYTE_OPCODE,           // 0x25
53     ONE_BYTE_OPCODE,           // 0x26
54     ONE_BYTE_OPCODE,           // 0x27
55     ONE_BYTE_OPCODE,           // 0x28
56     ONE_BYTE_OPCODE,           // 0x29
57     ONE_BYTE_OPCODE,           // 0x2a
58     ONE_BYTE_OPCODE,           // 0x2b
59     ONE_BYTE_OPCODE,           // 0x2c
60     ONE_BYTE_OPCODE,           // 0x2d
61     ONE_BYTE_OPCODE,           // 0x2e
62     ONE_BYTE_OPCODE,           // 0x2f
63     ONE_BYTE_OPCODE,           // 0x30
64     ONE_BYTE_OPCODE,           // 0x31
65     ONE_BYTE_OPCODE,           // 0x32
66     ONE_BYTE_OPCODE,           // 0x33
67     ONE_BYTE_OPCODE,           // 0x34
68     ONE_BYTE_OPCODE,           // 0x35
69     ONE_BYTE_OPCODE,           // 0x36
70     ONE_BYTE_OPCODE,           // 0x37
71     ONE_BYTE_OPCODE,           // 0x38
72     ONE_BYTE_OPCODE,           // 0x39
73     ONE_BYTE_OPCODE,           // 0x3a
74     ONE_BYTE_OPCODE,           // 0x3b
75     ONE_BYTE_OPCODE,           // 0x3c
76     ONE_BYTE_OPCODE,           // 0x3d
77     ONE_BYTE_OPCODE,           // 0x3e
78     ONE_BYTE_OPCODE,           // 0x3f
79     ONE_BYTE_OPCODE,           // 0x40
80     ONE_BYTE_OPCODE,           // 0x41
81     ONE_BYTE_OPCODE,           // 0x42
82     ONE_BYTE_OPCODE,           // 0x43
83     ONE_BYTE_OPCODE,           // 0x44
84     ONE_BYTE_OPCODE,           // 0x45
85     ONE_BYTE_OPCODE,           // 0x46
86     ONE_BYTE_OPCODE,           // 0x47
87     ONE_BYTE_OPCODE,           // 0x48
88     ONE_BYTE_OPCODE,           // 0x49
89     ONE_BYTE_OPCODE,           // 0x4a
90     ONE_BYTE_OPCODE,           // 0x4b
91     ONE_BYTE_OPCODE,           // 0x4c
92     ONE_BYTE_OPCODE,           // 0x4d
93     ONE_BYTE_OPCODE,           // 0x4e
94     ONE_BYTE_OPCODE,           // 0x4f
95     ONE_BYTE_OPCODE,           // 0x50
96     ONE_BYTE_OPCODE,           // 0x51
97     ONE_BYTE_OPCODE,           // 0x52
98     ONE_BYTE_OPCODE,           // 0x53
99     ONE_BYTE_OPCODE,           // 0x54
100     ONE_BYTE_OPCODE,           // 0x55
101     ONE_BYTE_OPCODE,           // 0x56
102     ONE_BYTE_OPCODE,           // 0x57
103     ONE_BYTE_OPCODE,           // 0x58
104     ONE_BYTE_OPCODE,           // 0x59
105     ONE_BYTE_OPCODE,           // 0x5a
106     ONE_BYTE_OPCODE,           // 0x5b
107     ONE_BYTE_OPCODE,           // 0x5c
108     ONE_BYTE_OPCODE,           // 0x5d
109     ONE_BYTE_OPCODE,           // 0x5e
110     ONE_BYTE_OPCODE,           // 0x5f
111     ONE_BYTE_OPCODE,           // 0x60
112     ONE_BYTE_OPCODE,           // 0x61
113     ONE_BYTE_OPCODE,           // 0x62
114     ONE_BYTE_OPCODE,           // 0x63
115     ONE_BYTE_OPCODE,           // 0x64
116     ONE_BYTE_OPCODE,           // 0x65
117     ONE_BYTE_OPCODE,           // 0x66
118     ONE_BYTE_OPCODE,           // 0x67
119     ONE_BYTE_OPCODE,           // 0x68
120     ONE_BYTE_OPCODE,           // 0x69
121     ONE_BYTE_OPCODE,           // 0x6a
122     ONE_BYTE_OPCODE,           // 0x6b
123     ONE_BYTE_OPCODE,           // 0x6c
124     ONE_BYTE_OPCODE,           // 0x6d
125     ONE_BYTE_OPCODE,           // 0x6e
126     ONE_BYTE_OPCODE,           // 0x6f
127     ONE_BYTE_OPCODE,           // 0x70
128     ONE_BYTE_OPCODE,           // 0x71
129     ONE_BYTE_OPCODE,           // 0x72
130     ONE_BYTE_OPCODE,           // 0x73
131     ONE_BYTE_OPCODE,           // 0x74
132     ONE_BYTE_OPCODE,           // 0x75
133     ONE_BYTE_OPCODE,           // 0x76
134     ONE_BYTE_OPCODE,           // 0x77
135     ONE_BYTE_OPCODE,           // 0x78
136     ONE_BYTE_OPCODE,           // 0x79
137     ONE_BYTE_OPCODE,           // 0x7a
138     ONE_BYTE_OPCODE,           // 0x7b
139     ONE_BYTE_OPCODE,           // 0x7c
140     ONE_BYTE_OPCODE,           // 0x7d
141     ONE_BYTE_OPCODE,           // 0x7e
142     ONE_BYTE_OPCODE,           // 0x7f
143     ONE_BYTE_OPCODE,           // 0x80
144     ONE_BYTE_OPCODE,           // 0x81
145     ONE_BYTE_OPCODE,           // 0x82
146     ONE_BYTE_OPCODE,           // 0x83
147     ONE_BYTE_OPCODE,           // 0x84
148     ONE_BYTE_OPCODE,           // 0x85
149     ONE_BYTE_OPCODE,           // 0x86
150     ONE_BYTE_OPCODE,           // 0x87
151     ONE_BYTE_OPCODE,           // 0x88
152     ONE_BYTE_OPCODE,           // 0x89
153     ONE_BYTE_OPCODE,           // 0x8a
154     ONE_BYTE_OPCODE,           // 0x8b
155     ONE_BYTE_OPCODE,           // 0x8c
156     ONE_BYTE_OPCODE,           // 0x8d
157     ONE_BYTE_OPCODE,           // 0x8e
158     ONE_BYTE_OPCODE,           // 0x8f
159     ONE_BYTE_OPCODE,           // 0x90
160     ONE_BYTE_OPCODE,           // 0x91
161     ONE_BYTE_OPCODE,           // 0x92
162     ONE_BYTE_OPCODE,           // 0x93
163     ONE_BYTE_OPCODE,           // 0x94
164     ONE_BYTE_OPCODE,           // 0x95
165     ONE_BYTE_OPCODE,           // 0x96
166     ONE_BYTE_OPCODE,           // 0x97
167     ONE_BYTE_OPCODE,           // 0x98
168     ONE_BYTE_OPCODE,           // 0x99
169     ONE_BYTE_OPCODE,           // 0x9a
170     ONE_BYTE_OPCODE,           // 0x9b
171     TWO_BYTE_DISJOINT_OPCODE,  // 0x9c
172     TWO_BYTE_DISJOINT_OPCODE,  // 0x9d
173     TWO_BYTE_DISJOINT_OPCODE,  // 0x9e
174     TWO_BYTE_DISJOINT_OPCODE,  // 0x9f
175     TWO_BYTE_DISJOINT_OPCODE,  // 0xa0
176     TWO_BYTE_DISJOINT_OPCODE,  // 0xa1
177     TWO_BYTE_DISJOINT_OPCODE,  // 0xa2
178     TWO_BYTE_DISJOINT_OPCODE,  // 0xa3
179     TWO_BYTE_DISJOINT_OPCODE,  // 0xa4
180     THREE_NIBBLE_OPCODE,       // 0xa5
181     TWO_BYTE_DISJOINT_OPCODE,  // 0xa6
182     THREE_NIBBLE_OPCODE,       // 0xa7
183     ONE_BYTE_OPCODE,           // 0xa8
184     ONE_BYTE_OPCODE,           // 0xa9
185     ONE_BYTE_OPCODE,           // 0xaa
186     ONE_BYTE_OPCODE,           // 0xab
187     ONE_BYTE_OPCODE,           // 0xac
188     ONE_BYTE_OPCODE,           // 0xad
189     ONE_BYTE_OPCODE,           // 0xae
190     ONE_BYTE_OPCODE,           // 0xaf
191     ONE_BYTE_OPCODE,           // 0xb0
192     ONE_BYTE_OPCODE,           // 0xb1
193     TWO_BYTE_OPCODE,           // 0xb2
194     TWO_BYTE_OPCODE,           // 0xb3
195     TWO_BYTE_DISJOINT_OPCODE,  // 0xb4
196     TWO_BYTE_DISJOINT_OPCODE,  // 0xb5
197     TWO_BYTE_DISJOINT_OPCODE,  // 0xb6
198     TWO_BYTE_DISJOINT_OPCODE,  // 0xb7
199     TWO_BYTE_DISJOINT_OPCODE,  // 0xb8
200     TWO_BYTE_OPCODE,           // 0xb9
201     ONE_BYTE_OPCODE,           // 0xba
202     ONE_BYTE_OPCODE,           // 0xbb
203     ONE_BYTE_OPCODE,           // 0xbc
204     ONE_BYTE_OPCODE,           // 0xbd
205     ONE_BYTE_OPCODE,           // 0xbe
206     ONE_BYTE_OPCODE,           // 0xbf
207     THREE_NIBBLE_OPCODE,       // 0xc0
208     THREE_NIBBLE_OPCODE,       // 0xc1
209     THREE_NIBBLE_OPCODE,       // 0xc2
210     THREE_NIBBLE_OPCODE,       // 0xc3
211     THREE_NIBBLE_OPCODE,       // 0xc4
212     THREE_NIBBLE_OPCODE,       // 0xc5
213     THREE_NIBBLE_OPCODE,       // 0xc6
214     ONE_BYTE_OPCODE,           // 0xc7
215     THREE_NIBBLE_OPCODE,       // 0xc8
216     THREE_NIBBLE_OPCODE,       // 0xc9
217     THREE_NIBBLE_OPCODE,       // 0xca
218     THREE_NIBBLE_OPCODE,       // 0xcb
219     THREE_NIBBLE_OPCODE,       // 0xcc
220     TWO_BYTE_DISJOINT_OPCODE,  // 0xcd
221     TWO_BYTE_DISJOINT_OPCODE,  // 0xce
222     TWO_BYTE_DISJOINT_OPCODE,  // 0xcf
223     ONE_BYTE_OPCODE,           // 0xd0
224     ONE_BYTE_OPCODE,           // 0xd1
225     ONE_BYTE_OPCODE,           // 0xd2
226     ONE_BYTE_OPCODE,           // 0xd3
227     ONE_BYTE_OPCODE,           // 0xd4
228     ONE_BYTE_OPCODE,           // 0xd5
229     ONE_BYTE_OPCODE,           // 0xd6
230     ONE_BYTE_OPCODE,           // 0xd7
231     ONE_BYTE_OPCODE,           // 0xd8
232     ONE_BYTE_OPCODE,           // 0xd9
233     ONE_BYTE_OPCODE,           // 0xda
234     ONE_BYTE_OPCODE,           // 0xdb
235     ONE_BYTE_OPCODE,           // 0xdc
236     ONE_BYTE_OPCODE,           // 0xdd
237     ONE_BYTE_OPCODE,           // 0xde
238     ONE_BYTE_OPCODE,           // 0xdf
239     ONE_BYTE_OPCODE,           // 0xe0
240     ONE_BYTE_OPCODE,           // 0xe1
241     ONE_BYTE_OPCODE,           // 0xe2
242     TWO_BYTE_DISJOINT_OPCODE,  // 0xe3
243     TWO_BYTE_DISJOINT_OPCODE,  // 0xe4
244     TWO_BYTE_OPCODE,           // 0xe5
245     TWO_BYTE_DISJOINT_OPCODE,  // 0xe6
246     TWO_BYTE_DISJOINT_OPCODE,  // 0xe7
247     ONE_BYTE_OPCODE,           // 0xe8
248     ONE_BYTE_OPCODE,           // 0xe9
249     ONE_BYTE_OPCODE,           // 0xea
250     TWO_BYTE_DISJOINT_OPCODE,  // 0xeb
251     TWO_BYTE_DISJOINT_OPCODE,  // 0xec
252     TWO_BYTE_DISJOINT_OPCODE,  // 0xed
253     ONE_BYTE_OPCODE,           // 0xee
254     ONE_BYTE_OPCODE,           // 0xef
255     ONE_BYTE_OPCODE,           // 0xf0
256     ONE_BYTE_OPCODE,           // 0xf1
257     ONE_BYTE_OPCODE,           // 0xf2
258     ONE_BYTE_OPCODE,           // 0xf3
259     ONE_BYTE_OPCODE,           // 0xf4
260     ONE_BYTE_OPCODE,           // 0xf5
261     ONE_BYTE_OPCODE,           // 0xf6
262     ONE_BYTE_OPCODE,           // 0xf7
263     ONE_BYTE_OPCODE,           // 0xf8
264     ONE_BYTE_OPCODE,           // 0xf9
265     ONE_BYTE_OPCODE,           // 0xfa
266     ONE_BYTE_OPCODE,           // 0xfb
267     ONE_BYTE_OPCODE,           // 0xfc
268     ONE_BYTE_OPCODE,           // 0xfd
269     TWO_BYTE_DISJOINT_OPCODE,  // 0xfe
270     TWO_BYTE_DISJOINT_OPCODE,  // 0xff
271 };
272 
273 // These register names are defined in a way to match the native disassembler
274 // formatting. See for example the command "objdump -d <binary file>".
275 const char* Registers::names_[kNumRegisters] = {
276     "r0", "r1", "r2",  "r3", "r4", "r5",  "r6",  "r7",
277     "r8", "r9", "r10", "fp", "ip", "r13", "r14", "sp"};
278 
279 const char* DoubleRegisters::names_[kNumDoubleRegisters] = {
280     "f0", "f1", "f2",  "f3",  "f4",  "f5",  "f6",  "f7",
281     "f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15"};
282 
Number(const char * name)283 int DoubleRegisters::Number(const char* name) {
284   for (int i = 0; i < kNumDoubleRegisters; i++) {
285     if (strcmp(names_[i], name) == 0) {
286       return i;
287     }
288   }
289 
290   // No register with the requested name found.
291   return kNoRegister;
292 }
293 
Number(const char * name)294 int Registers::Number(const char* name) {
295   // Look through the canonical names.
296   for (int i = 0; i < kNumRegisters; i++) {
297     if (strcmp(names_[i], name) == 0) {
298       return i;
299     }
300   }
301 
302   // No register with the requested name found.
303   return kNoRegister;
304 }
305 
306 }  // namespace internal
307 }  // namespace v8
308 
309 #endif  // V8_TARGET_ARCH_S390
310