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