Commit | Line | Data |
---|---|---|
252b5132 | 1 | /* Information for instruction disassembly on the Convex. |
e4e42b45 | 2 | Copyright 1989, 1993, 2002, 2010 Free Software Foundation, Inc. |
252b5132 | 3 | |
e4e42b45 | 4 | This file is part of GDB. |
252b5132 | 5 | |
e4e42b45 NC |
6 | This program is free software; you can redistribute it and/or modify |
7 | it under the terms of the GNU General Public License as published by | |
8 | the Free Software Foundation; either version 3 of the License, or | |
9 | (at your option) any later version. | |
252b5132 | 10 | |
e4e42b45 NC |
11 | This program is distributed in the hope that it will be useful, |
12 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 | GNU General Public License for more details. | |
252b5132 | 15 | |
e4e42b45 NC |
16 | You should have received a copy of the GNU General Public License |
17 | along with this program; if not, write to the Free Software | |
18 | Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, | |
19 | MA 02110-1301, USA. */ | |
252b5132 | 20 | |
252b5132 RH |
21 | #define xxx 0 |
22 | #define rrr 1 | |
23 | #define rr 2 | |
24 | #define rxr 3 | |
25 | #define r 4 | |
26 | #define nops 5 | |
27 | #define nr 6 | |
28 | #define pcrel 7 | |
29 | #define lr 8 | |
30 | #define rxl 9 | |
31 | #define rlr 10 | |
32 | #define rrl 11 | |
33 | #define iml 12 | |
34 | #define imr 13 | |
35 | #define a1r 14 | |
36 | #define a1l 15 | |
37 | #define a2r 16 | |
38 | #define a2l 17 | |
39 | #define a3 18 | |
40 | #define a4 19 | |
41 | #define a5 20 | |
42 | #define V 1 | |
43 | #define S 2 | |
44 | #define VM 3 | |
45 | #define A 4 | |
46 | #define VL 5 | |
47 | #define VS 6 | |
48 | #define VLS 7 | |
49 | #define PSW 8 | |
50 | /* Prevent an error during "make depend". */ | |
51 | #if !defined (PC) | |
52 | #define PC 9 | |
53 | #endif | |
54 | #define ITR 10 | |
55 | #define VV 11 | |
56 | #define ITSR 12 | |
57 | #define TOC 13 | |
58 | #define CIR 14 | |
59 | #define TTR 15 | |
60 | #define VMU 16 | |
61 | #define VML 17 | |
62 | #define ICR 18 | |
63 | #define TCPU 19 | |
64 | #define CPUID 20 | |
65 | #define TID 21 | |
66 | ||
92007e40 | 67 | const char *op[] = { |
252b5132 RH |
68 | "", |
69 | "v0\0v1\0v2\0v3\0v4\0v5\0v6\0v7", | |
70 | "s0\0s1\0s2\0s3\0s4\0s5\0s6\0s7", | |
71 | "vm", | |
72 | "sp\0a1\0a2\0a3\0a4\0a5\0ap\0fp", | |
73 | "vl", | |
74 | "vs", | |
75 | "vls", | |
76 | "psw", | |
77 | "pc", | |
78 | "itr", | |
79 | "vv", | |
80 | "itsr", | |
81 | "toc", | |
82 | "cir", | |
83 | "ttr", | |
84 | "vmu", | |
85 | "vml", | |
86 | "icr", | |
87 | "tcpu", | |
88 | "cpuid", | |
89 | "tid", | |
90 | }; | |
91 | ||
92007e40 | 92 | const struct formstr format0[] = { |
252b5132 RH |
93 | {0,0,rrr,V,S,S}, /* mov */ |
94 | {0,0,rrr,S,S,V}, /* mov */ | |
95 | {1,1,rrr,V,V,V}, /* merg.t */ | |
96 | {2,1,rrr,V,V,V}, /* mask.t */ | |
97 | {1,2,rrr,V,S,V}, /* merg.f */ | |
98 | {2,2,rrr,V,S,V}, /* mask.f */ | |
99 | {1,1,rrr,V,S,V}, /* merg.t */ | |
100 | {2,1,rrr,V,S,V}, /* mask.t */ | |
101 | {3,3,rrr,V,V,V}, /* mul.s */ | |
102 | {3,4,rrr,V,V,V}, /* mul.d */ | |
103 | {4,3,rrr,V,V,V}, /* div.s */ | |
104 | {4,4,rrr,V,V,V}, /* div.d */ | |
105 | {3,3,rrr,V,S,V}, /* mul.s */ | |
106 | {3,4,rrr,V,S,V}, /* mul.d */ | |
107 | {4,3,rrr,V,S,V}, /* div.s */ | |
108 | {4,4,rrr,V,S,V}, /* div.d */ | |
109 | {5,0,rrr,V,V,V}, /* and */ | |
110 | {6,0,rrr,V,V,V}, /* or */ | |
111 | {7,0,rrr,V,V,V}, /* xor */ | |
112 | {8,0,rrr,V,V,V}, /* shf */ | |
113 | {5,0,rrr,V,S,V}, /* and */ | |
114 | {6,0,rrr,V,S,V}, /* or */ | |
115 | {7,0,rrr,V,S,V}, /* xor */ | |
116 | {8,0,rrr,V,S,V}, /* shf */ | |
117 | {9,3,rrr,V,V,V}, /* add.s */ | |
118 | {9,4,rrr,V,V,V}, /* add.d */ | |
119 | {10,3,rrr,V,V,V}, /* sub.s */ | |
120 | {10,4,rrr,V,V,V}, /* sub.d */ | |
121 | {9,3,rrr,V,S,V}, /* add.s */ | |
122 | {9,4,rrr,V,S,V}, /* add.d */ | |
123 | {10,3,rrr,V,S,V}, /* sub.s */ | |
124 | {10,4,rrr,V,S,V}, /* sub.d */ | |
125 | {9,5,rrr,V,V,V}, /* add.b */ | |
126 | {9,6,rrr,V,V,V}, /* add.h */ | |
127 | {9,7,rrr,V,V,V}, /* add.w */ | |
128 | {9,8,rrr,V,V,V}, /* add.l */ | |
129 | {9,5,rrr,V,S,V}, /* add.b */ | |
130 | {9,6,rrr,V,S,V}, /* add.h */ | |
131 | {9,7,rrr,V,S,V}, /* add.w */ | |
132 | {9,8,rrr,V,S,V}, /* add.l */ | |
133 | {10,5,rrr,V,V,V}, /* sub.b */ | |
134 | {10,6,rrr,V,V,V}, /* sub.h */ | |
135 | {10,7,rrr,V,V,V}, /* sub.w */ | |
136 | {10,8,rrr,V,V,V}, /* sub.l */ | |
137 | {10,5,rrr,V,S,V}, /* sub.b */ | |
138 | {10,6,rrr,V,S,V}, /* sub.h */ | |
139 | {10,7,rrr,V,S,V}, /* sub.w */ | |
140 | {10,8,rrr,V,S,V}, /* sub.l */ | |
141 | {3,5,rrr,V,V,V}, /* mul.b */ | |
142 | {3,6,rrr,V,V,V}, /* mul.h */ | |
143 | {3,7,rrr,V,V,V}, /* mul.w */ | |
144 | {3,8,rrr,V,V,V}, /* mul.l */ | |
145 | {3,5,rrr,V,S,V}, /* mul.b */ | |
146 | {3,6,rrr,V,S,V}, /* mul.h */ | |
147 | {3,7,rrr,V,S,V}, /* mul.w */ | |
148 | {3,8,rrr,V,S,V}, /* mul.l */ | |
149 | {4,5,rrr,V,V,V}, /* div.b */ | |
150 | {4,6,rrr,V,V,V}, /* div.h */ | |
151 | {4,7,rrr,V,V,V}, /* div.w */ | |
152 | {4,8,rrr,V,V,V}, /* div.l */ | |
153 | {4,5,rrr,V,S,V}, /* div.b */ | |
154 | {4,6,rrr,V,S,V}, /* div.h */ | |
155 | {4,7,rrr,V,S,V}, /* div.w */ | |
156 | {4,8,rrr,V,S,V}, /* div.l */ | |
157 | }; | |
158 | ||
92007e40 | 159 | const struct formstr format1[] = { |
252b5132 RH |
160 | {11,0,xxx,0,0,0}, /* exit */ |
161 | {12,0,a3,0,0,0}, /* jmp */ | |
162 | {13,2,a3,0,0,0}, /* jmpi.f */ | |
163 | {13,1,a3,0,0,0}, /* jmpi.t */ | |
164 | {14,2,a3,0,0,0}, /* jmpa.f */ | |
165 | {14,1,a3,0,0,0}, /* jmpa.t */ | |
166 | {15,2,a3,0,0,0}, /* jmps.f */ | |
167 | {15,1,a3,0,0,0}, /* jmps.t */ | |
168 | {16,0,a3,0,0,0}, /* tac */ | |
169 | {17,0,a1r,A,0,0}, /* ldea */ | |
170 | {18,8,a1l,VLS,0,0}, /* ld.l */ | |
171 | {18,9,a1l,VM,0,0}, /* ld.x */ | |
172 | {19,0,a3,0,0,0}, /* tas */ | |
173 | {20,0,a3,0,0,0}, /* pshea */ | |
174 | {21,8,a2l,VLS,0,0}, /* st.l */ | |
175 | {21,9,a2l,VM,0,0}, /* st.x */ | |
176 | {0,0,0,0,0,0}, | |
177 | {0,0,0,0,0,0}, | |
178 | {0,0,0,0,0,0}, | |
179 | {0,0,0,0,0,0}, | |
180 | {0,0,0,0,0,0}, | |
181 | {0,0,0,0,0,0}, | |
182 | {0,0,0,0,0,0}, | |
183 | {0,0,0,0,0,0}, | |
184 | {0,0,0,0,0,0}, | |
185 | {0,0,0,0,0,0}, | |
186 | {0,0,0,0,0,0}, | |
187 | {0,0,0,0,0,0}, | |
188 | {0,0,0,0,0,0}, | |
189 | {0,0,0,0,0,0}, | |
190 | {0,0,0,0,0,0}, | |
191 | {0,0,0,0,0,0}, | |
192 | {22,0,a3,0,0,0}, /* call */ | |
193 | {23,0,a3,0,0,0}, /* calls */ | |
194 | {24,0,a3,0,0,0}, /* callq */ | |
195 | {25,0,a1r,A,0,0}, /* pfork */ | |
196 | {26,5,a2r,S,0,0}, /* ste.b */ | |
197 | {26,6,a2r,S,0,0}, /* ste.h */ | |
198 | {26,7,a2r,S,0,0}, /* ste.w */ | |
199 | {26,8,a2r,S,0,0}, /* ste.l */ | |
200 | {18,5,a1r,A,0,0}, /* ld.b */ | |
201 | {18,6,a1r,A,0,0}, /* ld.h */ | |
202 | {18,7,a1r,A,0,0}, /* ld.w */ | |
203 | {27,7,a1r,A,0,0}, /* incr.w */ | |
204 | {21,5,a2r,A,0,0}, /* st.b */ | |
205 | {21,6,a2r,A,0,0}, /* st.h */ | |
206 | {21,7,a2r,A,0,0}, /* st.w */ | |
207 | {27,8,a1r,S,0,0}, /* incr.l */ | |
208 | {18,5,a1r,S,0,0}, /* ld.b */ | |
209 | {18,6,a1r,S,0,0}, /* ld.h */ | |
210 | {18,7,a1r,S,0,0}, /* ld.w */ | |
211 | {18,8,a1r,S,0,0}, /* ld.l */ | |
212 | {21,5,a2r,S,0,0}, /* st.b */ | |
213 | {21,6,a2r,S,0,0}, /* st.h */ | |
214 | {21,7,a2r,S,0,0}, /* st.w */ | |
215 | {21,8,a2r,S,0,0}, /* st.l */ | |
216 | {18,5,a1r,V,0,0}, /* ld.b */ | |
217 | {18,6,a1r,V,0,0}, /* ld.h */ | |
218 | {18,7,a1r,V,0,0}, /* ld.w */ | |
219 | {18,8,a1r,V,0,0}, /* ld.l */ | |
220 | {21,5,a2r,V,0,0}, /* st.b */ | |
221 | {21,6,a2r,V,0,0}, /* st.h */ | |
222 | {21,7,a2r,V,0,0}, /* st.w */ | |
223 | {21,8,a2r,V,0,0}, /* st.l */ | |
224 | }; | |
225 | ||
92007e40 | 226 | const struct formstr format2[] = { |
252b5132 RH |
227 | {28,5,rr,A,A,0}, /* cvtw.b */ |
228 | {28,6,rr,A,A,0}, /* cvtw.h */ | |
229 | {29,7,rr,A,A,0}, /* cvtb.w */ | |
230 | {30,7,rr,A,A,0}, /* cvth.w */ | |
231 | {28,5,rr,S,S,0}, /* cvtw.b */ | |
232 | {28,6,rr,S,S,0}, /* cvtw.h */ | |
233 | {29,7,rr,S,S,0}, /* cvtb.w */ | |
234 | {30,7,rr,S,S,0}, /* cvth.w */ | |
235 | {28,3,rr,S,S,0}, /* cvtw.s */ | |
236 | {31,7,rr,S,S,0}, /* cvts.w */ | |
237 | {32,3,rr,S,S,0}, /* cvtd.s */ | |
238 | {31,4,rr,S,S,0}, /* cvts.d */ | |
239 | {31,8,rr,S,S,0}, /* cvts.l */ | |
240 | {32,8,rr,S,S,0}, /* cvtd.l */ | |
241 | {33,3,rr,S,S,0}, /* cvtl.s */ | |
242 | {33,4,rr,S,S,0}, /* cvtl.d */ | |
243 | {34,0,rr,A,A,0}, /* ldpa */ | |
244 | {8,0,nr,A,0,0}, /* shf */ | |
245 | {18,6,nr,A,0,0}, /* ld.h */ | |
246 | {18,7,nr,A,0,0}, /* ld.w */ | |
247 | {33,7,rr,S,S,0}, /* cvtl.w */ | |
248 | {28,8,rr,S,S,0}, /* cvtw.l */ | |
249 | {35,1,rr,S,S,0}, /* plc.t */ | |
250 | {36,0,rr,S,S,0}, /* tzc */ | |
251 | {37,6,rr,A,A,0}, /* eq.h */ | |
252 | {37,7,rr,A,A,0}, /* eq.w */ | |
253 | {37,6,nr,A,0,0}, /* eq.h */ | |
254 | {37,7,nr,A,0,0}, /* eq.w */ | |
255 | {37,5,rr,S,S,0}, /* eq.b */ | |
256 | {37,6,rr,S,S,0}, /* eq.h */ | |
257 | {37,7,rr,S,S,0}, /* eq.w */ | |
258 | {37,8,rr,S,S,0}, /* eq.l */ | |
259 | {38,6,rr,A,A,0}, /* leu.h */ | |
260 | {38,7,rr,A,A,0}, /* leu.w */ | |
261 | {38,6,nr,A,0,0}, /* leu.h */ | |
262 | {38,7,nr,A,0,0}, /* leu.w */ | |
263 | {38,5,rr,S,S,0}, /* leu.b */ | |
264 | {38,6,rr,S,S,0}, /* leu.h */ | |
265 | {38,7,rr,S,S,0}, /* leu.w */ | |
266 | {38,8,rr,S,S,0}, /* leu.l */ | |
267 | {39,6,rr,A,A,0}, /* ltu.h */ | |
268 | {39,7,rr,A,A,0}, /* ltu.w */ | |
269 | {39,6,nr,A,0,0}, /* ltu.h */ | |
270 | {39,7,nr,A,0,0}, /* ltu.w */ | |
271 | {39,5,rr,S,S,0}, /* ltu.b */ | |
272 | {39,6,rr,S,S,0}, /* ltu.h */ | |
273 | {39,7,rr,S,S,0}, /* ltu.w */ | |
274 | {39,8,rr,S,S,0}, /* ltu.l */ | |
275 | {40,6,rr,A,A,0}, /* le.h */ | |
276 | {40,7,rr,A,A,0}, /* le.w */ | |
277 | {40,6,nr,A,0,0}, /* le.h */ | |
278 | {40,7,nr,A,0,0}, /* le.w */ | |
279 | {40,5,rr,S,S,0}, /* le.b */ | |
280 | {40,6,rr,S,S,0}, /* le.h */ | |
281 | {40,7,rr,S,S,0}, /* le.w */ | |
282 | {40,8,rr,S,S,0}, /* le.l */ | |
283 | {41,6,rr,A,A,0}, /* lt.h */ | |
284 | {41,7,rr,A,A,0}, /* lt.w */ | |
285 | {41,6,nr,A,0,0}, /* lt.h */ | |
286 | {41,7,nr,A,0,0}, /* lt.w */ | |
287 | {41,5,rr,S,S,0}, /* lt.b */ | |
288 | {41,6,rr,S,S,0}, /* lt.h */ | |
289 | {41,7,rr,S,S,0}, /* lt.w */ | |
290 | {41,8,rr,S,S,0}, /* lt.l */ | |
291 | {9,7,rr,S,A,0}, /* add.w */ | |
292 | {8,0,rr,A,A,0}, /* shf */ | |
293 | {0,0,rr,A,A,0}, /* mov */ | |
294 | {0,0,rr,S,A,0}, /* mov */ | |
295 | {0,7,rr,S,S,0}, /* mov.w */ | |
296 | {8,0,rr,S,S,0}, /* shf */ | |
297 | {0,0,rr,S,S,0}, /* mov */ | |
298 | {0,0,rr,A,S,0}, /* mov */ | |
299 | {5,0,rr,A,A,0}, /* and */ | |
300 | {6,0,rr,A,A,0}, /* or */ | |
301 | {7,0,rr,A,A,0}, /* xor */ | |
302 | {42,0,rr,A,A,0}, /* not */ | |
303 | {5,0,rr,S,S,0}, /* and */ | |
304 | {6,0,rr,S,S,0}, /* or */ | |
305 | {7,0,rr,S,S,0}, /* xor */ | |
306 | {42,0,rr,S,S,0}, /* not */ | |
307 | {40,3,rr,S,S,0}, /* le.s */ | |
308 | {40,4,rr,S,S,0}, /* le.d */ | |
309 | {41,3,rr,S,S,0}, /* lt.s */ | |
310 | {41,4,rr,S,S,0}, /* lt.d */ | |
311 | {9,3,rr,S,S,0}, /* add.s */ | |
312 | {9,4,rr,S,S,0}, /* add.d */ | |
313 | {10,3,rr,S,S,0}, /* sub.s */ | |
314 | {10,4,rr,S,S,0}, /* sub.d */ | |
315 | {37,3,rr,S,S,0}, /* eq.s */ | |
316 | {37,4,rr,S,S,0}, /* eq.d */ | |
317 | {43,6,rr,A,A,0}, /* neg.h */ | |
318 | {43,7,rr,A,A,0}, /* neg.w */ | |
319 | {3,3,rr,S,S,0}, /* mul.s */ | |
320 | {3,4,rr,S,S,0}, /* mul.d */ | |
321 | {4,3,rr,S,S,0}, /* div.s */ | |
322 | {4,4,rr,S,S,0}, /* div.d */ | |
323 | {9,6,rr,A,A,0}, /* add.h */ | |
324 | {9,7,rr,A,A,0}, /* add.w */ | |
325 | {9,6,nr,A,0,0}, /* add.h */ | |
326 | {9,7,nr,A,0,0}, /* add.w */ | |
327 | {9,5,rr,S,S,0}, /* add.b */ | |
328 | {9,6,rr,S,S,0}, /* add.h */ | |
329 | {9,7,rr,S,S,0}, /* add.w */ | |
330 | {9,8,rr,S,S,0}, /* add.l */ | |
331 | {10,6,rr,A,A,0}, /* sub.h */ | |
332 | {10,7,rr,A,A,0}, /* sub.w */ | |
333 | {10,6,nr,A,0,0}, /* sub.h */ | |
334 | {10,7,nr,A,0,0}, /* sub.w */ | |
335 | {10,5,rr,S,S,0}, /* sub.b */ | |
336 | {10,6,rr,S,S,0}, /* sub.h */ | |
337 | {10,7,rr,S,S,0}, /* sub.w */ | |
338 | {10,8,rr,S,S,0}, /* sub.l */ | |
339 | {3,6,rr,A,A,0}, /* mul.h */ | |
340 | {3,7,rr,A,A,0}, /* mul.w */ | |
341 | {3,6,nr,A,0,0}, /* mul.h */ | |
342 | {3,7,nr,A,0,0}, /* mul.w */ | |
343 | {3,5,rr,S,S,0}, /* mul.b */ | |
344 | {3,6,rr,S,S,0}, /* mul.h */ | |
345 | {3,7,rr,S,S,0}, /* mul.w */ | |
346 | {3,8,rr,S,S,0}, /* mul.l */ | |
347 | {4,6,rr,A,A,0}, /* div.h */ | |
348 | {4,7,rr,A,A,0}, /* div.w */ | |
349 | {4,6,nr,A,0,0}, /* div.h */ | |
350 | {4,7,nr,A,0,0}, /* div.w */ | |
351 | {4,5,rr,S,S,0}, /* div.b */ | |
352 | {4,6,rr,S,S,0}, /* div.h */ | |
353 | {4,7,rr,S,S,0}, /* div.w */ | |
354 | {4,8,rr,S,S,0}, /* div.l */ | |
355 | }; | |
356 | ||
92007e40 | 357 | const struct formstr format3[] = { |
252b5132 RH |
358 | {32,3,rr,V,V,0}, /* cvtd.s */ |
359 | {31,4,rr,V,V,0}, /* cvts.d */ | |
360 | {33,4,rr,V,V,0}, /* cvtl.d */ | |
361 | {32,8,rr,V,V,0}, /* cvtd.l */ | |
362 | {0,0,rrl,S,S,VM}, /* mov */ | |
363 | {0,0,rlr,S,VM,S}, /* mov */ | |
364 | {0,0,0,0,0,0}, | |
365 | {44,0,rr,S,S,0}, /* lop */ | |
366 | {36,0,rr,V,V,0}, /* tzc */ | |
367 | {44,0,rr,V,V,0}, /* lop */ | |
368 | {0,0,0,0,0,0}, | |
369 | {42,0,rr,V,V,0}, /* not */ | |
370 | {8,0,rr,S,V,0}, /* shf */ | |
371 | {35,1,rr,V,V,0}, /* plc.t */ | |
372 | {45,2,rr,V,V,0}, /* cprs.f */ | |
373 | {45,1,rr,V,V,0}, /* cprs.t */ | |
374 | {37,3,rr,V,V,0}, /* eq.s */ | |
375 | {37,4,rr,V,V,0}, /* eq.d */ | |
376 | {43,3,rr,V,V,0}, /* neg.s */ | |
377 | {43,4,rr,V,V,0}, /* neg.d */ | |
378 | {37,3,rr,S,V,0}, /* eq.s */ | |
379 | {37,4,rr,S,V,0}, /* eq.d */ | |
380 | {43,3,rr,S,S,0}, /* neg.s */ | |
381 | {43,4,rr,S,S,0}, /* neg.d */ | |
382 | {40,3,rr,V,V,0}, /* le.s */ | |
383 | {40,4,rr,V,V,0}, /* le.d */ | |
384 | {41,3,rr,V,V,0}, /* lt.s */ | |
385 | {41,4,rr,V,V,0}, /* lt.d */ | |
386 | {40,3,rr,S,V,0}, /* le.s */ | |
387 | {40,4,rr,S,V,0}, /* le.d */ | |
388 | {41,3,rr,S,V,0}, /* lt.s */ | |
389 | {41,4,rr,S,V,0}, /* lt.d */ | |
390 | {37,5,rr,V,V,0}, /* eq.b */ | |
391 | {37,6,rr,V,V,0}, /* eq.h */ | |
392 | {37,7,rr,V,V,0}, /* eq.w */ | |
393 | {37,8,rr,V,V,0}, /* eq.l */ | |
394 | {37,5,rr,S,V,0}, /* eq.b */ | |
395 | {37,6,rr,S,V,0}, /* eq.h */ | |
396 | {37,7,rr,S,V,0}, /* eq.w */ | |
397 | {37,8,rr,S,V,0}, /* eq.l */ | |
398 | {40,5,rr,V,V,0}, /* le.b */ | |
399 | {40,6,rr,V,V,0}, /* le.h */ | |
400 | {40,7,rr,V,V,0}, /* le.w */ | |
401 | {40,8,rr,V,V,0}, /* le.l */ | |
402 | {40,5,rr,S,V,0}, /* le.b */ | |
403 | {40,6,rr,S,V,0}, /* le.h */ | |
404 | {40,7,rr,S,V,0}, /* le.w */ | |
405 | {40,8,rr,S,V,0}, /* le.l */ | |
406 | {41,5,rr,V,V,0}, /* lt.b */ | |
407 | {41,6,rr,V,V,0}, /* lt.h */ | |
408 | {41,7,rr,V,V,0}, /* lt.w */ | |
409 | {41,8,rr,V,V,0}, /* lt.l */ | |
410 | {41,5,rr,S,V,0}, /* lt.b */ | |
411 | {41,6,rr,S,V,0}, /* lt.h */ | |
412 | {41,7,rr,S,V,0}, /* lt.w */ | |
413 | {41,8,rr,S,V,0}, /* lt.l */ | |
414 | {43,5,rr,V,V,0}, /* neg.b */ | |
415 | {43,6,rr,V,V,0}, /* neg.h */ | |
416 | {43,7,rr,V,V,0}, /* neg.w */ | |
417 | {43,8,rr,V,V,0}, /* neg.l */ | |
418 | {43,5,rr,S,S,0}, /* neg.b */ | |
419 | {43,6,rr,S,S,0}, /* neg.h */ | |
420 | {43,7,rr,S,S,0}, /* neg.w */ | |
421 | {43,8,rr,S,S,0}, /* neg.l */ | |
422 | }; | |
423 | ||
92007e40 | 424 | const struct formstr format4[] = { |
252b5132 RH |
425 | {46,0,nops,0,0,0}, /* nop */ |
426 | {47,0,pcrel,0,0,0}, /* br */ | |
427 | {48,2,pcrel,0,0,0}, /* bri.f */ | |
428 | {48,1,pcrel,0,0,0}, /* bri.t */ | |
429 | {49,2,pcrel,0,0,0}, /* bra.f */ | |
430 | {49,1,pcrel,0,0,0}, /* bra.t */ | |
431 | {50,2,pcrel,0,0,0}, /* brs.f */ | |
432 | {50,1,pcrel,0,0,0}, /* brs.t */ | |
433 | }; | |
434 | ||
92007e40 | 435 | const struct formstr format5[] = { |
252b5132 RH |
436 | {51,5,rr,V,V,0}, /* ldvi.b */ |
437 | {51,6,rr,V,V,0}, /* ldvi.h */ | |
438 | {51,7,rr,V,V,0}, /* ldvi.w */ | |
439 | {51,8,rr,V,V,0}, /* ldvi.l */ | |
440 | {28,3,rr,V,V,0}, /* cvtw.s */ | |
441 | {31,7,rr,V,V,0}, /* cvts.w */ | |
442 | {28,8,rr,V,V,0}, /* cvtw.l */ | |
443 | {33,7,rr,V,V,0}, /* cvtl.w */ | |
444 | {52,5,rxr,V,V,0}, /* stvi.b */ | |
445 | {52,6,rxr,V,V,0}, /* stvi.h */ | |
446 | {52,7,rxr,V,V,0}, /* stvi.w */ | |
447 | {52,8,rxr,V,V,0}, /* stvi.l */ | |
448 | {52,5,rxr,S,V,0}, /* stvi.b */ | |
449 | {52,6,rxr,S,V,0}, /* stvi.h */ | |
450 | {52,7,rxr,S,V,0}, /* stvi.w */ | |
451 | {52,8,rxr,S,V,0}, /* stvi.l */ | |
452 | }; | |
453 | ||
92007e40 | 454 | const struct formstr format6[] = { |
252b5132 RH |
455 | {53,0,r,A,0,0}, /* ldsdr */ |
456 | {54,0,r,A,0,0}, /* ldkdr */ | |
457 | {55,3,r,S,0,0}, /* ln.s */ | |
458 | {55,4,r,S,0,0}, /* ln.d */ | |
459 | {56,0,nops,0,0,0}, /* patu */ | |
460 | {57,0,r,A,0,0}, /* pate */ | |
461 | {58,0,nops,0,0,0}, /* pich */ | |
462 | {59,0,nops,0,0,0}, /* plch */ | |
463 | {0,0,lr,PSW,A,0}, /* mov */ | |
464 | {0,0,rxl,A,PSW,0}, /* mov */ | |
465 | {0,0,lr,PC,A,0}, /* mov */ | |
466 | {60,0,r,S,0,0}, /* idle */ | |
467 | {0,0,lr,ITR,S,0}, /* mov */ | |
468 | {0,0,rxl,S,ITR,0}, /* mov */ | |
469 | {0,0,0,0,0,0}, | |
470 | {0,0,rxl,S,ITSR,0}, /* mov */ | |
471 | {61,0,nops,0,0,0}, /* rtnq */ | |
472 | {62,0,nops,0,0,0}, /* cfork */ | |
473 | {63,0,nops,0,0,0}, /* rtn */ | |
474 | {64,0,nops,0,0,0}, /* wfork */ | |
475 | {65,0,nops,0,0,0}, /* join */ | |
476 | {66,0,nops,0,0,0}, /* rtnc */ | |
477 | {67,3,r,S,0,0}, /* exp.s */ | |
478 | {67,4,r,S,0,0}, /* exp.d */ | |
479 | {68,3,r,S,0,0}, /* sin.s */ | |
480 | {68,4,r,S,0,0}, /* sin.d */ | |
481 | {0,0,0,0,0,0}, | |
482 | {0,0,0,0,0,0}, | |
483 | {69,3,r,S,0,0}, /* cos.s */ | |
484 | {69,4,r,S,0,0}, /* cos.d */ | |
485 | {0,0,0,0,0,0}, | |
486 | {0,0,0,0,0,0}, | |
487 | {70,7,r,A,0,0}, /* psh.w */ | |
488 | {0,0,0,0,0,0}, | |
489 | {71,7,r,A,0,0}, /* pop.w */ | |
490 | {0,0,0,0,0,0}, | |
491 | {70,7,r,S,0,0}, /* psh.w */ | |
492 | {70,8,r,S,0,0}, /* psh.l */ | |
493 | {71,7,r,S,0,0}, /* pop.w */ | |
494 | {71,8,r,S,0,0}, /* pop.l */ | |
495 | {72,0,nops,0,0,0}, /* eni */ | |
496 | {73,0,nops,0,0,0}, /* dsi */ | |
497 | {74,0,nops,0,0,0}, /* bkpt */ | |
498 | {75,0,nops,0,0,0}, /* msync */ | |
499 | {76,0,r,S,0,0}, /* mski */ | |
500 | {77,0,r,S,0,0}, /* xmti */ | |
501 | {0,0,rxl,S,VV,0}, /* mov */ | |
502 | {78,0,nops,0,0,0}, /* tstvv */ | |
503 | {0,0,lr,VS,A,0}, /* mov */ | |
504 | {0,0,rxl,A,VS,0}, /* mov */ | |
505 | {0,0,lr,VL,A,0}, /* mov */ | |
506 | {0,0,rxl,A,VL,0}, /* mov */ | |
507 | {0,7,lr,VS,S,0}, /* mov.w */ | |
508 | {0,7,rxl,S,VS,0}, /* mov.w */ | |
509 | {0,7,lr,VL,S,0}, /* mov.w */ | |
510 | {0,7,rxl,S,VL,0}, /* mov.w */ | |
511 | {79,0,r,A,0,0}, /* diag */ | |
512 | {80,0,nops,0,0,0}, /* pbkpt */ | |
513 | {81,3,r,S,0,0}, /* sqrt.s */ | |
514 | {81,4,r,S,0,0}, /* sqrt.d */ | |
515 | {82,0,nops,0,0,0}, /* casr */ | |
516 | {0,0,0,0,0,0}, | |
517 | {83,3,r,S,0,0}, /* atan.s */ | |
518 | {83,4,r,S,0,0}, /* atan.d */ | |
519 | }; | |
520 | ||
92007e40 | 521 | const struct formstr format7[] = { |
252b5132 RH |
522 | {84,5,r,V,0,0}, /* sum.b */ |
523 | {84,6,r,V,0,0}, /* sum.h */ | |
524 | {84,7,r,V,0,0}, /* sum.w */ | |
525 | {84,8,r,V,0,0}, /* sum.l */ | |
526 | {85,0,r,V,0,0}, /* all */ | |
527 | {86,0,r,V,0,0}, /* any */ | |
528 | {87,0,r,V,0,0}, /* parity */ | |
529 | {0,0,0,0,0,0}, | |
530 | {88,5,r,V,0,0}, /* max.b */ | |
531 | {88,6,r,V,0,0}, /* max.h */ | |
532 | {88,7,r,V,0,0}, /* max.w */ | |
533 | {88,8,r,V,0,0}, /* max.l */ | |
534 | {89,5,r,V,0,0}, /* min.b */ | |
535 | {89,6,r,V,0,0}, /* min.h */ | |
536 | {89,7,r,V,0,0}, /* min.w */ | |
537 | {89,8,r,V,0,0}, /* min.l */ | |
538 | {84,3,r,V,0,0}, /* sum.s */ | |
539 | {84,4,r,V,0,0}, /* sum.d */ | |
540 | {90,3,r,V,0,0}, /* prod.s */ | |
541 | {90,4,r,V,0,0}, /* prod.d */ | |
542 | {88,3,r,V,0,0}, /* max.s */ | |
543 | {88,4,r,V,0,0}, /* max.d */ | |
544 | {89,3,r,V,0,0}, /* min.s */ | |
545 | {89,4,r,V,0,0}, /* min.d */ | |
546 | {90,5,r,V,0,0}, /* prod.b */ | |
547 | {90,6,r,V,0,0}, /* prod.h */ | |
548 | {90,7,r,V,0,0}, /* prod.w */ | |
549 | {90,8,r,V,0,0}, /* prod.l */ | |
550 | {35,2,lr,VM,S,0}, /* plc.f */ | |
551 | {35,1,lr,VM,S,0}, /* plc.t */ | |
552 | {0,0,0,0,0,0}, | |
553 | {0,0,0,0,0,0}, | |
554 | }; | |
555 | ||
92007e40 | 556 | const struct formstr formatx[] = { |
252b5132 RH |
557 | {0,0,0,0,0,0}, |
558 | }; | |
559 | ||
92007e40 | 560 | const struct formstr format1a[] = { |
252b5132 RH |
561 | {91,0,imr,A,0,0}, /* halt */ |
562 | {92,0,a4,0,0,0}, /* sysc */ | |
563 | {18,6,imr,A,0,0}, /* ld.h */ | |
564 | {18,7,imr,A,0,0}, /* ld.w */ | |
565 | {5,0,imr,A,0,0}, /* and */ | |
566 | {6,0,imr,A,0,0}, /* or */ | |
567 | {7,0,imr,A,0,0}, /* xor */ | |
568 | {8,0,imr,A,0,0}, /* shf */ | |
569 | {9,6,imr,A,0,0}, /* add.h */ | |
570 | {9,7,imr,A,0,0}, /* add.w */ | |
571 | {10,6,imr,A,0,0}, /* sub.h */ | |
572 | {10,7,imr,A,0,0}, /* sub.w */ | |
573 | {3,6,imr,A,0,0}, /* mul.h */ | |
574 | {3,7,imr,A,0,0}, /* mul.w */ | |
575 | {4,6,imr,A,0,0}, /* div.h */ | |
576 | {4,7,imr,A,0,0}, /* div.w */ | |
577 | {18,7,iml,VL,0,0}, /* ld.w */ | |
578 | {18,7,iml,VS,0,0}, /* ld.w */ | |
579 | {0,0,0,0,0,0}, | |
580 | {8,7,imr,S,0,0}, /* shf.w */ | |
581 | {93,0,a5,0,0,0}, /* trap */ | |
582 | {0,0,0,0,0,0}, | |
583 | {37,6,imr,A,0,0}, /* eq.h */ | |
584 | {37,7,imr,A,0,0}, /* eq.w */ | |
585 | {38,6,imr,A,0,0}, /* leu.h */ | |
586 | {38,7,imr,A,0,0}, /* leu.w */ | |
587 | {39,6,imr,A,0,0}, /* ltu.h */ | |
588 | {39,7,imr,A,0,0}, /* ltu.w */ | |
589 | {40,6,imr,A,0,0}, /* le.h */ | |
590 | {40,7,imr,A,0,0}, /* le.w */ | |
591 | {41,6,imr,A,0,0}, /* lt.h */ | |
592 | {41,7,imr,A,0,0}, /* lt.w */ | |
593 | }; | |
594 | ||
92007e40 | 595 | const struct formstr format1b[] = { |
252b5132 RH |
596 | {18,4,imr,S,0,0}, /* ld.d */ |
597 | {18,10,imr,S,0,0}, /* ld.u */ | |
598 | {18,8,imr,S,0,0}, /* ld.l */ | |
599 | {18,7,imr,S,0,0}, /* ld.w */ | |
600 | {5,0,imr,S,0,0}, /* and */ | |
601 | {6,0,imr,S,0,0}, /* or */ | |
602 | {7,0,imr,S,0,0}, /* xor */ | |
603 | {8,0,imr,S,0,0}, /* shf */ | |
604 | {9,6,imr,S,0,0}, /* add.h */ | |
605 | {9,7,imr,S,0,0}, /* add.w */ | |
606 | {10,6,imr,S,0,0}, /* sub.h */ | |
607 | {10,7,imr,S,0,0}, /* sub.w */ | |
608 | {3,6,imr,S,0,0}, /* mul.h */ | |
609 | {3,7,imr,S,0,0}, /* mul.w */ | |
610 | {4,6,imr,S,0,0}, /* div.h */ | |
611 | {4,7,imr,S,0,0}, /* div.w */ | |
612 | {9,3,imr,S,0,0}, /* add.s */ | |
613 | {10,3,imr,S,0,0}, /* sub.s */ | |
614 | {3,3,imr,S,0,0}, /* mul.s */ | |
615 | {4,3,imr,S,0,0}, /* div.s */ | |
616 | {40,3,imr,S,0,0}, /* le.s */ | |
617 | {41,3,imr,S,0,0}, /* lt.s */ | |
618 | {37,6,imr,S,0,0}, /* eq.h */ | |
619 | {37,7,imr,S,0,0}, /* eq.w */ | |
620 | {38,6,imr,S,0,0}, /* leu.h */ | |
621 | {38,7,imr,S,0,0}, /* leu.w */ | |
622 | {39,6,imr,S,0,0}, /* ltu.h */ | |
623 | {39,7,imr,S,0,0}, /* ltu.w */ | |
624 | {40,6,imr,S,0,0}, /* le.h */ | |
625 | {40,7,imr,S,0,0}, /* le.w */ | |
626 | {41,6,imr,S,0,0}, /* lt.h */ | |
627 | {41,7,imr,S,0,0}, /* lt.w */ | |
628 | }; | |
629 | ||
92007e40 | 630 | const struct formstr e0_format0[] = { |
252b5132 RH |
631 | {10,3,rrr,S,V,V}, /* sub.s */ |
632 | {10,4,rrr,S,V,V}, /* sub.d */ | |
633 | {4,3,rrr,S,V,V}, /* div.s */ | |
634 | {4,4,rrr,S,V,V}, /* div.d */ | |
635 | {10,11,rrr,S,V,V}, /* sub.s.f */ | |
636 | {10,12,rrr,S,V,V}, /* sub.d.f */ | |
637 | {4,11,rrr,S,V,V}, /* div.s.f */ | |
638 | {4,12,rrr,S,V,V}, /* div.d.f */ | |
639 | {3,11,rrr,V,V,V}, /* mul.s.f */ | |
640 | {3,12,rrr,V,V,V}, /* mul.d.f */ | |
641 | {4,11,rrr,V,V,V}, /* div.s.f */ | |
642 | {4,12,rrr,V,V,V}, /* div.d.f */ | |
643 | {3,11,rrr,V,S,V}, /* mul.s.f */ | |
644 | {3,12,rrr,V,S,V}, /* mul.d.f */ | |
645 | {4,11,rrr,V,S,V}, /* div.s.f */ | |
646 | {4,12,rrr,V,S,V}, /* div.d.f */ | |
647 | {5,2,rrr,V,V,V}, /* and.f */ | |
648 | {6,2,rrr,V,V,V}, /* or.f */ | |
649 | {7,2,rrr,V,V,V}, /* xor.f */ | |
650 | {8,2,rrr,V,V,V}, /* shf.f */ | |
651 | {5,2,rrr,V,S,V}, /* and.f */ | |
652 | {6,2,rrr,V,S,V}, /* or.f */ | |
653 | {7,2,rrr,V,S,V}, /* xor.f */ | |
654 | {8,2,rrr,V,S,V}, /* shf.f */ | |
655 | {9,11,rrr,V,V,V}, /* add.s.f */ | |
656 | {9,12,rrr,V,V,V}, /* add.d.f */ | |
657 | {10,11,rrr,V,V,V}, /* sub.s.f */ | |
658 | {10,12,rrr,V,V,V}, /* sub.d.f */ | |
659 | {9,11,rrr,V,S,V}, /* add.s.f */ | |
660 | {9,12,rrr,V,S,V}, /* add.d.f */ | |
661 | {10,11,rrr,V,S,V}, /* sub.s.f */ | |
662 | {10,12,rrr,V,S,V}, /* sub.d.f */ | |
663 | {9,13,rrr,V,V,V}, /* add.b.f */ | |
664 | {9,14,rrr,V,V,V}, /* add.h.f */ | |
665 | {9,15,rrr,V,V,V}, /* add.w.f */ | |
666 | {9,16,rrr,V,V,V}, /* add.l.f */ | |
667 | {9,13,rrr,V,S,V}, /* add.b.f */ | |
668 | {9,14,rrr,V,S,V}, /* add.h.f */ | |
669 | {9,15,rrr,V,S,V}, /* add.w.f */ | |
670 | {9,16,rrr,V,S,V}, /* add.l.f */ | |
671 | {10,13,rrr,V,V,V}, /* sub.b.f */ | |
672 | {10,14,rrr,V,V,V}, /* sub.h.f */ | |
673 | {10,15,rrr,V,V,V}, /* sub.w.f */ | |
674 | {10,16,rrr,V,V,V}, /* sub.l.f */ | |
675 | {10,13,rrr,V,S,V}, /* sub.b.f */ | |
676 | {10,14,rrr,V,S,V}, /* sub.h.f */ | |
677 | {10,15,rrr,V,S,V}, /* sub.w.f */ | |
678 | {10,16,rrr,V,S,V}, /* sub.l.f */ | |
679 | {3,13,rrr,V,V,V}, /* mul.b.f */ | |
680 | {3,14,rrr,V,V,V}, /* mul.h.f */ | |
681 | {3,15,rrr,V,V,V}, /* mul.w.f */ | |
682 | {3,16,rrr,V,V,V}, /* mul.l.f */ | |
683 | {3,13,rrr,V,S,V}, /* mul.b.f */ | |
684 | {3,14,rrr,V,S,V}, /* mul.h.f */ | |
685 | {3,15,rrr,V,S,V}, /* mul.w.f */ | |
686 | {3,16,rrr,V,S,V}, /* mul.l.f */ | |
687 | {4,13,rrr,V,V,V}, /* div.b.f */ | |
688 | {4,14,rrr,V,V,V}, /* div.h.f */ | |
689 | {4,15,rrr,V,V,V}, /* div.w.f */ | |
690 | {4,16,rrr,V,V,V}, /* div.l.f */ | |
691 | {4,13,rrr,V,S,V}, /* div.b.f */ | |
692 | {4,14,rrr,V,S,V}, /* div.h.f */ | |
693 | {4,15,rrr,V,S,V}, /* div.w.f */ | |
694 | {4,16,rrr,V,S,V}, /* div.l.f */ | |
695 | }; | |
696 | ||
92007e40 | 697 | const struct formstr e0_format1[] = { |
252b5132 RH |
698 | {0,0,0,0,0,0}, |
699 | {94,0,a3,0,0,0}, /* tst */ | |
700 | {95,0,a3,0,0,0}, /* lck */ | |
701 | {96,0,a3,0,0,0}, /* ulk */ | |
702 | {17,0,a1r,S,0,0}, /* ldea */ | |
703 | {97,0,a1r,A,0,0}, /* spawn */ | |
704 | {98,0,a1r,A,0,0}, /* ldcmr */ | |
705 | {99,0,a2r,A,0,0}, /* stcmr */ | |
706 | {100,0,a1r,A,0,0}, /* popr */ | |
707 | {101,0,a2r,A,0,0}, /* pshr */ | |
708 | {102,7,a1r,A,0,0}, /* rcvr.w */ | |
709 | {103,7,a2r,A,0,0}, /* matm.w */ | |
710 | {104,7,a2r,A,0,0}, /* sndr.w */ | |
711 | {104,8,a2r,S,0,0}, /* sndr.l */ | |
712 | {102,8,a1r,S,0,0}, /* rcvr.l */ | |
713 | {103,8,a2r,S,0,0}, /* matm.l */ | |
714 | {0,0,0,0,0,0}, | |
715 | {0,0,0,0,0,0}, | |
716 | {0,0,0,0,0,0}, | |
717 | {0,0,0,0,0,0}, | |
718 | {0,0,0,0,0,0}, | |
719 | {0,0,0,0,0,0}, | |
720 | {0,0,0,0,0,0}, | |
721 | {0,0,0,0,0,0}, | |
722 | {0,0,0,0,0,0}, | |
723 | {0,0,0,0,0,0}, | |
724 | {0,0,0,0,0,0}, | |
725 | {0,0,0,0,0,0}, | |
726 | {0,0,0,0,0,0}, | |
727 | {0,0,0,0,0,0}, | |
728 | {0,0,0,0,0,0}, | |
729 | {0,0,0,0,0,0}, | |
730 | {105,7,a2r,A,0,0}, /* putr.w */ | |
731 | {105,8,a2r,S,0,0}, /* putr.l */ | |
732 | {106,7,a1r,A,0,0}, /* getr.w */ | |
733 | {106,8,a1r,S,0,0}, /* getr.l */ | |
734 | {26,13,a2r,S,0,0}, /* ste.b.f */ | |
735 | {26,14,a2r,S,0,0}, /* ste.h.f */ | |
736 | {26,15,a2r,S,0,0}, /* ste.w.f */ | |
737 | {26,16,a2r,S,0,0}, /* ste.l.f */ | |
738 | {107,7,a2r,A,0,0}, /* matr.w */ | |
739 | {108,7,a2r,A,0,0}, /* mat.w */ | |
740 | {109,7,a1r,A,0,0}, /* get.w */ | |
741 | {110,7,a1r,A,0,0}, /* rcv.w */ | |
742 | {0,0,0,0,0,0}, | |
743 | {111,7,a1r,A,0,0}, /* inc.w */ | |
744 | {112,7,a2r,A,0,0}, /* put.w */ | |
745 | {113,7,a2r,A,0,0}, /* snd.w */ | |
746 | {107,8,a2r,S,0,0}, /* matr.l */ | |
747 | {108,8,a2r,S,0,0}, /* mat.l */ | |
748 | {109,8,a1r,S,0,0}, /* get.l */ | |
749 | {110,8,a1r,S,0,0}, /* rcv.l */ | |
750 | {0,0,0,0,0,0}, | |
751 | {111,8,a1r,S,0,0}, /* inc.l */ | |
752 | {112,8,a2r,S,0,0}, /* put.l */ | |
753 | {113,8,a2r,S,0,0}, /* snd.l */ | |
754 | {18,13,a1r,V,0,0}, /* ld.b.f */ | |
755 | {18,14,a1r,V,0,0}, /* ld.h.f */ | |
756 | {18,15,a1r,V,0,0}, /* ld.w.f */ | |
757 | {18,16,a1r,V,0,0}, /* ld.l.f */ | |
758 | {21,13,a2r,V,0,0}, /* st.b.f */ | |
759 | {21,14,a2r,V,0,0}, /* st.h.f */ | |
760 | {21,15,a2r,V,0,0}, /* st.w.f */ | |
761 | {21,16,a2r,V,0,0}, /* st.l.f */ | |
762 | }; | |
763 | ||
92007e40 | 764 | const struct formstr e0_format2[] = { |
252b5132 RH |
765 | {28,5,rr,V,V,0}, /* cvtw.b */ |
766 | {28,6,rr,V,V,0}, /* cvtw.h */ | |
767 | {29,7,rr,V,V,0}, /* cvtb.w */ | |
768 | {30,7,rr,V,V,0}, /* cvth.w */ | |
769 | {28,13,rr,V,V,0}, /* cvtw.b.f */ | |
770 | {28,14,rr,V,V,0}, /* cvtw.h.f */ | |
771 | {29,15,rr,V,V,0}, /* cvtb.w.f */ | |
772 | {30,15,rr,V,V,0}, /* cvth.w.f */ | |
773 | {31,8,rr,V,V,0}, /* cvts.l */ | |
774 | {32,7,rr,V,V,0}, /* cvtd.w */ | |
775 | {33,3,rr,V,V,0}, /* cvtl.s */ | |
776 | {28,4,rr,V,V,0}, /* cvtw.d */ | |
777 | {31,16,rr,V,V,0}, /* cvts.l.f */ | |
778 | {32,15,rr,V,V,0}, /* cvtd.w.f */ | |
779 | {33,11,rr,V,V,0}, /* cvtl.s.f */ | |
780 | {28,12,rr,V,V,0}, /* cvtw.d.f */ | |
781 | {114,0,rr,S,S,0}, /* enal */ | |
782 | {8,7,rr,S,S,0}, /* shf.w */ | |
783 | {115,0,rr,S,S,0}, /* enag */ | |
784 | {0,0,0,0,0,0}, | |
785 | {28,4,rr,S,S,0}, /* cvtw.d */ | |
786 | {32,7,rr,S,S,0}, /* cvtd.w */ | |
787 | {0,0,0,0,0,0}, | |
788 | {0,0,0,0,0,0}, | |
789 | {0,0,0,0,0,0}, | |
790 | {0,0,0,0,0,0}, | |
791 | {0,0,0,0,0,0}, | |
792 | {0,0,0,0,0,0}, | |
793 | {116,3,rr,S,S,0}, /* frint.s */ | |
794 | {116,4,rr,S,S,0}, /* frint.d */ | |
795 | {0,0,0,0,0,0}, | |
796 | {0,0,0,0,0,0}, | |
797 | {0,0,0,0,0,0}, | |
798 | {0,0,0,0,0,0}, | |
799 | {0,0,0,0,0,0}, | |
800 | {0,0,0,0,0,0}, | |
801 | {0,0,0,0,0,0}, | |
802 | {0,0,0,0,0,0}, | |
803 | {0,0,0,0,0,0}, | |
804 | {0,0,0,0,0,0}, | |
805 | {0,0,0,0,0,0}, | |
806 | {0,0,0,0,0,0}, | |
807 | {0,0,0,0,0,0}, | |
808 | {0,0,0,0,0,0}, | |
809 | {0,0,0,0,0,0}, | |
810 | {0,0,0,0,0,0}, | |
811 | {0,0,0,0,0,0}, | |
812 | {0,0,0,0,0,0}, | |
813 | {0,0,0,0,0,0}, | |
814 | {0,0,0,0,0,0}, | |
815 | {0,0,0,0,0,0}, | |
816 | {0,0,0,0,0,0}, | |
817 | {0,0,0,0,0,0}, | |
818 | {0,0,0,0,0,0}, | |
819 | {0,0,0,0,0,0}, | |
820 | {0,0,0,0,0,0}, | |
821 | {0,0,0,0,0,0}, | |
822 | {0,0,0,0,0,0}, | |
823 | {0,0,0,0,0,0}, | |
824 | {0,0,0,0,0,0}, | |
825 | {0,0,0,0,0,0}, | |
826 | {0,0,0,0,0,0}, | |
827 | {0,0,0,0,0,0}, | |
828 | {0,0,0,0,0,0}, | |
829 | {0,0,0,0,0,0}, | |
830 | {0,0,0,0,0,0}, | |
831 | {0,0,0,0,0,0}, | |
832 | {0,0,0,0,0,0}, | |
833 | {0,0,0,0,0,0}, | |
834 | {0,0,0,0,0,0}, | |
835 | {0,0,0,0,0,0}, | |
836 | {0,0,0,0,0,0}, | |
837 | {0,0,0,0,0,0}, | |
838 | {0,0,0,0,0,0}, | |
839 | {0,0,0,0,0,0}, | |
840 | {0,0,0,0,0,0}, | |
841 | {0,0,0,0,0,0}, | |
842 | {0,0,0,0,0,0}, | |
843 | {0,0,0,0,0,0}, | |
844 | {0,0,0,0,0,0}, | |
845 | {0,0,0,0,0,0}, | |
846 | {0,0,0,0,0,0}, | |
847 | {0,0,0,0,0,0}, | |
848 | {0,0,0,0,0,0}, | |
849 | {0,0,0,0,0,0}, | |
850 | {0,0,0,0,0,0}, | |
851 | {0,0,0,0,0,0}, | |
852 | {0,0,0,0,0,0}, | |
853 | {0,0,0,0,0,0}, | |
854 | {0,0,0,0,0,0}, | |
855 | {0,0,0,0,0,0}, | |
856 | {0,0,0,0,0,0}, | |
857 | {0,0,0,0,0,0}, | |
858 | {0,0,0,0,0,0}, | |
859 | {0,0,0,0,0,0}, | |
860 | {0,0,0,0,0,0}, | |
861 | {0,0,0,0,0,0}, | |
862 | {0,0,0,0,0,0}, | |
863 | {116,3,rr,V,V,0}, /* frint.s */ | |
864 | {116,4,rr,V,V,0}, /* frint.d */ | |
865 | {0,0,0,0,0,0}, | |
866 | {0,0,0,0,0,0}, | |
867 | {116,11,rr,V,V,0}, /* frint.s.f */ | |
868 | {116,12,rr,V,V,0}, /* frint.d.f */ | |
869 | {0,0,0,0,0,0}, | |
870 | {0,0,0,0,0,0}, | |
871 | {0,0,0,0,0,0}, | |
872 | {0,0,0,0,0,0}, | |
873 | {0,0,0,0,0,0}, | |
874 | {0,0,0,0,0,0}, | |
875 | {0,0,0,0,0,0}, | |
876 | {0,0,0,0,0,0}, | |
877 | {0,0,0,0,0,0}, | |
878 | {0,0,0,0,0,0}, | |
879 | {0,0,0,0,0,0}, | |
880 | {0,0,0,0,0,0}, | |
881 | {81,3,rr,V,V,0}, /* sqrt.s */ | |
882 | {81,4,rr,V,V,0}, /* sqrt.d */ | |
883 | {0,0,0,0,0,0}, | |
884 | {0,0,0,0,0,0}, | |
885 | {0,0,0,0,0,0}, | |
886 | {0,0,0,0,0,0}, | |
887 | {0,0,0,0,0,0}, | |
888 | {0,0,0,0,0,0}, | |
889 | {81,11,rr,V,V,0}, /* sqrt.s.f */ | |
890 | {81,12,rr,V,V,0}, /* sqrt.d.f */ | |
891 | {0,0,0,0,0,0}, | |
892 | {0,0,0,0,0,0}, | |
893 | }; | |
894 | ||
92007e40 | 895 | const struct formstr e0_format3[] = { |
252b5132 RH |
896 | {32,11,rr,V,V,0}, /* cvtd.s.f */ |
897 | {31,12,rr,V,V,0}, /* cvts.d.f */ | |
898 | {33,12,rr,V,V,0}, /* cvtl.d.f */ | |
899 | {32,16,rr,V,V,0}, /* cvtd.l.f */ | |
900 | {0,0,0,0,0,0}, | |
901 | {0,0,0,0,0,0}, | |
902 | {0,0,0,0,0,0}, | |
903 | {0,0,0,0,0,0}, | |
904 | {36,2,rr,V,V,0}, /* tzc.f */ | |
905 | {44,2,rr,V,V,0}, /* lop.f */ | |
906 | {117,2,rr,V,V,0}, /* xpnd.f */ | |
907 | {42,2,rr,V,V,0}, /* not.f */ | |
908 | {8,2,rr,S,V,0}, /* shf.f */ | |
909 | {35,17,rr,V,V,0}, /* plc.t.f */ | |
910 | {0,0,0,0,0,0}, | |
911 | {0,0,0,0,0,0}, | |
912 | {37,11,rr,V,V,0}, /* eq.s.f */ | |
913 | {37,12,rr,V,V,0}, /* eq.d.f */ | |
914 | {43,11,rr,V,V,0}, /* neg.s.f */ | |
915 | {43,12,rr,V,V,0}, /* neg.d.f */ | |
916 | {37,11,rr,S,V,0}, /* eq.s.f */ | |
917 | {37,12,rr,S,V,0}, /* eq.d.f */ | |
918 | {0,0,0,0,0,0}, | |
919 | {0,0,0,0,0,0}, | |
920 | {40,11,rr,V,V,0}, /* le.s.f */ | |
921 | {40,12,rr,V,V,0}, /* le.d.f */ | |
922 | {41,11,rr,V,V,0}, /* lt.s.f */ | |
923 | {41,12,rr,V,V,0}, /* lt.d.f */ | |
924 | {40,11,rr,S,V,0}, /* le.s.f */ | |
925 | {40,12,rr,S,V,0}, /* le.d.f */ | |
926 | {41,11,rr,S,V,0}, /* lt.s.f */ | |
927 | {41,12,rr,S,V,0}, /* lt.d.f */ | |
928 | {37,13,rr,V,V,0}, /* eq.b.f */ | |
929 | {37,14,rr,V,V,0}, /* eq.h.f */ | |
930 | {37,15,rr,V,V,0}, /* eq.w.f */ | |
931 | {37,16,rr,V,V,0}, /* eq.l.f */ | |
932 | {37,13,rr,S,V,0}, /* eq.b.f */ | |
933 | {37,14,rr,S,V,0}, /* eq.h.f */ | |
934 | {37,15,rr,S,V,0}, /* eq.w.f */ | |
935 | {37,16,rr,S,V,0}, /* eq.l.f */ | |
936 | {40,13,rr,V,V,0}, /* le.b.f */ | |
937 | {40,14,rr,V,V,0}, /* le.h.f */ | |
938 | {40,15,rr,V,V,0}, /* le.w.f */ | |
939 | {40,16,rr,V,V,0}, /* le.l.f */ | |
940 | {40,13,rr,S,V,0}, /* le.b.f */ | |
941 | {40,14,rr,S,V,0}, /* le.h.f */ | |
942 | {40,15,rr,S,V,0}, /* le.w.f */ | |
943 | {40,16,rr,S,V,0}, /* le.l.f */ | |
944 | {41,13,rr,V,V,0}, /* lt.b.f */ | |
945 | {41,14,rr,V,V,0}, /* lt.h.f */ | |
946 | {41,15,rr,V,V,0}, /* lt.w.f */ | |
947 | {41,16,rr,V,V,0}, /* lt.l.f */ | |
948 | {41,13,rr,S,V,0}, /* lt.b.f */ | |
949 | {41,14,rr,S,V,0}, /* lt.h.f */ | |
950 | {41,15,rr,S,V,0}, /* lt.w.f */ | |
951 | {41,16,rr,S,V,0}, /* lt.l.f */ | |
952 | {43,13,rr,V,V,0}, /* neg.b.f */ | |
953 | {43,14,rr,V,V,0}, /* neg.h.f */ | |
954 | {43,15,rr,V,V,0}, /* neg.w.f */ | |
955 | {43,16,rr,V,V,0}, /* neg.l.f */ | |
956 | {0,0,0,0,0,0}, | |
957 | {0,0,0,0,0,0}, | |
958 | {0,0,0,0,0,0}, | |
959 | {0,0,0,0,0,0}, | |
960 | }; | |
961 | ||
92007e40 | 962 | const struct formstr e0_format4[] = { |
252b5132 RH |
963 | {0,0,0,0,0,0}, |
964 | {0,0,0,0,0,0}, | |
965 | {0,0,0,0,0,0}, | |
966 | {0,0,0,0,0,0}, | |
967 | {0,0,0,0,0,0}, | |
968 | {0,0,0,0,0,0}, | |
969 | {0,0,0,0,0,0}, | |
970 | {0,0,0,0,0,0}, | |
971 | }; | |
972 | ||
92007e40 | 973 | const struct formstr e0_format5[] = { |
252b5132 RH |
974 | {51,13,rr,V,V,0}, /* ldvi.b.f */ |
975 | {51,14,rr,V,V,0}, /* ldvi.h.f */ | |
976 | {51,15,rr,V,V,0}, /* ldvi.w.f */ | |
977 | {51,16,rr,V,V,0}, /* ldvi.l.f */ | |
978 | {28,11,rr,V,V,0}, /* cvtw.s.f */ | |
979 | {31,15,rr,V,V,0}, /* cvts.w.f */ | |
980 | {28,16,rr,V,V,0}, /* cvtw.l.f */ | |
981 | {33,15,rr,V,V,0}, /* cvtl.w.f */ | |
982 | {52,13,rxr,V,V,0}, /* stvi.b.f */ | |
983 | {52,14,rxr,V,V,0}, /* stvi.h.f */ | |
984 | {52,15,rxr,V,V,0}, /* stvi.w.f */ | |
985 | {52,16,rxr,V,V,0}, /* stvi.l.f */ | |
986 | {52,13,rxr,S,V,0}, /* stvi.b.f */ | |
987 | {52,14,rxr,S,V,0}, /* stvi.h.f */ | |
988 | {52,15,rxr,S,V,0}, /* stvi.w.f */ | |
989 | {52,16,rxr,S,V,0}, /* stvi.l.f */ | |
990 | }; | |
991 | ||
92007e40 | 992 | const struct formstr e0_format6[] = { |
252b5132 RH |
993 | {0,0,rxl,S,CIR,0}, /* mov */ |
994 | {0,0,lr,CIR,S,0}, /* mov */ | |
995 | {0,0,lr,TOC,S,0}, /* mov */ | |
996 | {0,0,lr,CPUID,S,0}, /* mov */ | |
997 | {0,0,rxl,S,TTR,0}, /* mov */ | |
998 | {0,0,lr,TTR,S,0}, /* mov */ | |
999 | {118,0,nops,0,0,0}, /* ctrsl */ | |
1000 | {119,0,nops,0,0,0}, /* ctrsg */ | |
1001 | {0,0,rxl,S,VMU,0}, /* mov */ | |
1002 | {0,0,lr,VMU,S,0}, /* mov */ | |
1003 | {0,0,rxl,S,VML,0}, /* mov */ | |
1004 | {0,0,lr,VML,S,0}, /* mov */ | |
1005 | {0,0,rxl,S,ICR,0}, /* mov */ | |
1006 | {0,0,lr,ICR,S,0}, /* mov */ | |
1007 | {0,0,rxl,S,TCPU,0}, /* mov */ | |
1008 | {0,0,lr,TCPU,S,0}, /* mov */ | |
1009 | {0,0,0,0,0,0}, | |
1010 | {0,0,0,0,0,0}, | |
1011 | {0,0,0,0,0,0}, | |
1012 | {0,0,0,0,0,0}, | |
1013 | {120,0,nops,0,0,0}, /* stop */ | |
1014 | {0,0,0,0,0,0}, | |
1015 | {0,0,rxl,S,TID,0}, /* mov */ | |
1016 | {0,0,lr,TID,S,0}, /* mov */ | |
1017 | {0,0,0,0,0,0}, | |
1018 | {0,0,0,0,0,0}, | |
1019 | {0,0,0,0,0,0}, | |
1020 | {0,0,0,0,0,0}, | |
1021 | {0,0,0,0,0,0}, | |
1022 | {0,0,0,0,0,0}, | |
1023 | {0,0,0,0,0,0}, | |
1024 | {0,0,0,0,0,0}, | |
1025 | {0,0,0,0,0,0}, | |
1026 | {0,0,0,0,0,0}, | |
1027 | {0,0,0,0,0,0}, | |
1028 | {0,0,0,0,0,0}, | |
1029 | {0,0,0,0,0,0}, | |
1030 | {0,0,0,0,0,0}, | |
1031 | {0,0,0,0,0,0}, | |
1032 | {0,0,0,0,0,0}, | |
1033 | {0,0,0,0,0,0}, | |
1034 | {0,0,0,0,0,0}, | |
1035 | {0,0,0,0,0,0}, | |
1036 | {0,0,0,0,0,0}, | |
1037 | {0,0,0,0,0,0}, | |
1038 | {0,0,0,0,0,0}, | |
1039 | {0,0,0,0,0,0}, | |
1040 | {0,0,0,0,0,0}, | |
1041 | {0,0,0,0,0,0}, | |
1042 | {0,0,0,0,0,0}, | |
1043 | {0,0,0,0,0,0}, | |
1044 | {0,0,0,0,0,0}, | |
1045 | {0,0,0,0,0,0}, | |
1046 | {0,0,0,0,0,0}, | |
1047 | {0,0,0,0,0,0}, | |
1048 | {0,0,0,0,0,0}, | |
1049 | {0,0,0,0,0,0}, | |
1050 | {0,0,0,0,0,0}, | |
1051 | {0,0,0,0,0,0}, | |
1052 | {0,0,0,0,0,0}, | |
1053 | {0,0,0,0,0,0}, | |
1054 | {0,0,0,0,0,0}, | |
1055 | {0,0,0,0,0,0}, | |
1056 | {0,0,0,0,0,0}, | |
1057 | }; | |
1058 | ||
92007e40 | 1059 | const struct formstr e0_format7[] = { |
252b5132 RH |
1060 | {84,13,r,V,0,0}, /* sum.b.f */ |
1061 | {84,14,r,V,0,0}, /* sum.h.f */ | |
1062 | {84,15,r,V,0,0}, /* sum.w.f */ | |
1063 | {84,16,r,V,0,0}, /* sum.l.f */ | |
1064 | {85,2,r,V,0,0}, /* all.f */ | |
1065 | {86,2,r,V,0,0}, /* any.f */ | |
1066 | {87,2,r,V,0,0}, /* parity.f */ | |
1067 | {0,0,0,0,0,0}, | |
1068 | {88,13,r,V,0,0}, /* max.b.f */ | |
1069 | {88,14,r,V,0,0}, /* max.h.f */ | |
1070 | {88,15,r,V,0,0}, /* max.w.f */ | |
1071 | {88,16,r,V,0,0}, /* max.l.f */ | |
1072 | {89,13,r,V,0,0}, /* min.b.f */ | |
1073 | {89,14,r,V,0,0}, /* min.h.f */ | |
1074 | {89,15,r,V,0,0}, /* min.w.f */ | |
1075 | {89,16,r,V,0,0}, /* min.l.f */ | |
1076 | {84,11,r,V,0,0}, /* sum.s.f */ | |
1077 | {84,12,r,V,0,0}, /* sum.d.f */ | |
1078 | {90,11,r,V,0,0}, /* prod.s.f */ | |
1079 | {90,12,r,V,0,0}, /* prod.d.f */ | |
1080 | {88,11,r,V,0,0}, /* max.s.f */ | |
1081 | {88,12,r,V,0,0}, /* max.d.f */ | |
1082 | {89,11,r,V,0,0}, /* min.s.f */ | |
1083 | {89,12,r,V,0,0}, /* min.d.f */ | |
1084 | {90,13,r,V,0,0}, /* prod.b.f */ | |
1085 | {90,14,r,V,0,0}, /* prod.h.f */ | |
1086 | {90,15,r,V,0,0}, /* prod.w.f */ | |
1087 | {90,16,r,V,0,0}, /* prod.l.f */ | |
1088 | {0,0,0,0,0,0}, | |
1089 | {0,0,0,0,0,0}, | |
1090 | {0,0,0,0,0,0}, | |
1091 | {0,0,0,0,0,0}, | |
1092 | }; | |
1093 | ||
92007e40 | 1094 | const struct formstr e1_format0[] = { |
252b5132 RH |
1095 | {0,0,0,0,0,0}, |
1096 | {0,0,0,0,0,0}, | |
1097 | {0,0,0,0,0,0}, | |
1098 | {0,0,0,0,0,0}, | |
1099 | {10,18,rrr,S,V,V}, /* sub.s.t */ | |
1100 | {10,19,rrr,S,V,V}, /* sub.d.t */ | |
1101 | {4,18,rrr,S,V,V}, /* div.s.t */ | |
1102 | {4,19,rrr,S,V,V}, /* div.d.t */ | |
1103 | {3,18,rrr,V,V,V}, /* mul.s.t */ | |
1104 | {3,19,rrr,V,V,V}, /* mul.d.t */ | |
1105 | {4,18,rrr,V,V,V}, /* div.s.t */ | |
1106 | {4,19,rrr,V,V,V}, /* div.d.t */ | |
1107 | {3,18,rrr,V,S,V}, /* mul.s.t */ | |
1108 | {3,19,rrr,V,S,V}, /* mul.d.t */ | |
1109 | {4,18,rrr,V,S,V}, /* div.s.t */ | |
1110 | {4,19,rrr,V,S,V}, /* div.d.t */ | |
1111 | {5,1,rrr,V,V,V}, /* and.t */ | |
1112 | {6,1,rrr,V,V,V}, /* or.t */ | |
1113 | {7,1,rrr,V,V,V}, /* xor.t */ | |
1114 | {8,1,rrr,V,V,V}, /* shf.t */ | |
1115 | {5,1,rrr,V,S,V}, /* and.t */ | |
1116 | {6,1,rrr,V,S,V}, /* or.t */ | |
1117 | {7,1,rrr,V,S,V}, /* xor.t */ | |
1118 | {8,1,rrr,V,S,V}, /* shf.t */ | |
1119 | {9,18,rrr,V,V,V}, /* add.s.t */ | |
1120 | {9,19,rrr,V,V,V}, /* add.d.t */ | |
1121 | {10,18,rrr,V,V,V}, /* sub.s.t */ | |
1122 | {10,19,rrr,V,V,V}, /* sub.d.t */ | |
1123 | {9,18,rrr,V,S,V}, /* add.s.t */ | |
1124 | {9,19,rrr,V,S,V}, /* add.d.t */ | |
1125 | {10,18,rrr,V,S,V}, /* sub.s.t */ | |
1126 | {10,19,rrr,V,S,V}, /* sub.d.t */ | |
1127 | {9,20,rrr,V,V,V}, /* add.b.t */ | |
1128 | {9,21,rrr,V,V,V}, /* add.h.t */ | |
1129 | {9,22,rrr,V,V,V}, /* add.w.t */ | |
1130 | {9,23,rrr,V,V,V}, /* add.l.t */ | |
1131 | {9,20,rrr,V,S,V}, /* add.b.t */ | |
1132 | {9,21,rrr,V,S,V}, /* add.h.t */ | |
1133 | {9,22,rrr,V,S,V}, /* add.w.t */ | |
1134 | {9,23,rrr,V,S,V}, /* add.l.t */ | |
1135 | {10,20,rrr,V,V,V}, /* sub.b.t */ | |
1136 | {10,21,rrr,V,V,V}, /* sub.h.t */ | |
1137 | {10,22,rrr,V,V,V}, /* sub.w.t */ | |
1138 | {10,23,rrr,V,V,V}, /* sub.l.t */ | |
1139 | {10,20,rrr,V,S,V}, /* sub.b.t */ | |
1140 | {10,21,rrr,V,S,V}, /* sub.h.t */ | |
1141 | {10,22,rrr,V,S,V}, /* sub.w.t */ | |
1142 | {10,23,rrr,V,S,V}, /* sub.l.t */ | |
1143 | {3,20,rrr,V,V,V}, /* mul.b.t */ | |
1144 | {3,21,rrr,V,V,V}, /* mul.h.t */ | |
1145 | {3,22,rrr,V,V,V}, /* mul.w.t */ | |
1146 | {3,23,rrr,V,V,V}, /* mul.l.t */ | |
1147 | {3,20,rrr,V,S,V}, /* mul.b.t */ | |
1148 | {3,21,rrr,V,S,V}, /* mul.h.t */ | |
1149 | {3,22,rrr,V,S,V}, /* mul.w.t */ | |
1150 | {3,23,rrr,V,S,V}, /* mul.l.t */ | |
1151 | {4,20,rrr,V,V,V}, /* div.b.t */ | |
1152 | {4,21,rrr,V,V,V}, /* div.h.t */ | |
1153 | {4,22,rrr,V,V,V}, /* div.w.t */ | |
1154 | {4,23,rrr,V,V,V}, /* div.l.t */ | |
1155 | {4,20,rrr,V,S,V}, /* div.b.t */ | |
1156 | {4,21,rrr,V,S,V}, /* div.h.t */ | |
1157 | {4,22,rrr,V,S,V}, /* div.w.t */ | |
1158 | {4,23,rrr,V,S,V}, /* div.l.t */ | |
1159 | }; | |
1160 | ||
92007e40 | 1161 | const struct formstr e1_format1[] = { |
252b5132 RH |
1162 | {0,0,0,0,0,0}, |
1163 | {0,0,0,0,0,0}, | |
1164 | {0,0,0,0,0,0}, | |
1165 | {0,0,0,0,0,0}, | |
1166 | {0,0,0,0,0,0}, | |
1167 | {0,0,0,0,0,0}, | |
1168 | {0,0,0,0,0,0}, | |
1169 | {0,0,0,0,0,0}, | |
1170 | {0,0,0,0,0,0}, | |
1171 | {0,0,0,0,0,0}, | |
1172 | {0,0,0,0,0,0}, | |
1173 | {0,0,0,0,0,0}, | |
1174 | {0,0,0,0,0,0}, | |
1175 | {0,0,0,0,0,0}, | |
1176 | {0,0,0,0,0,0}, | |
1177 | {0,0,0,0,0,0}, | |
1178 | {0,0,0,0,0,0}, | |
1179 | {0,0,0,0,0,0}, | |
1180 | {0,0,0,0,0,0}, | |
1181 | {0,0,0,0,0,0}, | |
1182 | {0,0,0,0,0,0}, | |
1183 | {0,0,0,0,0,0}, | |
1184 | {0,0,0,0,0,0}, | |
1185 | {0,0,0,0,0,0}, | |
1186 | {0,0,0,0,0,0}, | |
1187 | {0,0,0,0,0,0}, | |
1188 | {0,0,0,0,0,0}, | |
1189 | {0,0,0,0,0,0}, | |
1190 | {0,0,0,0,0,0}, | |
1191 | {0,0,0,0,0,0}, | |
1192 | {0,0,0,0,0,0}, | |
1193 | {0,0,0,0,0,0}, | |
1194 | {0,0,0,0,0,0}, | |
1195 | {0,0,0,0,0,0}, | |
1196 | {0,0,0,0,0,0}, | |
1197 | {0,0,0,0,0,0}, | |
1198 | {26,20,a2r,S,0,0}, /* ste.b.t */ | |
1199 | {26,21,a2r,S,0,0}, /* ste.h.t */ | |
1200 | {26,22,a2r,S,0,0}, /* ste.w.t */ | |
1201 | {26,23,a2r,S,0,0}, /* ste.l.t */ | |
1202 | {0,0,0,0,0,0}, | |
1203 | {0,0,0,0,0,0}, | |
1204 | {0,0,0,0,0,0}, | |
1205 | {0,0,0,0,0,0}, | |
1206 | {0,0,0,0,0,0}, | |
1207 | {0,0,0,0,0,0}, | |
1208 | {0,0,0,0,0,0}, | |
1209 | {0,0,0,0,0,0}, | |
1210 | {0,0,0,0,0,0}, | |
1211 | {0,0,0,0,0,0}, | |
1212 | {0,0,0,0,0,0}, | |
1213 | {0,0,0,0,0,0}, | |
1214 | {0,0,0,0,0,0}, | |
1215 | {0,0,0,0,0,0}, | |
1216 | {0,0,0,0,0,0}, | |
1217 | {0,0,0,0,0,0}, | |
1218 | {18,20,a1r,V,0,0}, /* ld.b.t */ | |
1219 | {18,21,a1r,V,0,0}, /* ld.h.t */ | |
1220 | {18,22,a1r,V,0,0}, /* ld.w.t */ | |
1221 | {18,23,a1r,V,0,0}, /* ld.l.t */ | |
1222 | {21,20,a2r,V,0,0}, /* st.b.t */ | |
1223 | {21,21,a2r,V,0,0}, /* st.h.t */ | |
1224 | {21,22,a2r,V,0,0}, /* st.w.t */ | |
1225 | {21,23,a2r,V,0,0}, /* st.l.t */ | |
1226 | }; | |
1227 | ||
92007e40 | 1228 | const struct formstr e1_format2[] = { |
252b5132 RH |
1229 | {0,0,0,0,0,0}, |
1230 | {0,0,0,0,0,0}, | |
1231 | {0,0,0,0,0,0}, | |
1232 | {0,0,0,0,0,0}, | |
1233 | {28,20,rr,V,V,0}, /* cvtw.b.t */ | |
1234 | {28,21,rr,V,V,0}, /* cvtw.h.t */ | |
1235 | {29,22,rr,V,V,0}, /* cvtb.w.t */ | |
1236 | {30,22,rr,V,V,0}, /* cvth.w.t */ | |
1237 | {0,0,0,0,0,0}, | |
1238 | {0,0,0,0,0,0}, | |
1239 | {0,0,0,0,0,0}, | |
1240 | {0,0,0,0,0,0}, | |
1241 | {31,23,rr,V,V,0}, /* cvts.l.t */ | |
1242 | {32,22,rr,V,V,0}, /* cvtd.w.t */ | |
1243 | {33,18,rr,V,V,0}, /* cvtl.s.t */ | |
1244 | {28,19,rr,V,V,0}, /* cvtw.d.t */ | |
1245 | {0,0,0,0,0,0}, | |
1246 | {0,0,0,0,0,0}, | |
1247 | {0,0,0,0,0,0}, | |
1248 | {0,0,0,0,0,0}, | |
1249 | {0,0,0,0,0,0}, | |
1250 | {0,0,0,0,0,0}, | |
1251 | {0,0,0,0,0,0}, | |
1252 | {0,0,0,0,0,0}, | |
1253 | {0,0,0,0,0,0}, | |
1254 | {0,0,0,0,0,0}, | |
1255 | {0,0,0,0,0,0}, | |
1256 | {0,0,0,0,0,0}, | |
1257 | {0,0,0,0,0,0}, | |
1258 | {0,0,0,0,0,0}, | |
1259 | {0,0,0,0,0,0}, | |
1260 | {0,0,0,0,0,0}, | |
1261 | {0,0,0,0,0,0}, | |
1262 | {0,0,0,0,0,0}, | |
1263 | {0,0,0,0,0,0}, | |
1264 | {0,0,0,0,0,0}, | |
1265 | {0,0,0,0,0,0}, | |
1266 | {0,0,0,0,0,0}, | |
1267 | {0,0,0,0,0,0}, | |
1268 | {0,0,0,0,0,0}, | |
1269 | {0,0,0,0,0,0}, | |
1270 | {0,0,0,0,0,0}, | |
1271 | {0,0,0,0,0,0}, | |
1272 | {0,0,0,0,0,0}, | |
1273 | {0,0,0,0,0,0}, | |
1274 | {0,0,0,0,0,0}, | |
1275 | {0,0,0,0,0,0}, | |
1276 | {0,0,0,0,0,0}, | |
1277 | {0,0,0,0,0,0}, | |
1278 | {0,0,0,0,0,0}, | |
1279 | {0,0,0,0,0,0}, | |
1280 | {0,0,0,0,0,0}, | |
1281 | {0,0,0,0,0,0}, | |
1282 | {0,0,0,0,0,0}, | |
1283 | {0,0,0,0,0,0}, | |
1284 | {0,0,0,0,0,0}, | |
1285 | {0,0,0,0,0,0}, | |
1286 | {0,0,0,0,0,0}, | |
1287 | {0,0,0,0,0,0}, | |
1288 | {0,0,0,0,0,0}, | |
1289 | {0,0,0,0,0,0}, | |
1290 | {0,0,0,0,0,0}, | |
1291 | {0,0,0,0,0,0}, | |
1292 | {0,0,0,0,0,0}, | |
1293 | {0,0,0,0,0,0}, | |
1294 | {0,0,0,0,0,0}, | |
1295 | {0,0,0,0,0,0}, | |
1296 | {0,0,0,0,0,0}, | |
1297 | {0,0,0,0,0,0}, | |
1298 | {0,0,0,0,0,0}, | |
1299 | {0,0,0,0,0,0}, | |
1300 | {0,0,0,0,0,0}, | |
1301 | {0,0,0,0,0,0}, | |
1302 | {0,0,0,0,0,0}, | |
1303 | {0,0,0,0,0,0}, | |
1304 | {0,0,0,0,0,0}, | |
1305 | {0,0,0,0,0,0}, | |
1306 | {0,0,0,0,0,0}, | |
1307 | {0,0,0,0,0,0}, | |
1308 | {0,0,0,0,0,0}, | |
1309 | {0,0,0,0,0,0}, | |
1310 | {0,0,0,0,0,0}, | |
1311 | {0,0,0,0,0,0}, | |
1312 | {0,0,0,0,0,0}, | |
1313 | {0,0,0,0,0,0}, | |
1314 | {0,0,0,0,0,0}, | |
1315 | {0,0,0,0,0,0}, | |
1316 | {0,0,0,0,0,0}, | |
1317 | {0,0,0,0,0,0}, | |
1318 | {0,0,0,0,0,0}, | |
1319 | {0,0,0,0,0,0}, | |
1320 | {0,0,0,0,0,0}, | |
1321 | {0,0,0,0,0,0}, | |
1322 | {0,0,0,0,0,0}, | |
1323 | {0,0,0,0,0,0}, | |
1324 | {0,0,0,0,0,0}, | |
1325 | {0,0,0,0,0,0}, | |
1326 | {0,0,0,0,0,0}, | |
1327 | {0,0,0,0,0,0}, | |
1328 | {0,0,0,0,0,0}, | |
1329 | {0,0,0,0,0,0}, | |
1330 | {0,0,0,0,0,0}, | |
1331 | {116,18,rr,V,V,0}, /* frint.s.t */ | |
1332 | {116,19,rr,V,V,0}, /* frint.d.t */ | |
1333 | {0,0,0,0,0,0}, | |
1334 | {0,0,0,0,0,0}, | |
1335 | {0,0,0,0,0,0}, | |
1336 | {0,0,0,0,0,0}, | |
1337 | {0,0,0,0,0,0}, | |
1338 | {0,0,0,0,0,0}, | |
1339 | {0,0,0,0,0,0}, | |
1340 | {0,0,0,0,0,0}, | |
1341 | {0,0,0,0,0,0}, | |
1342 | {0,0,0,0,0,0}, | |
1343 | {0,0,0,0,0,0}, | |
1344 | {0,0,0,0,0,0}, | |
1345 | {0,0,0,0,0,0}, | |
1346 | {0,0,0,0,0,0}, | |
1347 | {0,0,0,0,0,0}, | |
1348 | {0,0,0,0,0,0}, | |
1349 | {0,0,0,0,0,0}, | |
1350 | {0,0,0,0,0,0}, | |
1351 | {0,0,0,0,0,0}, | |
1352 | {0,0,0,0,0,0}, | |
1353 | {81,18,rr,V,V,0}, /* sqrt.s.t */ | |
1354 | {81,19,rr,V,V,0}, /* sqrt.d.t */ | |
1355 | {0,0,0,0,0,0}, | |
1356 | {0,0,0,0,0,0}, | |
1357 | }; | |
1358 | ||
92007e40 | 1359 | const struct formstr e1_format3[] = { |
252b5132 RH |
1360 | {32,18,rr,V,V,0}, /* cvtd.s.t */ |
1361 | {31,19,rr,V,V,0}, /* cvts.d.t */ | |
1362 | {33,19,rr,V,V,0}, /* cvtl.d.t */ | |
1363 | {32,23,rr,V,V,0}, /* cvtd.l.t */ | |
1364 | {0,0,0,0,0,0}, | |
1365 | {0,0,0,0,0,0}, | |
1366 | {0,0,0,0,0,0}, | |
1367 | {0,0,0,0,0,0}, | |
1368 | {36,1,rr,V,V,0}, /* tzc.t */ | |
1369 | {44,1,rr,V,V,0}, /* lop.t */ | |
1370 | {117,1,rr,V,V,0}, /* xpnd.t */ | |
1371 | {42,1,rr,V,V,0}, /* not.t */ | |
1372 | {8,1,rr,S,V,0}, /* shf.t */ | |
1373 | {35,24,rr,V,V,0}, /* plc.t.t */ | |
1374 | {0,0,0,0,0,0}, | |
1375 | {0,0,0,0,0,0}, | |
1376 | {37,18,rr,V,V,0}, /* eq.s.t */ | |
1377 | {37,19,rr,V,V,0}, /* eq.d.t */ | |
1378 | {43,18,rr,V,V,0}, /* neg.s.t */ | |
1379 | {43,19,rr,V,V,0}, /* neg.d.t */ | |
1380 | {37,18,rr,S,V,0}, /* eq.s.t */ | |
1381 | {37,19,rr,S,V,0}, /* eq.d.t */ | |
1382 | {0,0,0,0,0,0}, | |
1383 | {0,0,0,0,0,0}, | |
1384 | {40,18,rr,V,V,0}, /* le.s.t */ | |
1385 | {40,19,rr,V,V,0}, /* le.d.t */ | |
1386 | {41,18,rr,V,V,0}, /* lt.s.t */ | |
1387 | {41,19,rr,V,V,0}, /* lt.d.t */ | |
1388 | {40,18,rr,S,V,0}, /* le.s.t */ | |
1389 | {40,19,rr,S,V,0}, /* le.d.t */ | |
1390 | {41,18,rr,S,V,0}, /* lt.s.t */ | |
1391 | {41,19,rr,S,V,0}, /* lt.d.t */ | |
1392 | {37,20,rr,V,V,0}, /* eq.b.t */ | |
1393 | {37,21,rr,V,V,0}, /* eq.h.t */ | |
1394 | {37,22,rr,V,V,0}, /* eq.w.t */ | |
1395 | {37,23,rr,V,V,0}, /* eq.l.t */ | |
1396 | {37,20,rr,S,V,0}, /* eq.b.t */ | |
1397 | {37,21,rr,S,V,0}, /* eq.h.t */ | |
1398 | {37,22,rr,S,V,0}, /* eq.w.t */ | |
1399 | {37,23,rr,S,V,0}, /* eq.l.t */ | |
1400 | {40,20,rr,V,V,0}, /* le.b.t */ | |
1401 | {40,21,rr,V,V,0}, /* le.h.t */ | |
1402 | {40,22,rr,V,V,0}, /* le.w.t */ | |
1403 | {40,23,rr,V,V,0}, /* le.l.t */ | |
1404 | {40,20,rr,S,V,0}, /* le.b.t */ | |
1405 | {40,21,rr,S,V,0}, /* le.h.t */ | |
1406 | {40,22,rr,S,V,0}, /* le.w.t */ | |
1407 | {40,23,rr,S,V,0}, /* le.l.t */ | |
1408 | {41,20,rr,V,V,0}, /* lt.b.t */ | |
1409 | {41,21,rr,V,V,0}, /* lt.h.t */ | |
1410 | {41,22,rr,V,V,0}, /* lt.w.t */ | |
1411 | {41,23,rr,V,V,0}, /* lt.l.t */ | |
1412 | {41,20,rr,S,V,0}, /* lt.b.t */ | |
1413 | {41,21,rr,S,V,0}, /* lt.h.t */ | |
1414 | {41,22,rr,S,V,0}, /* lt.w.t */ | |
1415 | {41,23,rr,S,V,0}, /* lt.l.t */ | |
1416 | {43,20,rr,V,V,0}, /* neg.b.t */ | |
1417 | {43,21,rr,V,V,0}, /* neg.h.t */ | |
1418 | {43,22,rr,V,V,0}, /* neg.w.t */ | |
1419 | {43,23,rr,V,V,0}, /* neg.l.t */ | |
1420 | {0,0,0,0,0,0}, | |
1421 | {0,0,0,0,0,0}, | |
1422 | {0,0,0,0,0,0}, | |
1423 | {0,0,0,0,0,0}, | |
1424 | }; | |
1425 | ||
92007e40 | 1426 | const struct formstr e1_format4[] = { |
252b5132 RH |
1427 | {0,0,0,0,0,0}, |
1428 | {0,0,0,0,0,0}, | |
1429 | {0,0,0,0,0,0}, | |
1430 | {0,0,0,0,0,0}, | |
1431 | {0,0,0,0,0,0}, | |
1432 | {0,0,0,0,0,0}, | |
1433 | {0,0,0,0,0,0}, | |
1434 | {0,0,0,0,0,0}, | |
1435 | }; | |
1436 | ||
92007e40 | 1437 | const struct formstr e1_format5[] = { |
252b5132 RH |
1438 | {51,20,rr,V,V,0}, /* ldvi.b.t */ |
1439 | {51,21,rr,V,V,0}, /* ldvi.h.t */ | |
1440 | {51,22,rr,V,V,0}, /* ldvi.w.t */ | |
1441 | {51,23,rr,V,V,0}, /* ldvi.l.t */ | |
1442 | {28,18,rr,V,V,0}, /* cvtw.s.t */ | |
1443 | {31,22,rr,V,V,0}, /* cvts.w.t */ | |
1444 | {28,23,rr,V,V,0}, /* cvtw.l.t */ | |
1445 | {33,22,rr,V,V,0}, /* cvtl.w.t */ | |
1446 | {52,20,rxr,V,V,0}, /* stvi.b.t */ | |
1447 | {52,21,rxr,V,V,0}, /* stvi.h.t */ | |
1448 | {52,22,rxr,V,V,0}, /* stvi.w.t */ | |
1449 | {52,23,rxr,V,V,0}, /* stvi.l.t */ | |
1450 | {52,20,rxr,S,V,0}, /* stvi.b.t */ | |
1451 | {52,21,rxr,S,V,0}, /* stvi.h.t */ | |
1452 | {52,22,rxr,S,V,0}, /* stvi.w.t */ | |
1453 | {52,23,rxr,S,V,0}, /* stvi.l.t */ | |
1454 | }; | |
1455 | ||
92007e40 | 1456 | const struct formstr e1_format6[] = { |
252b5132 RH |
1457 | {0,0,0,0,0,0}, |
1458 | {0,0,0,0,0,0}, | |
1459 | {0,0,0,0,0,0}, | |
1460 | {0,0,0,0,0,0}, | |
1461 | {0,0,0,0,0,0}, | |
1462 | {0,0,0,0,0,0}, | |
1463 | {0,0,0,0,0,0}, | |
1464 | {0,0,0,0,0,0}, | |
1465 | {0,0,0,0,0,0}, | |
1466 | {0,0,0,0,0,0}, | |
1467 | {0,0,0,0,0,0}, | |
1468 | {0,0,0,0,0,0}, | |
1469 | {0,0,0,0,0,0}, | |
1470 | {0,0,0,0,0,0}, | |
1471 | {0,0,0,0,0,0}, | |
1472 | {0,0,0,0,0,0}, | |
1473 | {0,0,0,0,0,0}, | |
1474 | {0,0,0,0,0,0}, | |
1475 | {0,0,0,0,0,0}, | |
1476 | {0,0,0,0,0,0}, | |
1477 | {0,0,0,0,0,0}, | |
1478 | {0,0,0,0,0,0}, | |
1479 | {0,0,0,0,0,0}, | |
1480 | {0,0,0,0,0,0}, | |
1481 | {0,0,0,0,0,0}, | |
1482 | {0,0,0,0,0,0}, | |
1483 | {0,0,0,0,0,0}, | |
1484 | {0,0,0,0,0,0}, | |
1485 | {0,0,0,0,0,0}, | |
1486 | {0,0,0,0,0,0}, | |
1487 | {0,0,0,0,0,0}, | |
1488 | {0,0,0,0,0,0}, | |
1489 | {0,0,0,0,0,0}, | |
1490 | {0,0,0,0,0,0}, | |
1491 | {0,0,0,0,0,0}, | |
1492 | {0,0,0,0,0,0}, | |
1493 | {0,0,0,0,0,0}, | |
1494 | {0,0,0,0,0,0}, | |
1495 | {0,0,0,0,0,0}, | |
1496 | {0,0,0,0,0,0}, | |
1497 | {0,0,0,0,0,0}, | |
1498 | {0,0,0,0,0,0}, | |
1499 | {0,0,0,0,0,0}, | |
1500 | {0,0,0,0,0,0}, | |
1501 | {0,0,0,0,0,0}, | |
1502 | {0,0,0,0,0,0}, | |
1503 | {0,0,0,0,0,0}, | |
1504 | {0,0,0,0,0,0}, | |
1505 | {0,0,0,0,0,0}, | |
1506 | {0,0,0,0,0,0}, | |
1507 | {0,0,0,0,0,0}, | |
1508 | {0,0,0,0,0,0}, | |
1509 | {0,0,0,0,0,0}, | |
1510 | {0,0,0,0,0,0}, | |
1511 | {0,0,0,0,0,0}, | |
1512 | {0,0,0,0,0,0}, | |
1513 | {0,0,0,0,0,0}, | |
1514 | {0,0,0,0,0,0}, | |
1515 | {0,0,0,0,0,0}, | |
1516 | {0,0,0,0,0,0}, | |
1517 | {0,0,0,0,0,0}, | |
1518 | {0,0,0,0,0,0}, | |
1519 | {0,0,0,0,0,0}, | |
1520 | {0,0,0,0,0,0}, | |
1521 | }; | |
1522 | ||
92007e40 | 1523 | const struct formstr e1_format7[] = { |
252b5132 RH |
1524 | {84,20,r,V,0,0}, /* sum.b.t */ |
1525 | {84,21,r,V,0,0}, /* sum.h.t */ | |
1526 | {84,22,r,V,0,0}, /* sum.w.t */ | |
1527 | {84,23,r,V,0,0}, /* sum.l.t */ | |
1528 | {85,1,r,V,0,0}, /* all.t */ | |
1529 | {86,1,r,V,0,0}, /* any.t */ | |
1530 | {87,1,r,V,0,0}, /* parity.t */ | |
1531 | {0,0,0,0,0,0}, | |
1532 | {88,20,r,V,0,0}, /* max.b.t */ | |
1533 | {88,21,r,V,0,0}, /* max.h.t */ | |
1534 | {88,22,r,V,0,0}, /* max.w.t */ | |
1535 | {88,23,r,V,0,0}, /* max.l.t */ | |
1536 | {89,20,r,V,0,0}, /* min.b.t */ | |
1537 | {89,21,r,V,0,0}, /* min.h.t */ | |
1538 | {89,22,r,V,0,0}, /* min.w.t */ | |
1539 | {89,23,r,V,0,0}, /* min.l.t */ | |
1540 | {84,18,r,V,0,0}, /* sum.s.t */ | |
1541 | {84,19,r,V,0,0}, /* sum.d.t */ | |
1542 | {90,18,r,V,0,0}, /* prod.s.t */ | |
1543 | {90,19,r,V,0,0}, /* prod.d.t */ | |
1544 | {88,18,r,V,0,0}, /* max.s.t */ | |
1545 | {88,19,r,V,0,0}, /* max.d.t */ | |
1546 | {89,18,r,V,0,0}, /* min.s.t */ | |
1547 | {89,19,r,V,0,0}, /* min.d.t */ | |
1548 | {90,20,r,V,0,0}, /* prod.b.t */ | |
1549 | {90,21,r,V,0,0}, /* prod.h.t */ | |
1550 | {90,22,r,V,0,0}, /* prod.w.t */ | |
1551 | {90,23,r,V,0,0}, /* prod.l.t */ | |
1552 | {0,0,0,0,0,0}, | |
1553 | {0,0,0,0,0,0}, | |
1554 | {0,0,0,0,0,0}, | |
1555 | {0,0,0,0,0,0}, | |
1556 | }; | |
1557 | ||
1558 | char *lop[] = { | |
1559 | "mov", /* 0 */ | |
1560 | "merg", /* 1 */ | |
1561 | "mask", /* 2 */ | |
1562 | "mul", /* 3 */ | |
1563 | "div", /* 4 */ | |
1564 | "and", /* 5 */ | |
1565 | "or", /* 6 */ | |
1566 | "xor", /* 7 */ | |
1567 | "shf", /* 8 */ | |
1568 | "add", /* 9 */ | |
1569 | "sub", /* 10 */ | |
1570 | "exit", /* 11 */ | |
1571 | "jmp", /* 12 */ | |
1572 | "jmpi", /* 13 */ | |
1573 | "jmpa", /* 14 */ | |
1574 | "jmps", /* 15 */ | |
1575 | "tac", /* 16 */ | |
1576 | "ldea", /* 17 */ | |
1577 | "ld", /* 18 */ | |
1578 | "tas", /* 19 */ | |
1579 | "pshea", /* 20 */ | |
1580 | "st", /* 21 */ | |
1581 | "call", /* 22 */ | |
1582 | "calls", /* 23 */ | |
1583 | "callq", /* 24 */ | |
1584 | "pfork", /* 25 */ | |
1585 | "ste", /* 26 */ | |
1586 | "incr", /* 27 */ | |
1587 | "cvtw", /* 28 */ | |
1588 | "cvtb", /* 29 */ | |
1589 | "cvth", /* 30 */ | |
1590 | "cvts", /* 31 */ | |
1591 | "cvtd", /* 32 */ | |
1592 | "cvtl", /* 33 */ | |
1593 | "ldpa", /* 34 */ | |
1594 | "plc", /* 35 */ | |
1595 | "tzc", /* 36 */ | |
1596 | "eq", /* 37 */ | |
1597 | "leu", /* 38 */ | |
1598 | "ltu", /* 39 */ | |
1599 | "le", /* 40 */ | |
1600 | "lt", /* 41 */ | |
1601 | "not", /* 42 */ | |
1602 | "neg", /* 43 */ | |
1603 | "lop", /* 44 */ | |
1604 | "cprs", /* 45 */ | |
1605 | "nop", /* 46 */ | |
1606 | "br", /* 47 */ | |
1607 | "bri", /* 48 */ | |
1608 | "bra", /* 49 */ | |
1609 | "brs", /* 50 */ | |
1610 | "ldvi", /* 51 */ | |
1611 | "stvi", /* 52 */ | |
1612 | "ldsdr", /* 53 */ | |
1613 | "ldkdr", /* 54 */ | |
1614 | "ln", /* 55 */ | |
1615 | "patu", /* 56 */ | |
1616 | "pate", /* 57 */ | |
1617 | "pich", /* 58 */ | |
1618 | "plch", /* 59 */ | |
1619 | "idle", /* 60 */ | |
1620 | "rtnq", /* 61 */ | |
1621 | "cfork", /* 62 */ | |
1622 | "rtn", /* 63 */ | |
1623 | "wfork", /* 64 */ | |
1624 | "join", /* 65 */ | |
1625 | "rtnc", /* 66 */ | |
1626 | "exp", /* 67 */ | |
1627 | "sin", /* 68 */ | |
1628 | "cos", /* 69 */ | |
1629 | "psh", /* 70 */ | |
1630 | "pop", /* 71 */ | |
1631 | "eni", /* 72 */ | |
1632 | "dsi", /* 73 */ | |
1633 | "bkpt", /* 74 */ | |
1634 | "msync", /* 75 */ | |
1635 | "mski", /* 76 */ | |
1636 | "xmti", /* 77 */ | |
1637 | "tstvv", /* 78 */ | |
1638 | "diag", /* 79 */ | |
1639 | "pbkpt", /* 80 */ | |
1640 | "sqrt", /* 81 */ | |
1641 | "casr", /* 82 */ | |
1642 | "atan", /* 83 */ | |
1643 | "sum", /* 84 */ | |
1644 | "all", /* 85 */ | |
1645 | "any", /* 86 */ | |
1646 | "parity", /* 87 */ | |
1647 | "max", /* 88 */ | |
1648 | "min", /* 89 */ | |
1649 | "prod", /* 90 */ | |
1650 | "halt", /* 91 */ | |
1651 | "sysc", /* 92 */ | |
1652 | "trap", /* 93 */ | |
1653 | "tst", /* 94 */ | |
1654 | "lck", /* 95 */ | |
1655 | "ulk", /* 96 */ | |
1656 | "spawn", /* 97 */ | |
1657 | "ldcmr", /* 98 */ | |
1658 | "stcmr", /* 99 */ | |
1659 | "popr", /* 100 */ | |
1660 | "pshr", /* 101 */ | |
1661 | "rcvr", /* 102 */ | |
1662 | "matm", /* 103 */ | |
1663 | "sndr", /* 104 */ | |
1664 | "putr", /* 105 */ | |
1665 | "getr", /* 106 */ | |
1666 | "matr", /* 107 */ | |
1667 | "mat", /* 108 */ | |
1668 | "get", /* 109 */ | |
1669 | "rcv", /* 110 */ | |
1670 | "inc", /* 111 */ | |
1671 | "put", /* 112 */ | |
1672 | "snd", /* 113 */ | |
1673 | "enal", /* 114 */ | |
1674 | "enag", /* 115 */ | |
1675 | "frint", /* 116 */ | |
1676 | "xpnd", /* 117 */ | |
1677 | "ctrsl", /* 118 */ | |
1678 | "ctrsg", /* 119 */ | |
1679 | "stop", /* 120 */ | |
1680 | }; | |
1681 | ||
1682 | char *rop[] = { | |
1683 | "", /* 0 */ | |
1684 | ".t", /* 1 */ | |
1685 | ".f", /* 2 */ | |
1686 | ".s", /* 3 */ | |
1687 | ".d", /* 4 */ | |
1688 | ".b", /* 5 */ | |
1689 | ".h", /* 6 */ | |
1690 | ".w", /* 7 */ | |
1691 | ".l", /* 8 */ | |
1692 | ".x", /* 9 */ | |
1693 | ".u", /* 10 */ | |
1694 | ".s.f", /* 11 */ | |
1695 | ".d.f", /* 12 */ | |
1696 | ".b.f", /* 13 */ | |
1697 | ".h.f", /* 14 */ | |
1698 | ".w.f", /* 15 */ | |
1699 | ".l.f", /* 16 */ | |
1700 | ".t.f", /* 17 */ | |
1701 | ".s.t", /* 18 */ | |
1702 | ".d.t", /* 19 */ | |
1703 | ".b.t", /* 20 */ | |
1704 | ".h.t", /* 21 */ | |
1705 | ".w.t", /* 22 */ | |
1706 | ".l.t", /* 23 */ | |
1707 | ".t.t", /* 24 */ | |
1708 | }; |