1 // Copyright 2015, VIXL authors
2 // All rights reserved.
3 //
4 // Redistribution and use in source and binary forms, with or without
5 // modification, are permitted provided that the following conditions are met:
6 //
7 //   * Redistributions of source code must retain the above copyright notice,
8 //     this list of conditions and the following disclaimer.
9 //   * Redistributions in binary form must reproduce the above copyright notice,
10 //     this list of conditions and the following disclaimer in the documentation
11 //     and/or other materials provided with the distribution.
12 //   * Neither the name of ARM Limited nor the names of its contributors may be
13 //     used to endorse or promote products derived from this software without
14 //     specific prior written permission.
15 //
16 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS CONTRIBUTORS "AS IS" AND
17 // ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19 // DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
20 // FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 // DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
22 // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
23 // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 // OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 
27 
28 // ---------------------------------------------------------------------
29 // This file is auto generated using tools/generate_simulator_traces.py.
30 //
31 // PLEASE DO NOT EDIT.
32 // ---------------------------------------------------------------------
33 
34 #ifndef VIXL_ASSEMBLER_COND_RD_RN_OPERAND_RM_SHIFT_RS_SUB_A32_H_
35 #define VIXL_ASSEMBLER_COND_RD_RN_OPERAND_RM_SHIFT_RS_SUB_A32_H_
36 
37 const byte kInstruction_sub_mi_r8_r10_r8_LSL_r0[] = {
38   0x18, 0x80, 0x4a, 0x40 // sub mi r8 r10 r8 LSL r0
39 };
40 const byte kInstruction_sub_cc_r11_r4_r13_ROR_r8[] = {
41   0x7d, 0xb8, 0x44, 0x30 // sub cc r11 r4 r13 ROR r8
42 };
43 const byte kInstruction_sub_al_r13_r11_r3_ROR_r4[] = {
44   0x73, 0xd4, 0x4b, 0xe0 // sub al r13 r11 r3 ROR r4
45 };
46 const byte kInstruction_sub_gt_r11_r5_r4_LSR_r11[] = {
47   0x34, 0xbb, 0x45, 0xc0 // sub gt r11 r5 r4 LSR r11
48 };
49 const byte kInstruction_sub_vs_r12_r0_r8_ROR_r13[] = {
50   0x78, 0xcd, 0x40, 0x60 // sub vs r12 r0 r8 ROR r13
51 };
52 const byte kInstruction_sub_pl_r10_r12_r5_LSL_r5[] = {
53   0x15, 0xa5, 0x4c, 0x50 // sub pl r10 r12 r5 LSL r5
54 };
55 const byte kInstruction_sub_ls_r10_r2_r2_LSL_r9[] = {
56   0x12, 0xa9, 0x42, 0x90 // sub ls r10 r2 r2 LSL r9
57 };
58 const byte kInstruction_sub_eq_r12_r7_r9_LSR_r7[] = {
59   0x39, 0xc7, 0x47, 0x00 // sub eq r12 r7 r9 LSR r7
60 };
61 const byte kInstruction_sub_mi_r3_r13_r0_ROR_r11[] = {
62   0x70, 0x3b, 0x4d, 0x40 // sub mi r3 r13 r0 ROR r11
63 };
64 const byte kInstruction_sub_lt_r9_r0_r9_ASR_r12[] = {
65   0x59, 0x9c, 0x40, 0xb0 // sub lt r9 r0 r9 ASR r12
66 };
67 const byte kInstruction_sub_le_r12_r8_r14_ROR_r1[] = {
68   0x7e, 0xc1, 0x48, 0xd0 // sub le r12 r8 r14 ROR r1
69 };
70 const byte kInstruction_sub_cc_r7_r1_r14_LSL_r0[] = {
71   0x1e, 0x70, 0x41, 0x30 // sub cc r7 r1 r14 LSL r0
72 };
73 const byte kInstruction_sub_le_r11_r13_r3_ROR_r6[] = {
74   0x73, 0xb6, 0x4d, 0xd0 // sub le r11 r13 r3 ROR r6
75 };
76 const byte kInstruction_sub_al_r5_r8_r9_ASR_r14[] = {
77   0x59, 0x5e, 0x48, 0xe0 // sub al r5 r8 r9 ASR r14
78 };
79 const byte kInstruction_sub_hi_r1_r2_r7_ASR_r13[] = {
80   0x57, 0x1d, 0x42, 0x80 // sub hi r1 r2 r7 ASR r13
81 };
82 const byte kInstruction_sub_al_r13_r8_r7_LSR_r12[] = {
83   0x37, 0xdc, 0x48, 0xe0 // sub al r13 r8 r7 LSR r12
84 };
85 const byte kInstruction_sub_vc_r3_r6_r4_ASR_r4[] = {
86   0x54, 0x34, 0x46, 0x70 // sub vc r3 r6 r4 ASR r4
87 };
88 const byte kInstruction_sub_lt_r12_r4_r6_LSL_r5[] = {
89   0x16, 0xc5, 0x44, 0xb0 // sub lt r12 r4 r6 LSL r5
90 };
91 const byte kInstruction_sub_ls_r13_r5_r11_ROR_r8[] = {
92   0x7b, 0xd8, 0x45, 0x90 // sub ls r13 r5 r11 ROR r8
93 };
94 const byte kInstruction_sub_vc_r11_r10_r11_LSL_r9[] = {
95   0x1b, 0xb9, 0x4a, 0x70 // sub vc r11 r10 r11 LSL r9
96 };
97 const byte kInstruction_sub_al_r13_r14_r10_LSR_r4[] = {
98   0x3a, 0xd4, 0x4e, 0xe0 // sub al r13 r14 r10 LSR r4
99 };
100 const byte kInstruction_sub_ge_r12_r13_r6_ASR_r12[] = {
101   0x56, 0xcc, 0x4d, 0xa0 // sub ge r12 r13 r6 ASR r12
102 };
103 const byte kInstruction_sub_ne_r14_r6_r12_ROR_r0[] = {
104   0x7c, 0xe0, 0x46, 0x10 // sub ne r14 r6 r12 ROR r0
105 };
106 const byte kInstruction_sub_ls_r13_r14_r14_ASR_r13[] = {
107   0x5e, 0xdd, 0x4e, 0x90 // sub ls r13 r14 r14 ASR r13
108 };
109 const byte kInstruction_sub_lt_r10_r13_r7_ROR_r8[] = {
110   0x77, 0xa8, 0x4d, 0xb0 // sub lt r10 r13 r7 ROR r8
111 };
112 const byte kInstruction_sub_lt_r8_r8_r9_ASR_r0[] = {
113   0x59, 0x80, 0x48, 0xb0 // sub lt r8 r8 r9 ASR r0
114 };
115 const byte kInstruction_sub_ne_r7_r5_r4_LSR_r8[] = {
116   0x34, 0x78, 0x45, 0x10 // sub ne r7 r5 r4 LSR r8
117 };
118 const byte kInstruction_sub_mi_r11_r5_r1_LSL_r13[] = {
119   0x11, 0xbd, 0x45, 0x40 // sub mi r11 r5 r1 LSL r13
120 };
121 const byte kInstruction_sub_ge_r14_r1_r2_LSL_r1[] = {
122   0x12, 0xe1, 0x41, 0xa0 // sub ge r14 r1 r2 LSL r1
123 };
124 const byte kInstruction_sub_ls_r6_r11_r4_ASR_r11[] = {
125   0x54, 0x6b, 0x4b, 0x90 // sub ls r6 r11 r4 ASR r11
126 };
127 const byte kInstruction_sub_hi_r11_r12_r4_LSR_r13[] = {
128   0x34, 0xbd, 0x4c, 0x80 // sub hi r11 r12 r4 LSR r13
129 };
130 const byte kInstruction_sub_le_r9_r3_r0_LSL_r7[] = {
131   0x10, 0x97, 0x43, 0xd0 // sub le r9 r3 r0 LSL r7
132 };
133 const byte kInstruction_sub_ls_r8_r7_r4_ASR_r3[] = {
134   0x54, 0x83, 0x47, 0x90 // sub ls r8 r7 r4 ASR r3
135 };
136 const byte kInstruction_sub_pl_r9_r13_r11_LSL_r7[] = {
137   0x1b, 0x97, 0x4d, 0x50 // sub pl r9 r13 r11 LSL r7
138 };
139 const byte kInstruction_sub_eq_r12_r7_r11_ASR_r3[] = {
140   0x5b, 0xc3, 0x47, 0x00 // sub eq r12 r7 r11 ASR r3
141 };
142 const byte kInstruction_sub_mi_r3_r9_r13_ROR_r10[] = {
143   0x7d, 0x3a, 0x49, 0x40 // sub mi r3 r9 r13 ROR r10
144 };
145 const byte kInstruction_sub_mi_r14_r8_r10_ROR_r10[] = {
146   0x7a, 0xea, 0x48, 0x40 // sub mi r14 r8 r10 ROR r10
147 };
148 const byte kInstruction_sub_lt_r5_r3_r5_LSL_r1[] = {
149   0x15, 0x51, 0x43, 0xb0 // sub lt r5 r3 r5 LSL r1
150 };
151 const byte kInstruction_sub_ne_r12_r6_r1_LSL_r7[] = {
152   0x11, 0xc7, 0x46, 0x10 // sub ne r12 r6 r1 LSL r7
153 };
154 const byte kInstruction_sub_lt_r3_r6_r5_ASR_r1[] = {
155   0x55, 0x31, 0x46, 0xb0 // sub lt r3 r6 r5 ASR r1
156 };
157 const byte kInstruction_sub_lt_r14_r0_r0_LSR_r11[] = {
158   0x30, 0xeb, 0x40, 0xb0 // sub lt r14 r0 r0 LSR r11
159 };
160 const byte kInstruction_sub_eq_r11_r10_r4_LSL_r14[] = {
161   0x14, 0xbe, 0x4a, 0x00 // sub eq r11 r10 r4 LSL r14
162 };
163 const byte kInstruction_sub_lt_r2_r14_r11_LSL_r9[] = {
164   0x1b, 0x29, 0x4e, 0xb0 // sub lt r2 r14 r11 LSL r9
165 };
166 const byte kInstruction_sub_mi_r0_r6_r14_ASR_r11[] = {
167   0x5e, 0x0b, 0x46, 0x40 // sub mi r0 r6 r14 ASR r11
168 };
169 const byte kInstruction_sub_le_r4_r6_r3_LSR_r11[] = {
170   0x33, 0x4b, 0x46, 0xd0 // sub le r4 r6 r3 LSR r11
171 };
172 const byte kInstruction_sub_cs_r2_r6_r1_ROR_r5[] = {
173   0x71, 0x25, 0x46, 0x20 // sub cs r2 r6 r1 ROR r5
174 };
175 const byte kInstruction_sub_ne_r10_r9_r10_ROR_r4[] = {
176   0x7a, 0xa4, 0x49, 0x10 // sub ne r10 r9 r10 ROR r4
177 };
178 const byte kInstruction_sub_pl_r7_r9_r11_LSR_r14[] = {
179   0x3b, 0x7e, 0x49, 0x50 // sub pl r7 r9 r11 LSR r14
180 };
181 const byte kInstruction_sub_pl_r11_r8_r3_ASR_r5[] = {
182   0x53, 0xb5, 0x48, 0x50 // sub pl r11 r8 r3 ASR r5
183 };
184 const byte kInstruction_sub_le_r10_r4_r10_ROR_r8[] = {
185   0x7a, 0xa8, 0x44, 0xd0 // sub le r10 r4 r10 ROR r8
186 };
187 const byte kInstruction_sub_ne_r8_r14_r8_LSL_r5[] = {
188   0x18, 0x85, 0x4e, 0x10 // sub ne r8 r14 r8 LSL r5
189 };
190 const byte kInstruction_sub_eq_r12_r5_r2_LSL_r11[] = {
191   0x12, 0xcb, 0x45, 0x00 // sub eq r12 r5 r2 LSL r11
192 };
193 const byte kInstruction_sub_pl_r9_r9_r8_ASR_r2[] = {
194   0x58, 0x92, 0x49, 0x50 // sub pl r9 r9 r8 ASR r2
195 };
196 const byte kInstruction_sub_hi_r8_r12_r3_LSL_r5[] = {
197   0x13, 0x85, 0x4c, 0x80 // sub hi r8 r12 r3 LSL r5
198 };
199 const byte kInstruction_sub_eq_r6_r5_r9_LSL_r3[] = {
200   0x19, 0x63, 0x45, 0x00 // sub eq r6 r5 r9 LSL r3
201 };
202 const byte kInstruction_sub_lt_r5_r1_r9_LSR_r6[] = {
203   0x39, 0x56, 0x41, 0xb0 // sub lt r5 r1 r9 LSR r6
204 };
205 const byte kInstruction_sub_hi_r9_r9_r0_LSL_r5[] = {
206   0x10, 0x95, 0x49, 0x80 // sub hi r9 r9 r0 LSL r5
207 };
208 const byte kInstruction_sub_cs_r6_r6_r5_LSL_r8[] = {
209   0x15, 0x68, 0x46, 0x20 // sub cs r6 r6 r5 LSL r8
210 };
211 const byte kInstruction_sub_cs_r0_r1_r6_LSR_r12[] = {
212   0x36, 0x0c, 0x41, 0x20 // sub cs r0 r1 r6 LSR r12
213 };
214 const byte kInstruction_sub_cc_r4_r6_r13_ASR_r6[] = {
215   0x5d, 0x46, 0x46, 0x30 // sub cc r4 r6 r13 ASR r6
216 };
217 const byte kInstruction_sub_hi_r11_r8_r10_LSR_r5[] = {
218   0x3a, 0xb5, 0x48, 0x80 // sub hi r11 r8 r10 LSR r5
219 };
220 const byte kInstruction_sub_ls_r8_r1_r14_ROR_r14[] = {
221   0x7e, 0x8e, 0x41, 0x90 // sub ls r8 r1 r14 ROR r14
222 };
223 const byte kInstruction_sub_pl_r8_r2_r12_ASR_r7[] = {
224   0x5c, 0x87, 0x42, 0x50 // sub pl r8 r2 r12 ASR r7
225 };
226 const byte kInstruction_sub_gt_r14_r7_r5_ROR_r11[] = {
227   0x75, 0xeb, 0x47, 0xc0 // sub gt r14 r7 r5 ROR r11
228 };
229 const byte kInstruction_sub_eq_r3_r6_r13_ROR_r0[] = {
230   0x7d, 0x30, 0x46, 0x00 // sub eq r3 r6 r13 ROR r0
231 };
232 const byte kInstruction_sub_le_r4_r8_r8_ROR_r11[] = {
233   0x78, 0x4b, 0x48, 0xd0 // sub le r4 r8 r8 ROR r11
234 };
235 const byte kInstruction_sub_ge_r2_r7_r5_ASR_r6[] = {
236   0x55, 0x26, 0x47, 0xa0 // sub ge r2 r7 r5 ASR r6
237 };
238 const byte kInstruction_sub_cc_r8_r12_r5_LSL_r11[] = {
239   0x15, 0x8b, 0x4c, 0x30 // sub cc r8 r12 r5 LSL r11
240 };
241 const byte kInstruction_sub_vc_r11_r10_r3_ROR_r5[] = {
242   0x73, 0xb5, 0x4a, 0x70 // sub vc r11 r10 r3 ROR r5
243 };
244 const byte kInstruction_sub_vc_r11_r9_r11_LSL_r6[] = {
245   0x1b, 0xb6, 0x49, 0x70 // sub vc r11 r9 r11 LSL r6
246 };
247 const byte kInstruction_sub_lt_r6_r5_r0_ROR_r9[] = {
248   0x70, 0x69, 0x45, 0xb0 // sub lt r6 r5 r0 ROR r9
249 };
250 const byte kInstruction_sub_cs_r13_r7_r11_ASR_r9[] = {
251   0x5b, 0xd9, 0x47, 0x20 // sub cs r13 r7 r11 ASR r9
252 };
253 const byte kInstruction_sub_cs_r9_r7_r9_ROR_r11[] = {
254   0x79, 0x9b, 0x47, 0x20 // sub cs r9 r7 r9 ROR r11
255 };
256 const byte kInstruction_sub_ls_r14_r3_r2_ASR_r11[] = {
257   0x52, 0xeb, 0x43, 0x90 // sub ls r14 r3 r2 ASR r11
258 };
259 const byte kInstruction_sub_vc_r0_r1_r1_LSR_r0[] = {
260   0x31, 0x00, 0x41, 0x70 // sub vc r0 r1 r1 LSR r0
261 };
262 const byte kInstruction_sub_mi_r10_r8_r8_LSR_r13[] = {
263   0x38, 0xad, 0x48, 0x40 // sub mi r10 r8 r8 LSR r13
264 };
265 const byte kInstruction_sub_pl_r8_r14_r3_LSL_r8[] = {
266   0x13, 0x88, 0x4e, 0x50 // sub pl r8 r14 r3 LSL r8
267 };
268 const byte kInstruction_sub_ne_r6_r4_r1_LSL_r12[] = {
269   0x11, 0x6c, 0x44, 0x10 // sub ne r6 r4 r1 LSL r12
270 };
271 const byte kInstruction_sub_lt_r2_r2_r7_ROR_r0[] = {
272   0x77, 0x20, 0x42, 0xb0 // sub lt r2 r2 r7 ROR r0
273 };
274 const byte kInstruction_sub_lt_r2_r4_r13_ASR_r5[] = {
275   0x5d, 0x25, 0x44, 0xb0 // sub lt r2 r4 r13 ASR r5
276 };
277 const byte kInstruction_sub_eq_r8_r1_r2_ROR_r13[] = {
278   0x72, 0x8d, 0x41, 0x00 // sub eq r8 r1 r2 ROR r13
279 };
280 const byte kInstruction_sub_lt_r1_r8_r10_LSR_r7[] = {
281   0x3a, 0x17, 0x48, 0xb0 // sub lt r1 r8 r10 LSR r7
282 };
283 const byte kInstruction_sub_cs_r7_r5_r9_LSL_r9[] = {
284   0x19, 0x79, 0x45, 0x20 // sub cs r7 r5 r9 LSL r9
285 };
286 const byte kInstruction_sub_mi_r8_r0_r6_LSL_r8[] = {
287   0x16, 0x88, 0x40, 0x40 // sub mi r8 r0 r6 LSL r8
288 };
289 const byte kInstruction_sub_cs_r7_r12_r3_ROR_r6[] = {
290   0x73, 0x76, 0x4c, 0x20 // sub cs r7 r12 r3 ROR r6
291 };
292 const byte kInstruction_sub_vs_r13_r8_r13_LSR_r4[] = {
293   0x3d, 0xd4, 0x48, 0x60 // sub vs r13 r8 r13 LSR r4
294 };
295 const byte kInstruction_sub_cc_r4_r13_r7_ROR_r11[] = {
296   0x77, 0x4b, 0x4d, 0x30 // sub cc r4 r13 r7 ROR r11
297 };
298 const byte kInstruction_sub_ge_r10_r5_r9_LSR_r13[] = {
299   0x39, 0xad, 0x45, 0xa0 // sub ge r10 r5 r9 LSR r13
300 };
301 const byte kInstruction_sub_cc_r0_r5_r9_ASR_r4[] = {
302   0x59, 0x04, 0x45, 0x30 // sub cc r0 r5 r9 ASR r4
303 };
304 const byte kInstruction_sub_cc_r1_r5_r8_LSR_r12[] = {
305   0x38, 0x1c, 0x45, 0x30 // sub cc r1 r5 r8 LSR r12
306 };
307 const byte kInstruction_sub_ls_r12_r3_r5_LSL_r6[] = {
308   0x15, 0xc6, 0x43, 0x90 // sub ls r12 r3 r5 LSL r6
309 };
310 const byte kInstruction_sub_cs_r10_r0_r4_ASR_r7[] = {
311   0x54, 0xa7, 0x40, 0x20 // sub cs r10 r0 r4 ASR r7
312 };
313 const byte kInstruction_sub_ge_r10_r13_r14_ROR_r6[] = {
314   0x7e, 0xa6, 0x4d, 0xa0 // sub ge r10 r13 r14 ROR r6
315 };
316 const byte kInstruction_sub_al_r9_r0_r9_ROR_r3[] = {
317   0x79, 0x93, 0x40, 0xe0 // sub al r9 r0 r9 ROR r3
318 };
319 const byte kInstruction_sub_vs_r4_r5_r12_ASR_r6[] = {
320   0x5c, 0x46, 0x45, 0x60 // sub vs r4 r5 r12 ASR r6
321 };
322 const byte kInstruction_sub_lt_r4_r1_r14_LSL_r12[] = {
323   0x1e, 0x4c, 0x41, 0xb0 // sub lt r4 r1 r14 LSL r12
324 };
325 const byte kInstruction_sub_cs_r14_r11_r8_ROR_r4[] = {
326   0x78, 0xe4, 0x4b, 0x20 // sub cs r14 r11 r8 ROR r4
327 };
328 const byte kInstruction_sub_hi_r12_r0_r14_LSR_r11[] = {
329   0x3e, 0xcb, 0x40, 0x80 // sub hi r12 r0 r14 LSR r11
330 };
331 const byte kInstruction_sub_le_r8_r6_r4_ASR_r7[] = {
332   0x54, 0x87, 0x46, 0xd0 // sub le r8 r6 r4 ASR r7
333 };
334 const byte kInstruction_sub_mi_r13_r4_r14_LSR_r10[] = {
335   0x3e, 0xda, 0x44, 0x40 // sub mi r13 r4 r14 LSR r10
336 };
337 const byte kInstruction_sub_vs_r11_r10_r5_LSL_r10[] = {
338   0x15, 0xba, 0x4a, 0x60 // sub vs r11 r10 r5 LSL r10
339 };
340 const byte kInstruction_sub_cc_r4_r0_r5_LSR_r2[] = {
341   0x35, 0x42, 0x40, 0x30 // sub cc r4 r0 r5 LSR r2
342 };
343 const byte kInstruction_sub_pl_r9_r14_r0_LSL_r3[] = {
344   0x10, 0x93, 0x4e, 0x50 // sub pl r9 r14 r0 LSL r3
345 };
346 const byte kInstruction_sub_vc_r7_r2_r14_ASR_r1[] = {
347   0x5e, 0x71, 0x42, 0x70 // sub vc r7 r2 r14 ASR r1
348 };
349 const byte kInstruction_sub_gt_r4_r14_r1_ROR_r10[] = {
350   0x71, 0x4a, 0x4e, 0xc0 // sub gt r4 r14 r1 ROR r10
351 };
352 const byte kInstruction_sub_lt_r6_r4_r10_LSL_r7[] = {
353   0x1a, 0x67, 0x44, 0xb0 // sub lt r6 r4 r10 LSL r7
354 };
355 const byte kInstruction_sub_hi_r1_r14_r5_LSL_r12[] = {
356   0x15, 0x1c, 0x4e, 0x80 // sub hi r1 r14 r5 LSL r12
357 };
358 const byte kInstruction_sub_cc_r14_r12_r4_ASR_r14[] = {
359   0x54, 0xee, 0x4c, 0x30 // sub cc r14 r12 r4 ASR r14
360 };
361 const byte kInstruction_sub_cc_r0_r8_r5_ROR_r8[] = {
362   0x75, 0x08, 0x48, 0x30 // sub cc r0 r8 r5 ROR r8
363 };
364 const byte kInstruction_sub_gt_r9_r9_r0_ASR_r4[] = {
365   0x50, 0x94, 0x49, 0xc0 // sub gt r9 r9 r0 ASR r4
366 };
367 const byte kInstruction_sub_mi_r8_r11_r12_ASR_r4[] = {
368   0x5c, 0x84, 0x4b, 0x40 // sub mi r8 r11 r12 ASR r4
369 };
370 const byte kInstruction_sub_vs_r0_r12_r0_LSR_r11[] = {
371   0x30, 0x0b, 0x4c, 0x60 // sub vs r0 r12 r0 LSR r11
372 };
373 const byte kInstruction_sub_ge_r0_r9_r1_ASR_r0[] = {
374   0x51, 0x00, 0x49, 0xa0 // sub ge r0 r9 r1 ASR r0
375 };
376 const byte kInstruction_sub_al_r10_r11_r5_LSR_r4[] = {
377   0x35, 0xa4, 0x4b, 0xe0 // sub al r10 r11 r5 LSR r4
378 };
379 const byte kInstruction_sub_eq_r0_r6_r8_LSR_r10[] = {
380   0x38, 0x0a, 0x46, 0x00 // sub eq r0 r6 r8 LSR r10
381 };
382 const byte kInstruction_sub_cc_r13_r12_r14_ROR_r9[] = {
383   0x7e, 0xd9, 0x4c, 0x30 // sub cc r13 r12 r14 ROR r9
384 };
385 const byte kInstruction_sub_ls_r4_r11_r0_LSL_r14[] = {
386   0x10, 0x4e, 0x4b, 0x90 // sub ls r4 r11 r0 LSL r14
387 };
388 const byte kInstruction_sub_hi_r1_r6_r12_LSR_r13[] = {
389   0x3c, 0x1d, 0x46, 0x80 // sub hi r1 r6 r12 LSR r13
390 };
391 const byte kInstruction_sub_cs_r7_r11_r1_ASR_r5[] = {
392   0x51, 0x75, 0x4b, 0x20 // sub cs r7 r11 r1 ASR r5
393 };
394 const byte kInstruction_sub_cc_r7_r5_r4_ASR_r11[] = {
395   0x54, 0x7b, 0x45, 0x30 // sub cc r7 r5 r4 ASR r11
396 };
397 const byte kInstruction_sub_hi_r7_r2_r5_ROR_r5[] = {
398   0x75, 0x75, 0x42, 0x80 // sub hi r7 r2 r5 ROR r5
399 };
400 const byte kInstruction_sub_vc_r11_r9_r7_LSL_r14[] = {
401   0x17, 0xbe, 0x49, 0x70 // sub vc r11 r9 r7 LSL r14
402 };
403 const byte kInstruction_sub_le_r12_r1_r3_ROR_r7[] = {
404   0x73, 0xc7, 0x41, 0xd0 // sub le r12 r1 r3 ROR r7
405 };
406 const byte kInstruction_sub_al_r8_r14_r0_ASR_r12[] = {
407   0x50, 0x8c, 0x4e, 0xe0 // sub al r8 r14 r0 ASR r12
408 };
409 const byte kInstruction_sub_vc_r14_r3_r0_ROR_r1[] = {
410   0x70, 0xe1, 0x43, 0x70 // sub vc r14 r3 r0 ROR r1
411 };
412 const byte kInstruction_sub_pl_r10_r8_r3_ROR_r4[] = {
413   0x73, 0xa4, 0x48, 0x50 // sub pl r10 r8 r3 ROR r4
414 };
415 const byte kInstruction_sub_al_r9_r14_r12_LSL_r4[] = {
416   0x1c, 0x94, 0x4e, 0xe0 // sub al r9 r14 r12 LSL r4
417 };
418 const byte kInstruction_sub_vs_r8_r3_r14_ASR_r7[] = {
419   0x5e, 0x87, 0x43, 0x60 // sub vs r8 r3 r14 ASR r7
420 };
421 const byte kInstruction_sub_hi_r4_r8_r13_LSL_r1[] = {
422   0x1d, 0x41, 0x48, 0x80 // sub hi r4 r8 r13 LSL r1
423 };
424 const byte kInstruction_sub_al_r6_r11_r11_LSL_r14[] = {
425   0x1b, 0x6e, 0x4b, 0xe0 // sub al r6 r11 r11 LSL r14
426 };
427 const byte kInstruction_sub_al_r7_r2_r4_LSR_r1[] = {
428   0x34, 0x71, 0x42, 0xe0 // sub al r7 r2 r4 LSR r1
429 };
430 const byte kInstruction_sub_vc_r5_r10_r3_ASR_r8[] = {
431   0x53, 0x58, 0x4a, 0x70 // sub vc r5 r10 r3 ASR r8
432 };
433 const byte kInstruction_sub_cc_r3_r10_r9_ROR_r11[] = {
434   0x79, 0x3b, 0x4a, 0x30 // sub cc r3 r10 r9 ROR r11
435 };
436 const byte kInstruction_sub_eq_r11_r9_r8_LSL_r2[] = {
437   0x18, 0xb2, 0x49, 0x00 // sub eq r11 r9 r8 LSL r2
438 };
439 const byte kInstruction_sub_mi_r6_r9_r5_ASR_r12[] = {
440   0x55, 0x6c, 0x49, 0x40 // sub mi r6 r9 r5 ASR r12
441 };
442 const byte kInstruction_sub_hi_r6_r6_r0_ASR_r9[] = {
443   0x50, 0x69, 0x46, 0x80 // sub hi r6 r6 r0 ASR r9
444 };
445 const byte kInstruction_sub_ge_r12_r13_r1_LSL_r9[] = {
446   0x11, 0xc9, 0x4d, 0xa0 // sub ge r12 r13 r1 LSL r9
447 };
448 const byte kInstruction_sub_le_r4_r9_r14_ASR_r2[] = {
449   0x5e, 0x42, 0x49, 0xd0 // sub le r4 r9 r14 ASR r2
450 };
451 const byte kInstruction_sub_gt_r5_r3_r9_ROR_r5[] = {
452   0x79, 0x55, 0x43, 0xc0 // sub gt r5 r3 r9 ROR r5
453 };
454 const byte kInstruction_sub_al_r14_r5_r13_ROR_r7[] = {
455   0x7d, 0xe7, 0x45, 0xe0 // sub al r14 r5 r13 ROR r7
456 };
457 const byte kInstruction_sub_lt_r2_r1_r14_ASR_r8[] = {
458   0x5e, 0x28, 0x41, 0xb0 // sub lt r2 r1 r14 ASR r8
459 };
460 const byte kInstruction_sub_al_r12_r7_r8_LSL_r11[] = {
461   0x18, 0xcb, 0x47, 0xe0 // sub al r12 r7 r8 LSL r11
462 };
463 const byte kInstruction_sub_ne_r4_r12_r14_LSL_r1[] = {
464   0x1e, 0x41, 0x4c, 0x10 // sub ne r4 r12 r14 LSL r1
465 };
466 const byte kInstruction_sub_vs_r7_r14_r4_LSL_r6[] = {
467   0x14, 0x76, 0x4e, 0x60 // sub vs r7 r14 r4 LSL r6
468 };
469 const byte kInstruction_sub_ge_r12_r5_r11_ASR_r4[] = {
470   0x5b, 0xc4, 0x45, 0xa0 // sub ge r12 r5 r11 ASR r4
471 };
472 const byte kInstruction_sub_gt_r4_r10_r6_LSR_r6[] = {
473   0x36, 0x46, 0x4a, 0xc0 // sub gt r4 r10 r6 LSR r6
474 };
475 const byte kInstruction_sub_cc_r14_r8_r14_LSR_r8[] = {
476   0x3e, 0xe8, 0x48, 0x30 // sub cc r14 r8 r14 LSR r8
477 };
478 const byte kInstruction_sub_al_r1_r14_r11_LSR_r7[] = {
479   0x3b, 0x17, 0x4e, 0xe0 // sub al r1 r14 r11 LSR r7
480 };
481 const byte kInstruction_sub_pl_r13_r6_r5_ASR_r14[] = {
482   0x55, 0xde, 0x46, 0x50 // sub pl r13 r6 r5 ASR r14
483 };
484 const byte kInstruction_sub_cc_r10_r6_r9_ROR_r13[] = {
485   0x79, 0xad, 0x46, 0x30 // sub cc r10 r6 r9 ROR r13
486 };
487 const byte kInstruction_sub_ne_r0_r4_r7_ROR_r13[] = {
488   0x77, 0x0d, 0x44, 0x10 // sub ne r0 r4 r7 ROR r13
489 };
490 const byte kInstruction_sub_vc_r12_r0_r14_LSL_r13[] = {
491   0x1e, 0xcd, 0x40, 0x70 // sub vc r12 r0 r14 LSL r13
492 };
493 const byte kInstruction_sub_al_r10_r13_r13_ROR_r5[] = {
494   0x7d, 0xa5, 0x4d, 0xe0 // sub al r10 r13 r13 ROR r5
495 };
496 const byte kInstruction_sub_cs_r10_r3_r0_ROR_r7[] = {
497   0x70, 0xa7, 0x43, 0x20 // sub cs r10 r3 r0 ROR r7
498 };
499 const byte kInstruction_sub_ge_r10_r14_r14_ROR_r6[] = {
500   0x7e, 0xa6, 0x4e, 0xa0 // sub ge r10 r14 r14 ROR r6
501 };
502 const byte kInstruction_sub_pl_r0_r10_r10_LSL_r4[] = {
503   0x1a, 0x04, 0x4a, 0x50 // sub pl r0 r10 r10 LSL r4
504 };
505 const byte kInstruction_sub_vs_r1_r2_r7_ASR_r6[] = {
506   0x57, 0x16, 0x42, 0x60 // sub vs r1 r2 r7 ASR r6
507 };
508 const byte kInstruction_sub_cs_r9_r11_r9_LSL_r9[] = {
509   0x19, 0x99, 0x4b, 0x20 // sub cs r9 r11 r9 LSL r9
510 };
511 const byte kInstruction_sub_eq_r10_r8_r4_LSL_r6[] = {
512   0x14, 0xa6, 0x48, 0x00 // sub eq r10 r8 r4 LSL r6
513 };
514 const byte kInstruction_sub_vc_r8_r5_r12_LSL_r8[] = {
515   0x1c, 0x88, 0x45, 0x70 // sub vc r8 r5 r12 LSL r8
516 };
517 const byte kInstruction_sub_pl_r1_r13_r11_LSL_r8[] = {
518   0x1b, 0x18, 0x4d, 0x50 // sub pl r1 r13 r11 LSL r8
519 };
520 const byte kInstruction_sub_le_r9_r10_r5_ROR_r4[] = {
521   0x75, 0x94, 0x4a, 0xd0 // sub le r9 r10 r5 ROR r4
522 };
523 const byte kInstruction_sub_vs_r8_r3_r0_ASR_r11[] = {
524   0x50, 0x8b, 0x43, 0x60 // sub vs r8 r3 r0 ASR r11
525 };
526 const byte kInstruction_sub_hi_r12_r0_r13_LSL_r2[] = {
527   0x1d, 0xc2, 0x40, 0x80 // sub hi r12 r0 r13 LSL r2
528 };
529 const byte kInstruction_sub_lt_r4_r2_r8_LSL_r5[] = {
530   0x18, 0x45, 0x42, 0xb0 // sub lt r4 r2 r8 LSL r5
531 };
532 const byte kInstruction_sub_ge_r9_r4_r13_LSL_r13[] = {
533   0x1d, 0x9d, 0x44, 0xa0 // sub ge r9 r4 r13 LSL r13
534 };
535 const byte kInstruction_sub_ge_r0_r2_r1_ROR_r8[] = {
536   0x71, 0x08, 0x42, 0xa0 // sub ge r0 r2 r1 ROR r8
537 };
538 const byte kInstruction_sub_le_r6_r13_r9_LSR_r0[] = {
539   0x39, 0x60, 0x4d, 0xd0 // sub le r6 r13 r9 LSR r0
540 };
541 const byte kInstruction_sub_ls_r13_r7_r4_ASR_r3[] = {
542   0x54, 0xd3, 0x47, 0x90 // sub ls r13 r7 r4 ASR r3
543 };
544 const byte kInstruction_sub_vc_r8_r13_r6_LSR_r14[] = {
545   0x36, 0x8e, 0x4d, 0x70 // sub vc r8 r13 r6 LSR r14
546 };
547 const byte kInstruction_sub_pl_r10_r5_r3_LSR_r9[] = {
548   0x33, 0xa9, 0x45, 0x50 // sub pl r10 r5 r3 LSR r9
549 };
550 const byte kInstruction_sub_al_r6_r3_r14_LSR_r7[] = {
551   0x3e, 0x67, 0x43, 0xe0 // sub al r6 r3 r14 LSR r7
552 };
553 const byte kInstruction_sub_cc_r3_r5_r3_ROR_r10[] = {
554   0x73, 0x3a, 0x45, 0x30 // sub cc r3 r5 r3 ROR r10
555 };
556 const byte kInstruction_sub_cs_r4_r11_r2_LSR_r10[] = {
557   0x32, 0x4a, 0x4b, 0x20 // sub cs r4 r11 r2 LSR r10
558 };
559 const byte kInstruction_sub_lt_r6_r10_r5_ASR_r8[] = {
560   0x55, 0x68, 0x4a, 0xb0 // sub lt r6 r10 r5 ASR r8
561 };
562 const byte kInstruction_sub_ge_r0_r13_r10_ASR_r8[] = {
563   0x5a, 0x08, 0x4d, 0xa0 // sub ge r0 r13 r10 ASR r8
564 };
565 const byte kInstruction_sub_cs_r8_r8_r0_LSL_r9[] = {
566   0x10, 0x89, 0x48, 0x20 // sub cs r8 r8 r0 LSL r9
567 };
568 const byte kInstruction_sub_gt_r1_r1_r1_ASR_r2[] = {
569   0x51, 0x12, 0x41, 0xc0 // sub gt r1 r1 r1 ASR r2
570 };
571 const byte kInstruction_sub_al_r5_r0_r14_ROR_r3[] = {
572   0x7e, 0x53, 0x40, 0xe0 // sub al r5 r0 r14 ROR r3
573 };
574 const byte kInstruction_sub_mi_r3_r9_r14_LSL_r9[] = {
575   0x1e, 0x39, 0x49, 0x40 // sub mi r3 r9 r14 LSL r9
576 };
577 const byte kInstruction_sub_ls_r9_r6_r5_LSL_r9[] = {
578   0x15, 0x99, 0x46, 0x90 // sub ls r9 r6 r5 LSL r9
579 };
580 const byte kInstruction_sub_lt_r13_r3_r1_LSL_r13[] = {
581   0x11, 0xdd, 0x43, 0xb0 // sub lt r13 r3 r1 LSL r13
582 };
583 const byte kInstruction_sub_lt_r9_r14_r3_ASR_r3[] = {
584   0x53, 0x93, 0x4e, 0xb0 // sub lt r9 r14 r3 ASR r3
585 };
586 const byte kInstruction_sub_cc_r5_r4_r1_LSR_r0[] = {
587   0x31, 0x50, 0x44, 0x30 // sub cc r5 r4 r1 LSR r0
588 };
589 const byte kInstruction_sub_cs_r9_r7_r8_ASR_r0[] = {
590   0x58, 0x90, 0x47, 0x20 // sub cs r9 r7 r8 ASR r0
591 };
592 const byte kInstruction_sub_ge_r8_r6_r14_ROR_r7[] = {
593   0x7e, 0x87, 0x46, 0xa0 // sub ge r8 r6 r14 ROR r7
594 };
595 const byte kInstruction_sub_le_r14_r8_r12_LSL_r0[] = {
596   0x1c, 0xe0, 0x48, 0xd0 // sub le r14 r8 r12 LSL r0
597 };
598 const byte kInstruction_sub_mi_r0_r13_r14_ASR_r3[] = {
599   0x5e, 0x03, 0x4d, 0x40 // sub mi r0 r13 r14 ASR r3
600 };
601 const byte kInstruction_sub_cs_r7_r4_r9_ROR_r8[] = {
602   0x79, 0x78, 0x44, 0x20 // sub cs r7 r4 r9 ROR r8
603 };
604 const byte kInstruction_sub_ne_r4_r6_r11_ROR_r2[] = {
605   0x7b, 0x42, 0x46, 0x10 // sub ne r4 r6 r11 ROR r2
606 };
607 const byte kInstruction_sub_gt_r8_r8_r9_ROR_r12[] = {
608   0x79, 0x8c, 0x48, 0xc0 // sub gt r8 r8 r9 ROR r12
609 };
610 const byte kInstruction_sub_hi_r1_r2_r0_LSR_r13[] = {
611   0x30, 0x1d, 0x42, 0x80 // sub hi r1 r2 r0 LSR r13
612 };
613 const byte kInstruction_sub_ge_r14_r12_r6_ASR_r5[] = {
614   0x56, 0xe5, 0x4c, 0xa0 // sub ge r14 r12 r6 ASR r5
615 };
616 const byte kInstruction_sub_ge_r5_r4_r7_LSR_r14[] = {
617   0x37, 0x5e, 0x44, 0xa0 // sub ge r5 r4 r7 LSR r14
618 };
619 const byte kInstruction_sub_cc_r13_r11_r10_LSR_r2[] = {
620   0x3a, 0xd2, 0x4b, 0x30 // sub cc r13 r11 r10 LSR r2
621 };
622 const byte kInstruction_sub_mi_r3_r9_r14_LSR_r14[] = {
623   0x3e, 0x3e, 0x49, 0x40 // sub mi r3 r9 r14 LSR r14
624 };
625 const byte kInstruction_sub_ne_r10_r3_r4_LSR_r3[] = {
626   0x34, 0xa3, 0x43, 0x10 // sub ne r10 r3 r4 LSR r3
627 };
628 const byte kInstruction_sub_ls_r14_r9_r6_LSL_r9[] = {
629   0x16, 0xe9, 0x49, 0x90 // sub ls r14 r9 r6 LSL r9
630 };
631 const byte kInstruction_sub_ls_r8_r2_r8_ROR_r7[] = {
632   0x78, 0x87, 0x42, 0x90 // sub ls r8 r2 r8 ROR r7
633 };
634 const byte kInstruction_sub_ne_r2_r6_r3_ROR_r3[] = {
635   0x73, 0x23, 0x46, 0x10 // sub ne r2 r6 r3 ROR r3
636 };
637 const byte kInstruction_sub_mi_r12_r3_r11_ASR_r11[] = {
638   0x5b, 0xcb, 0x43, 0x40 // sub mi r12 r3 r11 ASR r11
639 };
640 const byte kInstruction_sub_le_r7_r10_r11_LSL_r9[] = {
641   0x1b, 0x79, 0x4a, 0xd0 // sub le r7 r10 r11 LSL r9
642 };
643 const byte kInstruction_sub_al_r1_r2_r10_ROR_r8[] = {
644   0x7a, 0x18, 0x42, 0xe0 // sub al r1 r2 r10 ROR r8
645 };
646 const byte kInstruction_sub_cc_r7_r9_r14_LSL_r7[] = {
647   0x1e, 0x77, 0x49, 0x30 // sub cc r7 r9 r14 LSL r7
648 };
649 const byte kInstruction_sub_cc_r9_r3_r5_LSL_r8[] = {
650   0x15, 0x98, 0x43, 0x30 // sub cc r9 r3 r5 LSL r8
651 };
652 const byte kInstruction_sub_hi_r8_r3_r8_ROR_r2[] = {
653   0x78, 0x82, 0x43, 0x80 // sub hi r8 r3 r8 ROR r2
654 };
655 const byte kInstruction_sub_pl_r10_r13_r14_LSR_r10[] = {
656   0x3e, 0xaa, 0x4d, 0x50 // sub pl r10 r13 r14 LSR r10
657 };
658 const byte kInstruction_sub_lt_r13_r4_r13_LSR_r12[] = {
659   0x3d, 0xdc, 0x44, 0xb0 // sub lt r13 r4 r13 LSR r12
660 };
661 const byte kInstruction_sub_ls_r12_r14_r11_LSR_r13[] = {
662   0x3b, 0xcd, 0x4e, 0x90 // sub ls r12 r14 r11 LSR r13
663 };
664 const byte kInstruction_sub_vs_r11_r10_r10_ASR_r2[] = {
665   0x5a, 0xb2, 0x4a, 0x60 // sub vs r11 r10 r10 ASR r2
666 };
667 const byte kInstruction_sub_cc_r5_r8_r13_LSL_r10[] = {
668   0x1d, 0x5a, 0x48, 0x30 // sub cc r5 r8 r13 LSL r10
669 };
670 const byte kInstruction_sub_cs_r7_r4_r11_LSR_r14[] = {
671   0x3b, 0x7e, 0x44, 0x20 // sub cs r7 r4 r11 LSR r14
672 };
673 const byte kInstruction_sub_lt_r1_r12_r7_ASR_r11[] = {
674   0x57, 0x1b, 0x4c, 0xb0 // sub lt r1 r12 r7 ASR r11
675 };
676 const byte kInstruction_sub_vc_r11_r4_r4_LSL_r10[] = {
677   0x14, 0xba, 0x44, 0x70 // sub vc r11 r4 r4 LSL r10
678 };
679 const byte kInstruction_sub_vc_r7_r4_r6_LSR_r7[] = {
680   0x36, 0x77, 0x44, 0x70 // sub vc r7 r4 r6 LSR r7
681 };
682 const byte kInstruction_sub_vc_r0_r3_r0_ASR_r14[] = {
683   0x50, 0x0e, 0x43, 0x70 // sub vc r0 r3 r0 ASR r14
684 };
685 const byte kInstruction_sub_mi_r11_r8_r13_ASR_r8[] = {
686   0x5d, 0xb8, 0x48, 0x40 // sub mi r11 r8 r13 ASR r8
687 };
688 const byte kInstruction_sub_gt_r13_r14_r6_LSL_r11[] = {
689   0x16, 0xdb, 0x4e, 0xc0 // sub gt r13 r14 r6 LSL r11
690 };
691 const byte kInstruction_sub_cs_r3_r2_r6_LSL_r8[] = {
692   0x16, 0x38, 0x42, 0x20 // sub cs r3 r2 r6 LSL r8
693 };
694 const byte kInstruction_sub_ne_r7_r5_r5_LSL_r8[] = {
695   0x15, 0x78, 0x45, 0x10 // sub ne r7 r5 r5 LSL r8
696 };
697 const byte kInstruction_sub_lt_r0_r12_r6_LSR_r0[] = {
698   0x36, 0x00, 0x4c, 0xb0 // sub lt r0 r12 r6 LSR r0
699 };
700 const byte kInstruction_sub_ls_r11_r9_r12_ROR_r2[] = {
701   0x7c, 0xb2, 0x49, 0x90 // sub ls r11 r9 r12 ROR r2
702 };
703 const byte kInstruction_sub_ls_r6_r0_r8_LSR_r4[] = {
704   0x38, 0x64, 0x40, 0x90 // sub ls r6 r0 r8 LSR r4
705 };
706 const byte kInstruction_sub_lt_r6_r7_r0_ROR_r13[] = {
707   0x70, 0x6d, 0x47, 0xb0 // sub lt r6 r7 r0 ROR r13
708 };
709 const byte kInstruction_sub_gt_r14_r4_r1_LSL_r8[] = {
710   0x11, 0xe8, 0x44, 0xc0 // sub gt r14 r4 r1 LSL r8
711 };
712 const byte kInstruction_sub_al_r14_r5_r6_LSL_r7[] = {
713   0x16, 0xe7, 0x45, 0xe0 // sub al r14 r5 r6 LSL r7
714 };
715 const byte kInstruction_sub_ge_r9_r6_r4_LSR_r8[] = {
716   0x34, 0x98, 0x46, 0xa0 // sub ge r9 r6 r4 LSR r8
717 };
718 const byte kInstruction_sub_lt_r2_r14_r13_ROR_r3[] = {
719   0x7d, 0x23, 0x4e, 0xb0 // sub lt r2 r14 r13 ROR r3
720 };
721 const byte kInstruction_sub_al_r11_r1_r13_LSR_r9[] = {
722   0x3d, 0xb9, 0x41, 0xe0 // sub al r11 r1 r13 LSR r9
723 };
724 const byte kInstruction_sub_vs_r8_r2_r5_LSL_r11[] = {
725   0x15, 0x8b, 0x42, 0x60 // sub vs r8 r2 r5 LSL r11
726 };
727 const byte kInstruction_sub_pl_r8_r14_r8_LSL_r7[] = {
728   0x18, 0x87, 0x4e, 0x50 // sub pl r8 r14 r8 LSL r7
729 };
730 const byte kInstruction_sub_cs_r10_r5_r5_ASR_r4[] = {
731   0x55, 0xa4, 0x45, 0x20 // sub cs r10 r5 r5 ASR r4
732 };
733 const byte kInstruction_sub_eq_r12_r14_r9_LSR_r11[] = {
734   0x39, 0xcb, 0x4e, 0x00 // sub eq r12 r14 r9 LSR r11
735 };
736 const byte kInstruction_sub_lt_r1_r3_r3_LSL_r1[] = {
737   0x13, 0x11, 0x43, 0xb0 // sub lt r1 r3 r3 LSL r1
738 };
739 const byte kInstruction_sub_le_r4_r13_r4_ASR_r8[] = {
740   0x54, 0x48, 0x4d, 0xd0 // sub le r4 r13 r4 ASR r8
741 };
742 const byte kInstruction_sub_ne_r5_r4_r2_LSL_r8[] = {
743   0x12, 0x58, 0x44, 0x10 // sub ne r5 r4 r2 LSL r8
744 };
745 const byte kInstruction_sub_le_r3_r14_r13_LSR_r1[] = {
746   0x3d, 0x31, 0x4e, 0xd0 // sub le r3 r14 r13 LSR r1
747 };
748 const byte kInstruction_sub_cc_r6_r3_r5_LSL_r1[] = {
749   0x15, 0x61, 0x43, 0x30 // sub cc r6 r3 r5 LSL r1
750 };
751 const byte kInstruction_sub_lt_r9_r6_r11_LSR_r14[] = {
752   0x3b, 0x9e, 0x46, 0xb0 // sub lt r9 r6 r11 LSR r14
753 };
754 const byte kInstruction_sub_cc_r13_r8_r10_ROR_r1[] = {
755   0x7a, 0xd1, 0x48, 0x30 // sub cc r13 r8 r10 ROR r1
756 };
757 const byte kInstruction_sub_lt_r7_r10_r11_LSR_r2[] = {
758   0x3b, 0x72, 0x4a, 0xb0 // sub lt r7 r10 r11 LSR r2
759 };
760 const byte kInstruction_sub_pl_r0_r9_r5_LSR_r8[] = {
761   0x35, 0x08, 0x49, 0x50 // sub pl r0 r9 r5 LSR r8
762 };
763 const byte kInstruction_sub_eq_r8_r9_r11_LSR_r13[] = {
764   0x3b, 0x8d, 0x49, 0x00 // sub eq r8 r9 r11 LSR r13
765 };
766 const byte kInstruction_sub_hi_r10_r1_r9_ROR_r12[] = {
767   0x79, 0xac, 0x41, 0x80 // sub hi r10 r1 r9 ROR r12
768 };
769 const byte kInstruction_sub_pl_r13_r1_r14_LSL_r14[] = {
770   0x1e, 0xde, 0x41, 0x50 // sub pl r13 r1 r14 LSL r14
771 };
772 const byte kInstruction_sub_eq_r13_r3_r7_LSR_r13[] = {
773   0x37, 0xdd, 0x43, 0x00 // sub eq r13 r3 r7 LSR r13
774 };
775 const byte kInstruction_sub_eq_r3_r6_r6_ASR_r14[] = {
776   0x56, 0x3e, 0x46, 0x00 // sub eq r3 r6 r6 ASR r14
777 };
778 const byte kInstruction_sub_gt_r5_r4_r8_ROR_r13[] = {
779   0x78, 0x5d, 0x44, 0xc0 // sub gt r5 r4 r8 ROR r13
780 };
781 const byte kInstruction_sub_al_r9_r7_r0_ROR_r3[] = {
782   0x70, 0x93, 0x47, 0xe0 // sub al r9 r7 r0 ROR r3
783 };
784 const byte kInstruction_sub_mi_r13_r11_r3_LSL_r1[] = {
785   0x13, 0xd1, 0x4b, 0x40 // sub mi r13 r11 r3 LSL r1
786 };
787 const byte kInstruction_sub_ls_r11_r14_r6_LSL_r14[] = {
788   0x16, 0xbe, 0x4e, 0x90 // sub ls r11 r14 r6 LSL r14
789 };
790 const byte kInstruction_sub_al_r14_r3_r7_LSL_r9[] = {
791   0x17, 0xe9, 0x43, 0xe0 // sub al r14 r3 r7 LSL r9
792 };
793 const byte kInstruction_sub_cs_r14_r2_r14_LSL_r13[] = {
794   0x1e, 0xed, 0x42, 0x20 // sub cs r14 r2 r14 LSL r13
795 };
796 const byte kInstruction_sub_ls_r11_r10_r6_ASR_r11[] = {
797   0x56, 0xbb, 0x4a, 0x90 // sub ls r11 r10 r6 ASR r11
798 };
799 const byte kInstruction_sub_pl_r13_r4_r2_LSL_r4[] = {
800   0x12, 0xd4, 0x44, 0x50 // sub pl r13 r4 r2 LSL r4
801 };
802 const byte kInstruction_sub_mi_r8_r10_r5_ASR_r0[] = {
803   0x55, 0x80, 0x4a, 0x40 // sub mi r8 r10 r5 ASR r0
804 };
805 const byte kInstruction_sub_cs_r2_r1_r6_ASR_r4[] = {
806   0x56, 0x24, 0x41, 0x20 // sub cs r2 r1 r6 ASR r4
807 };
808 const byte kInstruction_sub_cc_r0_r11_r8_LSR_r14[] = {
809   0x38, 0x0e, 0x4b, 0x30 // sub cc r0 r11 r8 LSR r14
810 };
811 const byte kInstruction_sub_ge_r5_r4_r6_ROR_r1[] = {
812   0x76, 0x51, 0x44, 0xa0 // sub ge r5 r4 r6 ROR r1
813 };
814 const byte kInstruction_sub_cs_r0_r14_r3_LSR_r11[] = {
815   0x33, 0x0b, 0x4e, 0x20 // sub cs r0 r14 r3 LSR r11
816 };
817 const byte kInstruction_sub_ge_r9_r4_r10_LSR_r13[] = {
818   0x3a, 0x9d, 0x44, 0xa0 // sub ge r9 r4 r10 LSR r13
819 };
820 const byte kInstruction_sub_ne_r11_r0_r9_LSL_r8[] = {
821   0x19, 0xb8, 0x40, 0x10 // sub ne r11 r0 r9 LSL r8
822 };
823 const byte kInstruction_sub_vs_r4_r1_r0_LSL_r8[] = {
824   0x10, 0x48, 0x41, 0x60 // sub vs r4 r1 r0 LSL r8
825 };
826 const byte kInstruction_sub_le_r5_r5_r4_ROR_r10[] = {
827   0x74, 0x5a, 0x45, 0xd0 // sub le r5 r5 r4 ROR r10
828 };
829 const byte kInstruction_sub_al_r9_r5_r0_ROR_r6[] = {
830   0x70, 0x96, 0x45, 0xe0 // sub al r9 r5 r0 ROR r6
831 };
832 const byte kInstruction_sub_hi_r6_r6_r9_LSR_r12[] = {
833   0x39, 0x6c, 0x46, 0x80 // sub hi r6 r6 r9 LSR r12
834 };
835 const byte kInstruction_sub_lt_r1_r4_r9_ROR_r4[] = {
836   0x79, 0x14, 0x44, 0xb0 // sub lt r1 r4 r9 ROR r4
837 };
838 const byte kInstruction_sub_vc_r4_r7_r0_ROR_r11[] = {
839   0x70, 0x4b, 0x47, 0x70 // sub vc r4 r7 r0 ROR r11
840 };
841 const byte kInstruction_sub_gt_r1_r4_r2_ROR_r8[] = {
842   0x72, 0x18, 0x44, 0xc0 // sub gt r1 r4 r2 ROR r8
843 };
844 const byte kInstruction_sub_ne_r4_r5_r9_LSL_r6[] = {
845   0x19, 0x46, 0x45, 0x10 // sub ne r4 r5 r9 LSL r6
846 };
847 const byte kInstruction_sub_gt_r3_r4_r10_LSR_r5[] = {
848   0x3a, 0x35, 0x44, 0xc0 // sub gt r3 r4 r10 LSR r5
849 };
850 const byte kInstruction_sub_al_r7_r9_r2_ROR_r2[] = {
851   0x72, 0x72, 0x49, 0xe0 // sub al r7 r9 r2 ROR r2
852 };
853 const byte kInstruction_sub_le_r3_r8_r2_LSL_r2[] = {
854   0x12, 0x32, 0x48, 0xd0 // sub le r3 r8 r2 LSL r2
855 };
856 const byte kInstruction_sub_hi_r3_r8_r0_LSL_r1[] = {
857   0x10, 0x31, 0x48, 0x80 // sub hi r3 r8 r0 LSL r1
858 };
859 const byte kInstruction_sub_ge_r11_r4_r4_LSL_r14[] = {
860   0x14, 0xbe, 0x44, 0xa0 // sub ge r11 r4 r4 LSL r14
861 };
862 const byte kInstruction_sub_mi_r8_r14_r1_LSR_r13[] = {
863   0x31, 0x8d, 0x4e, 0x40 // sub mi r8 r14 r1 LSR r13
864 };
865 const byte kInstruction_sub_pl_r6_r1_r10_LSL_r0[] = {
866   0x1a, 0x60, 0x41, 0x50 // sub pl r6 r1 r10 LSL r0
867 };
868 const byte kInstruction_sub_eq_r11_r7_r13_LSL_r0[] = {
869   0x1d, 0xb0, 0x47, 0x00 // sub eq r11 r7 r13 LSL r0
870 };
871 const byte kInstruction_sub_cc_r4_r9_r11_LSR_r1[] = {
872   0x3b, 0x41, 0x49, 0x30 // sub cc r4 r9 r11 LSR r1
873 };
874 const byte kInstruction_sub_cc_r8_r2_r3_LSR_r8[] = {
875   0x33, 0x88, 0x42, 0x30 // sub cc r8 r2 r3 LSR r8
876 };
877 const byte kInstruction_sub_ne_r5_r1_r14_LSL_r12[] = {
878   0x1e, 0x5c, 0x41, 0x10 // sub ne r5 r1 r14 LSL r12
879 };
880 const byte kInstruction_sub_le_r13_r5_r2_ASR_r1[] = {
881   0x52, 0xd1, 0x45, 0xd0 // sub le r13 r5 r2 ASR r1
882 };
883 const byte kInstruction_sub_al_r0_r5_r0_LSL_r4[] = {
884   0x10, 0x04, 0x45, 0xe0 // sub al r0 r5 r0 LSL r4
885 };
886 const byte kInstruction_sub_mi_r3_r1_r4_LSR_r3[] = {
887   0x34, 0x33, 0x41, 0x40 // sub mi r3 r1 r4 LSR r3
888 };
889 const byte kInstruction_sub_cs_r3_r7_r0_ROR_r8[] = {
890   0x70, 0x38, 0x47, 0x20 // sub cs r3 r7 r0 ROR r8
891 };
892 const byte kInstruction_sub_cs_r11_r14_r4_LSR_r13[] = {
893   0x34, 0xbd, 0x4e, 0x20 // sub cs r11 r14 r4 LSR r13
894 };
895 const byte kInstruction_sub_vs_r11_r10_r8_ASR_r3[] = {
896   0x58, 0xb3, 0x4a, 0x60 // sub vs r11 r10 r8 ASR r3
897 };
898 const byte kInstruction_sub_gt_r10_r8_r9_LSL_r13[] = {
899   0x19, 0xad, 0x48, 0xc0 // sub gt r10 r8 r9 LSL r13
900 };
901 const byte kInstruction_sub_eq_r10_r1_r8_ASR_r9[] = {
902   0x58, 0xa9, 0x41, 0x00 // sub eq r10 r1 r8 ASR r9
903 };
904 const byte kInstruction_sub_al_r2_r1_r10_ASR_r8[] = {
905   0x5a, 0x28, 0x41, 0xe0 // sub al r2 r1 r10 ASR r8
906 };
907 const byte kInstruction_sub_al_r7_r1_r7_ROR_r11[] = {
908   0x77, 0x7b, 0x41, 0xe0 // sub al r7 r1 r7 ROR r11
909 };
910 const byte kInstruction_sub_cs_r0_r5_r6_ASR_r1[] = {
911   0x56, 0x01, 0x45, 0x20 // sub cs r0 r5 r6 ASR r1
912 };
913 const byte kInstruction_sub_lt_r12_r11_r10_LSR_r14[] = {
914   0x3a, 0xce, 0x4b, 0xb0 // sub lt r12 r11 r10 LSR r14
915 };
916 const byte kInstruction_sub_pl_r13_r7_r5_LSL_r2[] = {
917   0x15, 0xd2, 0x47, 0x50 // sub pl r13 r7 r5 LSL r2
918 };
919 const byte kInstruction_sub_ne_r2_r0_r12_LSL_r11[] = {
920   0x1c, 0x2b, 0x40, 0x10 // sub ne r2 r0 r12 LSL r11
921 };
922 const byte kInstruction_sub_ls_r14_r9_r12_ROR_r6[] = {
923   0x7c, 0xe6, 0x49, 0x90 // sub ls r14 r9 r12 ROR r6
924 };
925 const byte kInstruction_sub_cc_r9_r2_r8_ASR_r3[] = {
926   0x58, 0x93, 0x42, 0x30 // sub cc r9 r2 r8 ASR r3
927 };
928 const byte kInstruction_sub_pl_r12_r11_r0_ASR_r7[] = {
929   0x50, 0xc7, 0x4b, 0x50 // sub pl r12 r11 r0 ASR r7
930 };
931 const byte kInstruction_sub_vs_r12_r2_r3_ROR_r1[] = {
932   0x73, 0xc1, 0x42, 0x60 // sub vs r12 r2 r3 ROR r1
933 };
934 const byte kInstruction_sub_al_r3_r1_r8_LSL_r4[] = {
935   0x18, 0x34, 0x41, 0xe0 // sub al r3 r1 r8 LSL r4
936 };
937 const byte kInstruction_sub_mi_r7_r9_r13_ASR_r5[] = {
938   0x5d, 0x75, 0x49, 0x40 // sub mi r7 r9 r13 ASR r5
939 };
940 const byte kInstruction_sub_vs_r13_r4_r10_ROR_r9[] = {
941   0x7a, 0xd9, 0x44, 0x60 // sub vs r13 r4 r10 ROR r9
942 };
943 const byte kInstruction_sub_eq_r8_r2_r3_LSR_r2[] = {
944   0x33, 0x82, 0x42, 0x00 // sub eq r8 r2 r3 LSR r2
945 };
946 const byte kInstruction_sub_cs_r0_r3_r11_LSR_r7[] = {
947   0x3b, 0x07, 0x43, 0x20 // sub cs r0 r3 r11 LSR r7
948 };
949 const byte kInstruction_sub_pl_r2_r10_r9_ASR_r13[] = {
950   0x59, 0x2d, 0x4a, 0x50 // sub pl r2 r10 r9 ASR r13
951 };
952 const byte kInstruction_sub_eq_r14_r0_r7_ASR_r0[] = {
953   0x57, 0xe0, 0x40, 0x00 // sub eq r14 r0 r7 ASR r0
954 };
955 const byte kInstruction_sub_lt_r12_r11_r7_ROR_r7[] = {
956   0x77, 0xc7, 0x4b, 0xb0 // sub lt r12 r11 r7 ROR r7
957 };
958 const byte kInstruction_sub_eq_r4_r10_r1_LSL_r2[] = {
959   0x11, 0x42, 0x4a, 0x00 // sub eq r4 r10 r1 LSL r2
960 };
961 const byte kInstruction_sub_al_r7_r14_r12_ASR_r6[] = {
962   0x5c, 0x76, 0x4e, 0xe0 // sub al r7 r14 r12 ASR r6
963 };
964 const byte kInstruction_sub_al_r2_r5_r13_ASR_r1[] = {
965   0x5d, 0x21, 0x45, 0xe0 // sub al r2 r5 r13 ASR r1
966 };
967 const byte kInstruction_sub_hi_r0_r3_r14_LSL_r11[] = {
968   0x1e, 0x0b, 0x43, 0x80 // sub hi r0 r3 r14 LSL r11
969 };
970 const byte kInstruction_sub_vs_r5_r6_r9_LSR_r13[] = {
971   0x39, 0x5d, 0x46, 0x60 // sub vs r5 r6 r9 LSR r13
972 };
973 const byte kInstruction_sub_hi_r14_r0_r14_ROR_r14[] = {
974   0x7e, 0xee, 0x40, 0x80 // sub hi r14 r0 r14 ROR r14
975 };
976 const byte kInstruction_sub_eq_r9_r3_r13_ROR_r9[] = {
977   0x7d, 0x99, 0x43, 0x00 // sub eq r9 r3 r13 ROR r9
978 };
979 const byte kInstruction_sub_hi_r6_r8_r1_ASR_r14[] = {
980   0x51, 0x6e, 0x48, 0x80 // sub hi r6 r8 r1 ASR r14
981 };
982 const byte kInstruction_sub_vs_r13_r2_r8_LSR_r7[] = {
983   0x38, 0xd7, 0x42, 0x60 // sub vs r13 r2 r8 LSR r7
984 };
985 const byte kInstruction_sub_cc_r13_r0_r8_LSR_r7[] = {
986   0x38, 0xd7, 0x40, 0x30 // sub cc r13 r0 r8 LSR r7
987 };
988 const byte kInstruction_sub_le_r12_r0_r11_ASR_r9[] = {
989   0x5b, 0xc9, 0x40, 0xd0 // sub le r12 r0 r11 ASR r9
990 };
991 const byte kInstruction_sub_le_r8_r8_r1_LSR_r6[] = {
992   0x31, 0x86, 0x48, 0xd0 // sub le r8 r8 r1 LSR r6
993 };
994 const byte kInstruction_sub_cs_r5_r14_r7_ASR_r3[] = {
995   0x57, 0x53, 0x4e, 0x20 // sub cs r5 r14 r7 ASR r3
996 };
997 const byte kInstruction_sub_eq_r13_r13_r10_ROR_r12[] = {
998   0x7a, 0xdc, 0x4d, 0x00 // sub eq r13 r13 r10 ROR r12
999 };
1000 const byte kInstruction_sub_lt_r4_r7_r7_LSR_r5[] = {
1001   0x37, 0x45, 0x47, 0xb0 // sub lt r4 r7 r7 LSR r5
1002 };
1003 const byte kInstruction_sub_le_r6_r13_r10_LSR_r2[] = {
1004   0x3a, 0x62, 0x4d, 0xd0 // sub le r6 r13 r10 LSR r2
1005 };
1006 const byte kInstruction_sub_eq_r10_r13_r10_ASR_r8[] = {
1007   0x5a, 0xa8, 0x4d, 0x00 // sub eq r10 r13 r10 ASR r8
1008 };
1009 const byte kInstruction_sub_ne_r6_r5_r12_LSR_r12[] = {
1010   0x3c, 0x6c, 0x45, 0x10 // sub ne r6 r5 r12 LSR r12
1011 };
1012 const byte kInstruction_sub_vc_r10_r8_r10_ROR_r8[] = {
1013   0x7a, 0xa8, 0x48, 0x70 // sub vc r10 r8 r10 ROR r8
1014 };
1015 const byte kInstruction_sub_gt_r10_r1_r8_LSR_r1[] = {
1016   0x38, 0xa1, 0x41, 0xc0 // sub gt r10 r1 r8 LSR r1
1017 };
1018 const byte kInstruction_sub_pl_r5_r12_r9_LSR_r13[] = {
1019   0x39, 0x5d, 0x4c, 0x50 // sub pl r5 r12 r9 LSR r13
1020 };
1021 const byte kInstruction_sub_gt_r10_r6_r4_ROR_r12[] = {
1022   0x74, 0xac, 0x46, 0xc0 // sub gt r10 r6 r4 ROR r12
1023 };
1024 const byte kInstruction_sub_cs_r14_r10_r10_ASR_r6[] = {
1025   0x5a, 0xe6, 0x4a, 0x20 // sub cs r14 r10 r10 ASR r6
1026 };
1027 const byte kInstruction_sub_le_r6_r8_r2_ROR_r7[] = {
1028   0x72, 0x67, 0x48, 0xd0 // sub le r6 r8 r2 ROR r7
1029 };
1030 const byte kInstruction_sub_le_r13_r12_r0_ROR_r14[] = {
1031   0x70, 0xde, 0x4c, 0xd0 // sub le r13 r12 r0 ROR r14
1032 };
1033 const byte kInstruction_sub_le_r7_r6_r0_ASR_r10[] = {
1034   0x50, 0x7a, 0x46, 0xd0 // sub le r7 r6 r0 ASR r10
1035 };
1036 const byte kInstruction_sub_cs_r10_r4_r1_ASR_r10[] = {
1037   0x51, 0xaa, 0x44, 0x20 // sub cs r10 r4 r1 ASR r10
1038 };
1039 const byte kInstruction_sub_ne_r12_r9_r11_ASR_r6[] = {
1040   0x5b, 0xc6, 0x49, 0x10 // sub ne r12 r9 r11 ASR r6
1041 };
1042 const byte kInstruction_sub_vs_r9_r14_r6_ASR_r12[] = {
1043   0x56, 0x9c, 0x4e, 0x60 // sub vs r9 r14 r6 ASR r12
1044 };
1045 const byte kInstruction_sub_mi_r1_r8_r0_ASR_r7[] = {
1046   0x50, 0x17, 0x48, 0x40 // sub mi r1 r8 r0 ASR r7
1047 };
1048 const byte kInstruction_sub_gt_r11_r2_r3_ROR_r11[] = {
1049   0x73, 0xbb, 0x42, 0xc0 // sub gt r11 r2 r3 ROR r11
1050 };
1051 const byte kInstruction_sub_cs_r3_r1_r12_LSR_r0[] = {
1052   0x3c, 0x30, 0x41, 0x20 // sub cs r3 r1 r12 LSR r0
1053 };
1054 const byte kInstruction_sub_hi_r12_r14_r11_LSL_r2[] = {
1055   0x1b, 0xc2, 0x4e, 0x80 // sub hi r12 r14 r11 LSL r2
1056 };
1057 const byte kInstruction_sub_mi_r10_r11_r14_LSL_r10[] = {
1058   0x1e, 0xaa, 0x4b, 0x40 // sub mi r10 r11 r14 LSL r10
1059 };
1060 const byte kInstruction_sub_al_r11_r6_r13_ASR_r2[] = {
1061   0x5d, 0xb2, 0x46, 0xe0 // sub al r11 r6 r13 ASR r2
1062 };
1063 const byte kInstruction_sub_gt_r2_r14_r3_ROR_r6[] = {
1064   0x73, 0x26, 0x4e, 0xc0 // sub gt r2 r14 r3 ROR r6
1065 };
1066 const byte kInstruction_sub_hi_r1_r10_r6_LSR_r6[] = {
1067   0x36, 0x16, 0x4a, 0x80 // sub hi r1 r10 r6 LSR r6
1068 };
1069 const byte kInstruction_sub_gt_r2_r8_r3_LSL_r6[] = {
1070   0x13, 0x26, 0x48, 0xc0 // sub gt r2 r8 r3 LSL r6
1071 };
1072 const byte kInstruction_sub_ls_r13_r4_r12_ROR_r13[] = {
1073   0x7c, 0xdd, 0x44, 0x90 // sub ls r13 r4 r12 ROR r13
1074 };
1075 const byte kInstruction_sub_vs_r13_r11_r7_ROR_r8[] = {
1076   0x77, 0xd8, 0x4b, 0x60 // sub vs r13 r11 r7 ROR r8
1077 };
1078 const byte kInstruction_sub_hi_r5_r12_r14_LSR_r3[] = {
1079   0x3e, 0x53, 0x4c, 0x80 // sub hi r5 r12 r14 LSR r3
1080 };
1081 const byte kInstruction_sub_cs_r14_r8_r3_ROR_r13[] = {
1082   0x73, 0xed, 0x48, 0x20 // sub cs r14 r8 r3 ROR r13
1083 };
1084 const byte kInstruction_sub_cs_r9_r10_r0_LSL_r10[] = {
1085   0x10, 0x9a, 0x4a, 0x20 // sub cs r9 r10 r0 LSL r10
1086 };
1087 const byte kInstruction_sub_lt_r0_r13_r12_ASR_r5[] = {
1088   0x5c, 0x05, 0x4d, 0xb0 // sub lt r0 r13 r12 ASR r5
1089 };
1090 const byte kInstruction_sub_cs_r4_r5_r7_ROR_r7[] = {
1091   0x77, 0x47, 0x45, 0x20 // sub cs r4 r5 r7 ROR r7
1092 };
1093 const byte kInstruction_sub_lt_r0_r14_r7_LSR_r7[] = {
1094   0x37, 0x07, 0x4e, 0xb0 // sub lt r0 r14 r7 LSR r7
1095 };
1096 const byte kInstruction_sub_hi_r10_r5_r3_LSL_r10[] = {
1097   0x13, 0xaa, 0x45, 0x80 // sub hi r10 r5 r3 LSL r10
1098 };
1099 const byte kInstruction_sub_ls_r6_r2_r4_ROR_r0[] = {
1100   0x74, 0x60, 0x42, 0x90 // sub ls r6 r2 r4 ROR r0
1101 };
1102 const byte kInstruction_sub_hi_r9_r7_r7_ASR_r10[] = {
1103   0x57, 0x9a, 0x47, 0x80 // sub hi r9 r7 r7 ASR r10
1104 };
1105 const byte kInstruction_sub_cc_r0_r9_r4_LSR_r2[] = {
1106   0x34, 0x02, 0x49, 0x30 // sub cc r0 r9 r4 LSR r2
1107 };
1108 const byte kInstruction_sub_le_r3_r14_r2_ASR_r0[] = {
1109   0x52, 0x30, 0x4e, 0xd0 // sub le r3 r14 r2 ASR r0
1110 };
1111 const byte kInstruction_sub_pl_r2_r8_r7_LSL_r13[] = {
1112   0x17, 0x2d, 0x48, 0x50 // sub pl r2 r8 r7 LSL r13
1113 };
1114 const byte kInstruction_sub_al_r10_r1_r9_LSR_r6[] = {
1115   0x39, 0xa6, 0x41, 0xe0 // sub al r10 r1 r9 LSR r6
1116 };
1117 const byte kInstruction_sub_vs_r1_r6_r14_ASR_r14[] = {
1118   0x5e, 0x1e, 0x46, 0x60 // sub vs r1 r6 r14 ASR r14
1119 };
1120 const byte kInstruction_sub_lt_r3_r3_r13_LSR_r0[] = {
1121   0x3d, 0x30, 0x43, 0xb0 // sub lt r3 r3 r13 LSR r0
1122 };
1123 const byte kInstruction_sub_le_r9_r3_r2_ASR_r11[] = {
1124   0x52, 0x9b, 0x43, 0xd0 // sub le r9 r3 r2 ASR r11
1125 };
1126 const byte kInstruction_sub_mi_r4_r14_r6_LSL_r11[] = {
1127   0x16, 0x4b, 0x4e, 0x40 // sub mi r4 r14 r6 LSL r11
1128 };
1129 const byte kInstruction_sub_ne_r7_r5_r14_ASR_r9[] = {
1130   0x5e, 0x79, 0x45, 0x10 // sub ne r7 r5 r14 ASR r9
1131 };
1132 const byte kInstruction_sub_cs_r11_r11_r13_LSR_r11[] = {
1133   0x3d, 0xbb, 0x4b, 0x20 // sub cs r11 r11 r13 LSR r11
1134 };
1135 const byte kInstruction_sub_lt_r12_r9_r5_LSR_r9[] = {
1136   0x35, 0xc9, 0x49, 0xb0 // sub lt r12 r9 r5 LSR r9
1137 };
1138 const byte kInstruction_sub_hi_r13_r1_r10_LSL_r4[] = {
1139   0x1a, 0xd4, 0x41, 0x80 // sub hi r13 r1 r10 LSL r4
1140 };
1141 const byte kInstruction_sub_mi_r14_r6_r8_ASR_r14[] = {
1142   0x58, 0xee, 0x46, 0x40 // sub mi r14 r6 r8 ASR r14
1143 };
1144 const byte kInstruction_sub_vc_r3_r2_r6_ASR_r3[] = {
1145   0x56, 0x33, 0x42, 0x70 // sub vc r3 r2 r6 ASR r3
1146 };
1147 const byte kInstruction_sub_ne_r13_r14_r0_ASR_r2[] = {
1148   0x50, 0xd2, 0x4e, 0x10 // sub ne r13 r14 r0 ASR r2
1149 };
1150 const byte kInstruction_sub_gt_r2_r14_r5_ROR_r1[] = {
1151   0x75, 0x21, 0x4e, 0xc0 // sub gt r2 r14 r5 ROR r1
1152 };
1153 const byte kInstruction_sub_ls_r7_r7_r9_LSR_r10[] = {
1154   0x39, 0x7a, 0x47, 0x90 // sub ls r7 r7 r9 LSR r10
1155 };
1156 const byte kInstruction_sub_gt_r2_r12_r8_ASR_r5[] = {
1157   0x58, 0x25, 0x4c, 0xc0 // sub gt r2 r12 r8 ASR r5
1158 };
1159 const byte kInstruction_sub_lt_r13_r2_r11_ROR_r6[] = {
1160   0x7b, 0xd6, 0x42, 0xb0 // sub lt r13 r2 r11 ROR r6
1161 };
1162 const byte kInstruction_sub_cc_r2_r13_r13_ASR_r1[] = {
1163   0x5d, 0x21, 0x4d, 0x30 // sub cc r2 r13 r13 ASR r1
1164 };
1165 const byte kInstruction_sub_vs_r0_r6_r14_ROR_r3[] = {
1166   0x7e, 0x03, 0x46, 0x60 // sub vs r0 r6 r14 ROR r3
1167 };
1168 const byte kInstruction_sub_vs_r2_r13_r8_LSL_r9[] = {
1169   0x18, 0x29, 0x4d, 0x60 // sub vs r2 r13 r8 LSL r9
1170 };
1171 const byte kInstruction_sub_pl_r2_r12_r12_ROR_r6[] = {
1172   0x7c, 0x26, 0x4c, 0x50 // sub pl r2 r12 r12 ROR r6
1173 };
1174 const byte kInstruction_sub_vc_r4_r0_r12_ASR_r13[] = {
1175   0x5c, 0x4d, 0x40, 0x70 // sub vc r4 r0 r12 ASR r13
1176 };
1177 const byte kInstruction_sub_mi_r8_r12_r7_ASR_r7[] = {
1178   0x57, 0x87, 0x4c, 0x40 // sub mi r8 r12 r7 ASR r7
1179 };
1180 const byte kInstruction_sub_al_r13_r5_r0_LSL_r5[] = {
1181   0x10, 0xd5, 0x45, 0xe0 // sub al r13 r5 r0 LSL r5
1182 };
1183 const byte kInstruction_sub_le_r9_r1_r12_LSR_r8[] = {
1184   0x3c, 0x98, 0x41, 0xd0 // sub le r9 r1 r12 LSR r8
1185 };
1186 const byte kInstruction_sub_vs_r5_r10_r13_ROR_r1[] = {
1187   0x7d, 0x51, 0x4a, 0x60 // sub vs r5 r10 r13 ROR r1
1188 };
1189 const byte kInstruction_sub_vs_r8_r5_r0_LSR_r11[] = {
1190   0x30, 0x8b, 0x45, 0x60 // sub vs r8 r5 r0 LSR r11
1191 };
1192 const byte kInstruction_sub_ne_r7_r2_r0_LSL_r4[] = {
1193   0x10, 0x74, 0x42, 0x10 // sub ne r7 r2 r0 LSL r4
1194 };
1195 const byte kInstruction_sub_lt_r6_r6_r9_LSL_r10[] = {
1196   0x19, 0x6a, 0x46, 0xb0 // sub lt r6 r6 r9 LSL r10
1197 };
1198 const byte kInstruction_sub_cs_r13_r3_r4_ROR_r12[] = {
1199   0x74, 0xdc, 0x43, 0x20 // sub cs r13 r3 r4 ROR r12
1200 };
1201 const byte kInstruction_sub_ne_r11_r11_r0_LSL_r7[] = {
1202   0x10, 0xb7, 0x4b, 0x10 // sub ne r11 r11 r0 LSL r7
1203 };
1204 const byte kInstruction_sub_pl_r3_r14_r12_LSR_r13[] = {
1205   0x3c, 0x3d, 0x4e, 0x50 // sub pl r3 r14 r12 LSR r13
1206 };
1207 const byte kInstruction_sub_al_r2_r14_r3_LSL_r11[] = {
1208   0x13, 0x2b, 0x4e, 0xe0 // sub al r2 r14 r3 LSL r11
1209 };
1210 const byte kInstruction_sub_vc_r4_r6_r3_LSR_r7[] = {
1211   0x33, 0x47, 0x46, 0x70 // sub vc r4 r6 r3 LSR r7
1212 };
1213 const byte kInstruction_sub_ls_r6_r2_r1_LSR_r6[] = {
1214   0x31, 0x66, 0x42, 0x90 // sub ls r6 r2 r1 LSR r6
1215 };
1216 const byte kInstruction_sub_le_r0_r2_r5_ASR_r3[] = {
1217   0x55, 0x03, 0x42, 0xd0 // sub le r0 r2 r5 ASR r3
1218 };
1219 const byte kInstruction_sub_ge_r12_r9_r12_ROR_r13[] = {
1220   0x7c, 0xcd, 0x49, 0xa0 // sub ge r12 r9 r12 ROR r13
1221 };
1222 const byte kInstruction_sub_cc_r10_r5_r3_ROR_r12[] = {
1223   0x73, 0xac, 0x45, 0x30 // sub cc r10 r5 r3 ROR r12
1224 };
1225 const byte kInstruction_sub_mi_r14_r0_r10_ASR_r4[] = {
1226   0x5a, 0xe4, 0x40, 0x40 // sub mi r14 r0 r10 ASR r4
1227 };
1228 const byte kInstruction_sub_al_r12_r0_r3_ROR_r13[] = {
1229   0x73, 0xcd, 0x40, 0xe0 // sub al r12 r0 r3 ROR r13
1230 };
1231 const byte kInstruction_sub_hi_r1_r8_r13_ASR_r2[] = {
1232   0x5d, 0x12, 0x48, 0x80 // sub hi r1 r8 r13 ASR r2
1233 };
1234 const byte kInstruction_sub_ls_r7_r9_r9_ASR_r2[] = {
1235   0x59, 0x72, 0x49, 0x90 // sub ls r7 r9 r9 ASR r2
1236 };
1237 const byte kInstruction_sub_ls_r9_r13_r6_ROR_r11[] = {
1238   0x76, 0x9b, 0x4d, 0x90 // sub ls r9 r13 r6 ROR r11
1239 };
1240 const byte kInstruction_sub_pl_r11_r12_r14_LSL_r14[] = {
1241   0x1e, 0xbe, 0x4c, 0x50 // sub pl r11 r12 r14 LSL r14
1242 };
1243 const byte kInstruction_sub_eq_r1_r3_r10_ASR_r9[] = {
1244   0x5a, 0x19, 0x43, 0x00 // sub eq r1 r3 r10 ASR r9
1245 };
1246 const byte kInstruction_sub_al_r1_r6_r6_LSL_r9[] = {
1247   0x16, 0x19, 0x46, 0xe0 // sub al r1 r6 r6 LSL r9
1248 };
1249 const byte kInstruction_sub_ne_r4_r14_r7_ROR_r12[] = {
1250   0x77, 0x4c, 0x4e, 0x10 // sub ne r4 r14 r7 ROR r12
1251 };
1252 const byte kInstruction_sub_vc_r2_r13_r1_ROR_r7[] = {
1253   0x71, 0x27, 0x4d, 0x70 // sub vc r2 r13 r1 ROR r7
1254 };
1255 const byte kInstruction_sub_cs_r13_r12_r8_LSR_r11[] = {
1256   0x38, 0xdb, 0x4c, 0x20 // sub cs r13 r12 r8 LSR r11
1257 };
1258 const byte kInstruction_sub_le_r10_r14_r12_LSL_r4[] = {
1259   0x1c, 0xa4, 0x4e, 0xd0 // sub le r10 r14 r12 LSL r4
1260 };
1261 const byte kInstruction_sub_cs_r14_r9_r4_ROR_r13[] = {
1262   0x74, 0xed, 0x49, 0x20 // sub cs r14 r9 r4 ROR r13
1263 };
1264 const byte kInstruction_sub_ge_r10_r12_r8_ASR_r14[] = {
1265   0x58, 0xae, 0x4c, 0xa0 // sub ge r10 r12 r8 ASR r14
1266 };
1267 const byte kInstruction_sub_cs_r14_r10_r3_LSL_r13[] = {
1268   0x13, 0xed, 0x4a, 0x20 // sub cs r14 r10 r3 LSL r13
1269 };
1270 const byte kInstruction_sub_lt_r4_r3_r10_LSR_r2[] = {
1271   0x3a, 0x42, 0x43, 0xb0 // sub lt r4 r3 r10 LSR r2
1272 };
1273 const byte kInstruction_sub_ls_r13_r12_r8_ASR_r14[] = {
1274   0x58, 0xde, 0x4c, 0x90 // sub ls r13 r12 r8 ASR r14
1275 };
1276 const byte kInstruction_sub_ge_r3_r2_r0_ASR_r8[] = {
1277   0x50, 0x38, 0x42, 0xa0 // sub ge r3 r2 r0 ASR r8
1278 };
1279 const byte kInstruction_sub_vs_r3_r7_r1_LSL_r0[] = {
1280   0x11, 0x30, 0x47, 0x60 // sub vs r3 r7 r1 LSL r0
1281 };
1282 const byte kInstruction_sub_lt_r5_r13_r7_LSR_r7[] = {
1283   0x37, 0x57, 0x4d, 0xb0 // sub lt r5 r13 r7 LSR r7
1284 };
1285 const byte kInstruction_sub_ls_r8_r4_r3_ROR_r14[] = {
1286   0x73, 0x8e, 0x44, 0x90 // sub ls r8 r4 r3 ROR r14
1287 };
1288 const byte kInstruction_sub_vc_r5_r4_r13_LSL_r12[] = {
1289   0x1d, 0x5c, 0x44, 0x70 // sub vc r5 r4 r13 LSL r12
1290 };
1291 const byte kInstruction_sub_pl_r6_r10_r11_LSR_r2[] = {
1292   0x3b, 0x62, 0x4a, 0x50 // sub pl r6 r10 r11 LSR r2
1293 };
1294 const byte kInstruction_sub_ne_r4_r0_r6_ASR_r10[] = {
1295   0x56, 0x4a, 0x40, 0x10 // sub ne r4 r0 r6 ASR r10
1296 };
1297 const byte kInstruction_sub_vc_r2_r6_r7_LSR_r4[] = {
1298   0x37, 0x24, 0x46, 0x70 // sub vc r2 r6 r7 LSR r4
1299 };
1300 const byte kInstruction_sub_pl_r4_r12_r1_ROR_r14[] = {
1301   0x71, 0x4e, 0x4c, 0x50 // sub pl r4 r12 r1 ROR r14
1302 };
1303 const byte kInstruction_sub_cs_r13_r1_r10_LSL_r12[] = {
1304   0x1a, 0xdc, 0x41, 0x20 // sub cs r13 r1 r10 LSL r12
1305 };
1306 const byte kInstruction_sub_al_r7_r12_r7_LSL_r10[] = {
1307   0x17, 0x7a, 0x4c, 0xe0 // sub al r7 r12 r7 LSL r10
1308 };
1309 const byte kInstruction_sub_ge_r1_r9_r13_LSR_r8[] = {
1310   0x3d, 0x18, 0x49, 0xa0 // sub ge r1 r9 r13 LSR r8
1311 };
1312 const byte kInstruction_sub_eq_r12_r5_r11_ASR_r2[] = {
1313   0x5b, 0xc2, 0x45, 0x00 // sub eq r12 r5 r11 ASR r2
1314 };
1315 const byte kInstruction_sub_ls_r7_r9_r3_ASR_r14[] = {
1316   0x53, 0x7e, 0x49, 0x90 // sub ls r7 r9 r3 ASR r14
1317 };
1318 const byte kInstruction_sub_pl_r5_r10_r3_LSL_r12[] = {
1319   0x13, 0x5c, 0x4a, 0x50 // sub pl r5 r10 r3 LSL r12
1320 };
1321 const byte kInstruction_sub_vs_r5_r14_r11_ASR_r13[] = {
1322   0x5b, 0x5d, 0x4e, 0x60 // sub vs r5 r14 r11 ASR r13
1323 };
1324 const byte kInstruction_sub_al_r9_r2_r8_LSR_r10[] = {
1325   0x38, 0x9a, 0x42, 0xe0 // sub al r9 r2 r8 LSR r10
1326 };
1327 const byte kInstruction_sub_cc_r11_r12_r6_ROR_r11[] = {
1328   0x76, 0xbb, 0x4c, 0x30 // sub cc r11 r12 r6 ROR r11
1329 };
1330 const byte kInstruction_sub_ge_r10_r3_r1_LSR_r5[] = {
1331   0x31, 0xa5, 0x43, 0xa0 // sub ge r10 r3 r1 LSR r5
1332 };
1333 const byte kInstruction_sub_lt_r13_r4_r7_ROR_r0[] = {
1334   0x77, 0xd0, 0x44, 0xb0 // sub lt r13 r4 r7 ROR r0
1335 };
1336 const byte kInstruction_sub_ne_r2_r12_r12_LSR_r0[] = {
1337   0x3c, 0x20, 0x4c, 0x10 // sub ne r2 r12 r12 LSR r0
1338 };
1339 const byte kInstruction_sub_gt_r2_r10_r14_ASR_r10[] = {
1340   0x5e, 0x2a, 0x4a, 0xc0 // sub gt r2 r10 r14 ASR r10
1341 };
1342 const byte kInstruction_sub_cc_r5_r6_r10_ASR_r11[] = {
1343   0x5a, 0x5b, 0x46, 0x30 // sub cc r5 r6 r10 ASR r11
1344 };
1345 const byte kInstruction_sub_hi_r8_r13_r1_ROR_r9[] = {
1346   0x71, 0x89, 0x4d, 0x80 // sub hi r8 r13 r1 ROR r9
1347 };
1348 const byte kInstruction_sub_cc_r3_r1_r14_LSR_r3[] = {
1349   0x3e, 0x33, 0x41, 0x30 // sub cc r3 r1 r14 LSR r3
1350 };
1351 const byte kInstruction_sub_lt_r11_r9_r8_ASR_r13[] = {
1352   0x58, 0xbd, 0x49, 0xb0 // sub lt r11 r9 r8 ASR r13
1353 };
1354 const byte kInstruction_sub_mi_r0_r3_r13_ASR_r5[] = {
1355   0x5d, 0x05, 0x43, 0x40 // sub mi r0 r3 r13 ASR r5
1356 };
1357 const byte kInstruction_sub_vc_r7_r6_r10_ASR_r6[] = {
1358   0x5a, 0x76, 0x46, 0x70 // sub vc r7 r6 r10 ASR r6
1359 };
1360 const byte kInstruction_sub_mi_r2_r6_r4_LSL_r9[] = {
1361   0x14, 0x29, 0x46, 0x40 // sub mi r2 r6 r4 LSL r9
1362 };
1363 const byte kInstruction_sub_ne_r12_r9_r4_ROR_r6[] = {
1364   0x74, 0xc6, 0x49, 0x10 // sub ne r12 r9 r4 ROR r6
1365 };
1366 const byte kInstruction_sub_hi_r4_r3_r0_ROR_r4[] = {
1367   0x70, 0x44, 0x43, 0x80 // sub hi r4 r3 r0 ROR r4
1368 };
1369 const byte kInstruction_sub_gt_r9_r2_r11_LSL_r13[] = {
1370   0x1b, 0x9d, 0x42, 0xc0 // sub gt r9 r2 r11 LSL r13
1371 };
1372 const byte kInstruction_sub_eq_r14_r4_r3_LSL_r10[] = {
1373   0x13, 0xea, 0x44, 0x00 // sub eq r14 r4 r3 LSL r10
1374 };
1375 const byte kInstruction_sub_le_r8_r2_r12_LSL_r10[] = {
1376   0x1c, 0x8a, 0x42, 0xd0 // sub le r8 r2 r12 LSL r10
1377 };
1378 const byte kInstruction_sub_ls_r8_r0_r1_ASR_r8[] = {
1379   0x51, 0x88, 0x40, 0x90 // sub ls r8 r0 r1 ASR r8
1380 };
1381 const byte kInstruction_sub_cc_r13_r9_r7_LSR_r3[] = {
1382   0x37, 0xd3, 0x49, 0x30 // sub cc r13 r9 r7 LSR r3
1383 };
1384 const byte kInstruction_sub_gt_r6_r0_r7_ROR_r9[] = {
1385   0x77, 0x69, 0x40, 0xc0 // sub gt r6 r0 r7 ROR r9
1386 };
1387 const byte kInstruction_sub_hi_r14_r12_r6_LSR_r12[] = {
1388   0x36, 0xec, 0x4c, 0x80 // sub hi r14 r12 r6 LSR r12
1389 };
1390 const byte kInstruction_sub_cs_r3_r7_r10_LSR_r8[] = {
1391   0x3a, 0x38, 0x47, 0x20 // sub cs r3 r7 r10 LSR r8
1392 };
1393 const byte kInstruction_sub_le_r7_r7_r7_LSL_r11[] = {
1394   0x17, 0x7b, 0x47, 0xd0 // sub le r7 r7 r7 LSL r11
1395 };
1396 const byte kInstruction_sub_le_r11_r11_r14_ASR_r3[] = {
1397   0x5e, 0xb3, 0x4b, 0xd0 // sub le r11 r11 r14 ASR r3
1398 };
1399 const byte kInstruction_sub_vc_r13_r5_r6_LSL_r13[] = {
1400   0x16, 0xdd, 0x45, 0x70 // sub vc r13 r5 r6 LSL r13
1401 };
1402 const byte kInstruction_sub_cc_r12_r3_r12_LSL_r8[] = {
1403   0x1c, 0xc8, 0x43, 0x30 // sub cc r12 r3 r12 LSL r8
1404 };
1405 const byte kInstruction_sub_gt_r4_r14_r12_ASR_r11[] = {
1406   0x5c, 0x4b, 0x4e, 0xc0 // sub gt r4 r14 r12 ASR r11
1407 };
1408 const byte kInstruction_sub_cs_r9_r6_r7_LSL_r10[] = {
1409   0x17, 0x9a, 0x46, 0x20 // sub cs r9 r6 r7 LSL r10
1410 };
1411 const byte kInstruction_sub_ge_r9_r5_r3_ROR_r5[] = {
1412   0x73, 0x95, 0x45, 0xa0 // sub ge r9 r5 r3 ROR r5
1413 };
1414 const byte kInstruction_sub_vc_r4_r5_r14_LSR_r4[] = {
1415   0x3e, 0x44, 0x45, 0x70 // sub vc r4 r5 r14 LSR r4
1416 };
1417 const byte kInstruction_sub_ne_r13_r12_r2_ASR_r14[] = {
1418   0x52, 0xde, 0x4c, 0x10 // sub ne r13 r12 r2 ASR r14
1419 };
1420 const byte kInstruction_sub_gt_r2_r9_r11_LSR_r13[] = {
1421   0x3b, 0x2d, 0x49, 0xc0 // sub gt r2 r9 r11 LSR r13
1422 };
1423 const byte kInstruction_sub_mi_r10_r11_r8_LSR_r1[] = {
1424   0x38, 0xa1, 0x4b, 0x40 // sub mi r10 r11 r8 LSR r1
1425 };
1426 const byte kInstruction_sub_hi_r6_r8_r1_ASR_r6[] = {
1427   0x51, 0x66, 0x48, 0x80 // sub hi r6 r8 r1 ASR r6
1428 };
1429 const byte kInstruction_sub_eq_r10_r12_r5_ROR_r11[] = {
1430   0x75, 0xab, 0x4c, 0x00 // sub eq r10 r12 r5 ROR r11
1431 };
1432 const byte kInstruction_sub_mi_r9_r6_r4_LSL_r1[] = {
1433   0x14, 0x91, 0x46, 0x40 // sub mi r9 r6 r4 LSL r1
1434 };
1435 const byte kInstruction_sub_vc_r14_r6_r0_ROR_r7[] = {
1436   0x70, 0xe7, 0x46, 0x70 // sub vc r14 r6 r0 ROR r7
1437 };
1438 const byte kInstruction_sub_mi_r10_r3_r12_LSL_r2[] = {
1439   0x1c, 0xa2, 0x43, 0x40 // sub mi r10 r3 r12 LSL r2
1440 };
1441 const byte kInstruction_sub_pl_r9_r6_r9_LSR_r14[] = {
1442   0x39, 0x9e, 0x46, 0x50 // sub pl r9 r6 r9 LSR r14
1443 };
1444 const byte kInstruction_sub_al_r10_r5_r10_ROR_r1[] = {
1445   0x7a, 0xa1, 0x45, 0xe0 // sub al r10 r5 r10 ROR r1
1446 };
1447 const byte kInstruction_sub_ne_r9_r6_r2_ASR_r3[] = {
1448   0x52, 0x93, 0x46, 0x10 // sub ne r9 r6 r2 ASR r3
1449 };
1450 const byte kInstruction_sub_hi_r4_r9_r4_LSL_r6[] = {
1451   0x14, 0x46, 0x49, 0x80 // sub hi r4 r9 r4 LSL r6
1452 };
1453 const byte kInstruction_sub_vs_r1_r9_r7_ASR_r7[] = {
1454   0x57, 0x17, 0x49, 0x60 // sub vs r1 r9 r7 ASR r7
1455 };
1456 const byte kInstruction_sub_ne_r10_r13_r9_ASR_r14[] = {
1457   0x59, 0xae, 0x4d, 0x10 // sub ne r10 r13 r9 ASR r14
1458 };
1459 const byte kInstruction_sub_gt_r11_r13_r12_ASR_r12[] = {
1460   0x5c, 0xbc, 0x4d, 0xc0 // sub gt r11 r13 r12 ASR r12
1461 };
1462 const byte kInstruction_sub_lt_r3_r5_r0_LSR_r10[] = {
1463   0x30, 0x3a, 0x45, 0xb0 // sub lt r3 r5 r0 LSR r10
1464 };
1465 const byte kInstruction_sub_gt_r4_r8_r13_ROR_r7[] = {
1466   0x7d, 0x47, 0x48, 0xc0 // sub gt r4 r8 r13 ROR r7
1467 };
1468 const byte kInstruction_sub_ls_r14_r14_r0_ASR_r3[] = {
1469   0x50, 0xe3, 0x4e, 0x90 // sub ls r14 r14 r0 ASR r3
1470 };
1471 const byte kInstruction_sub_vc_r2_r7_r9_ASR_r5[] = {
1472   0x59, 0x25, 0x47, 0x70 // sub vc r2 r7 r9 ASR r5
1473 };
1474 const byte kInstruction_sub_mi_r9_r3_r10_LSR_r10[] = {
1475   0x3a, 0x9a, 0x43, 0x40 // sub mi r9 r3 r10 LSR r10
1476 };
1477 const byte kInstruction_sub_gt_r11_r10_r3_ASR_r11[] = {
1478   0x53, 0xbb, 0x4a, 0xc0 // sub gt r11 r10 r3 ASR r11
1479 };
1480 const byte kInstruction_sub_cc_r3_r14_r2_ROR_r12[] = {
1481   0x72, 0x3c, 0x4e, 0x30 // sub cc r3 r14 r2 ROR r12
1482 };
1483 const byte kInstruction_sub_ls_r3_r5_r14_ROR_r12[] = {
1484   0x7e, 0x3c, 0x45, 0x90 // sub ls r3 r5 r14 ROR r12
1485 };
1486 const byte kInstruction_sub_al_r6_r0_r11_ASR_r0[] = {
1487   0x5b, 0x60, 0x40, 0xe0 // sub al r6 r0 r11 ASR r0
1488 };
1489 const byte kInstruction_sub_al_r14_r12_r13_LSL_r8[] = {
1490   0x1d, 0xe8, 0x4c, 0xe0 // sub al r14 r12 r13 LSL r8
1491 };
1492 const byte kInstruction_sub_cs_r12_r9_r14_ROR_r4[] = {
1493   0x7e, 0xc4, 0x49, 0x20 // sub cs r12 r9 r14 ROR r4
1494 };
1495 const byte kInstruction_sub_vs_r4_r9_r6_LSL_r10[] = {
1496   0x16, 0x4a, 0x49, 0x60 // sub vs r4 r9 r6 LSL r10
1497 };
1498 const byte kInstruction_sub_eq_r6_r1_r4_ASR_r6[] = {
1499   0x54, 0x66, 0x41, 0x00 // sub eq r6 r1 r4 ASR r6
1500 };
1501 const byte kInstruction_sub_ge_r6_r11_r2_LSR_r10[] = {
1502   0x32, 0x6a, 0x4b, 0xa0 // sub ge r6 r11 r2 LSR r10
1503 };
1504 const byte kInstruction_sub_cc_r10_r14_r4_LSR_r0[] = {
1505   0x34, 0xa0, 0x4e, 0x30 // sub cc r10 r14 r4 LSR r0
1506 };
1507 const byte kInstruction_sub_ge_r0_r12_r1_ROR_r5[] = {
1508   0x71, 0x05, 0x4c, 0xa0 // sub ge r0 r12 r1 ROR r5
1509 };
1510 const byte kInstruction_sub_ls_r1_r13_r10_ASR_r5[] = {
1511   0x5a, 0x15, 0x4d, 0x90 // sub ls r1 r13 r10 ASR r5
1512 };
1513 const byte kInstruction_sub_cc_r9_r8_r5_ASR_r5[] = {
1514   0x55, 0x95, 0x48, 0x30 // sub cc r9 r8 r5 ASR r5
1515 };
1516 const byte kInstruction_sub_ls_r6_r5_r1_LSL_r11[] = {
1517   0x11, 0x6b, 0x45, 0x90 // sub ls r6 r5 r1 LSL r11
1518 };
1519 const byte kInstruction_sub_ne_r2_r12_r1_ROR_r10[] = {
1520   0x71, 0x2a, 0x4c, 0x10 // sub ne r2 r12 r1 ROR r10
1521 };
1522 const byte kInstruction_sub_cc_r2_r9_r9_LSR_r1[] = {
1523   0x39, 0x21, 0x49, 0x30 // sub cc r2 r9 r9 LSR r1
1524 };
1525 const byte kInstruction_sub_ne_r1_r8_r1_ASR_r14[] = {
1526   0x51, 0x1e, 0x48, 0x10 // sub ne r1 r8 r1 ASR r14
1527 };
1528 const byte kInstruction_sub_lt_r9_r2_r1_LSR_r10[] = {
1529   0x31, 0x9a, 0x42, 0xb0 // sub lt r9 r2 r1 LSR r10
1530 };
1531 const byte kInstruction_sub_cc_r14_r11_r9_ROR_r6[] = {
1532   0x79, 0xe6, 0x4b, 0x30 // sub cc r14 r11 r9 ROR r6
1533 };
1534 const byte kInstruction_sub_eq_r3_r12_r13_ASR_r0[] = {
1535   0x5d, 0x30, 0x4c, 0x00 // sub eq r3 r12 r13 ASR r0
1536 };
1537 const byte kInstruction_sub_le_r6_r6_r6_ASR_r2[] = {
1538   0x56, 0x62, 0x46, 0xd0 // sub le r6 r6 r6 ASR r2
1539 };
1540 const byte kInstruction_sub_mi_r11_r14_r4_ASR_r1[] = {
1541   0x54, 0xb1, 0x4e, 0x40 // sub mi r11 r14 r4 ASR r1
1542 };
1543 const byte kInstruction_sub_ls_r5_r9_r10_LSL_r9[] = {
1544   0x1a, 0x59, 0x49, 0x90 // sub ls r5 r9 r10 LSL r9
1545 };
1546 const byte kInstruction_sub_vc_r12_r9_r3_LSR_r10[] = {
1547   0x33, 0xca, 0x49, 0x70 // sub vc r12 r9 r3 LSR r10
1548 };
1549 const byte kInstruction_sub_lt_r12_r0_r4_ASR_r0[] = {
1550   0x54, 0xc0, 0x40, 0xb0 // sub lt r12 r0 r4 ASR r0
1551 };
1552 const byte kInstruction_sub_mi_r0_r10_r6_ROR_r9[] = {
1553   0x76, 0x09, 0x4a, 0x40 // sub mi r0 r10 r6 ROR r9
1554 };
1555 const byte kInstruction_sub_hi_r7_r10_r1_LSL_r7[] = {
1556   0x11, 0x77, 0x4a, 0x80 // sub hi r7 r10 r1 LSL r7
1557 };
1558 const byte kInstruction_sub_ls_r2_r0_r14_ROR_r5[] = {
1559   0x7e, 0x25, 0x40, 0x90 // sub ls r2 r0 r14 ROR r5
1560 };
1561 const byte kInstruction_sub_cs_r12_r14_r12_LSR_r10[] = {
1562   0x3c, 0xca, 0x4e, 0x20 // sub cs r12 r14 r12 LSR r10
1563 };
1564 const byte kInstruction_sub_le_r9_r0_r6_ROR_r2[] = {
1565   0x76, 0x92, 0x40, 0xd0 // sub le r9 r0 r6 ROR r2
1566 };
1567 const byte kInstruction_sub_cc_r3_r10_r4_LSR_r12[] = {
1568   0x34, 0x3c, 0x4a, 0x30 // sub cc r3 r10 r4 LSR r12
1569 };
1570 const byte kInstruction_sub_mi_r4_r5_r2_ASR_r14[] = {
1571   0x52, 0x4e, 0x45, 0x40 // sub mi r4 r5 r2 ASR r14
1572 };
1573 const byte kInstruction_sub_vc_r12_r8_r10_ROR_r14[] = {
1574   0x7a, 0xce, 0x48, 0x70 // sub vc r12 r8 r10 ROR r14
1575 };
1576 const byte kInstruction_sub_al_r5_r14_r4_ASR_r10[] = {
1577   0x54, 0x5a, 0x4e, 0xe0 // sub al r5 r14 r4 ASR r10
1578 };
1579 const byte kInstruction_sub_ls_r13_r8_r3_ASR_r1[] = {
1580   0x53, 0xd1, 0x48, 0x90 // sub ls r13 r8 r3 ASR r1
1581 };
1582 const byte kInstruction_sub_le_r10_r1_r2_LSR_r4[] = {
1583   0x32, 0xa4, 0x41, 0xd0 // sub le r10 r1 r2 LSR r4
1584 };
1585 const byte kInstruction_sub_ne_r0_r2_r10_ROR_r7[] = {
1586   0x7a, 0x07, 0x42, 0x10 // sub ne r0 r2 r10 ROR r7
1587 };
1588 const byte kInstruction_sub_vs_r11_r13_r11_LSR_r12[] = {
1589   0x3b, 0xbc, 0x4d, 0x60 // sub vs r11 r13 r11 LSR r12
1590 };
1591 const byte kInstruction_sub_vs_r10_r10_r8_ROR_r8[] = {
1592   0x78, 0xa8, 0x4a, 0x60 // sub vs r10 r10 r8 ROR r8
1593 };
1594 const byte kInstruction_sub_ne_r7_r2_r9_LSL_r11[] = {
1595   0x19, 0x7b, 0x42, 0x10 // sub ne r7 r2 r9 LSL r11
1596 };
1597 const byte kInstruction_sub_mi_r5_r12_r11_ASR_r5[] = {
1598   0x5b, 0x55, 0x4c, 0x40 // sub mi r5 r12 r11 ASR r5
1599 };
1600 const byte kInstruction_sub_le_r1_r10_r5_ROR_r5[] = {
1601   0x75, 0x15, 0x4a, 0xd0 // sub le r1 r10 r5 ROR r5
1602 };
1603 const byte kInstruction_sub_cc_r3_r14_r3_ASR_r6[] = {
1604   0x53, 0x36, 0x4e, 0x30 // sub cc r3 r14 r3 ASR r6
1605 };
1606 const byte kInstruction_sub_vc_r4_r4_r0_ROR_r2[] = {
1607   0x70, 0x42, 0x44, 0x70 // sub vc r4 r4 r0 ROR r2
1608 };
1609 const byte kInstruction_sub_le_r3_r4_r12_ROR_r14[] = {
1610   0x7c, 0x3e, 0x44, 0xd0 // sub le r3 r4 r12 ROR r14
1611 };
1612 const byte kInstruction_sub_al_r3_r7_r14_LSL_r11[] = {
1613   0x1e, 0x3b, 0x47, 0xe0 // sub al r3 r7 r14 LSL r11
1614 };
1615 const byte kInstruction_sub_vc_r8_r11_r0_LSL_r11[] = {
1616   0x10, 0x8b, 0x4b, 0x70 // sub vc r8 r11 r0 LSL r11
1617 };
1618 const byte kInstruction_sub_vs_r12_r9_r14_LSR_r2[] = {
1619   0x3e, 0xc2, 0x49, 0x60 // sub vs r12 r9 r14 LSR r2
1620 };
1621 const byte kInstruction_sub_hi_r3_r5_r5_ROR_r6[] = {
1622   0x75, 0x36, 0x45, 0x80 // sub hi r3 r5 r5 ROR r6
1623 };
1624 const byte kInstruction_sub_cs_r9_r3_r13_ASR_r7[] = {
1625   0x5d, 0x97, 0x43, 0x20 // sub cs r9 r3 r13 ASR r7
1626 };
1627 const byte kInstruction_sub_eq_r14_r3_r6_LSR_r5[] = {
1628   0x36, 0xe5, 0x43, 0x00 // sub eq r14 r3 r6 LSR r5
1629 };
1630 const byte kInstruction_sub_lt_r8_r3_r4_LSR_r13[] = {
1631   0x34, 0x8d, 0x43, 0xb0 // sub lt r8 r3 r4 LSR r13
1632 };
1633 const byte kInstruction_sub_vc_r7_r4_r12_ROR_r6[] = {
1634   0x7c, 0x76, 0x44, 0x70 // sub vc r7 r4 r12 ROR r6
1635 };
1636 const byte kInstruction_sub_vs_r5_r3_r3_ASR_r1[] = {
1637   0x53, 0x51, 0x43, 0x60 // sub vs r5 r3 r3 ASR r1
1638 };
1639 const byte kInstruction_sub_le_r5_r6_r1_ROR_r7[] = {
1640   0x71, 0x57, 0x46, 0xd0 // sub le r5 r6 r1 ROR r7
1641 };
1642 const byte kInstruction_sub_ge_r11_r5_r11_LSL_r12[] = {
1643   0x1b, 0xbc, 0x45, 0xa0 // sub ge r11 r5 r11 LSL r12
1644 };
1645 const byte kInstruction_sub_lt_r0_r3_r7_ASR_r14[] = {
1646   0x57, 0x0e, 0x43, 0xb0 // sub lt r0 r3 r7 ASR r14
1647 };
1648 const byte kInstruction_sub_cs_r9_r2_r10_LSL_r1[] = {
1649   0x1a, 0x91, 0x42, 0x20 // sub cs r9 r2 r10 LSL r1
1650 };
1651 const byte kInstruction_sub_cs_r6_r8_r6_ASR_r1[] = {
1652   0x56, 0x61, 0x48, 0x20 // sub cs r6 r8 r6 ASR r1
1653 };
1654 const byte kInstruction_sub_lt_r0_r11_r14_ASR_r5[] = {
1655   0x5e, 0x05, 0x4b, 0xb0 // sub lt r0 r11 r14 ASR r5
1656 };
1657 const byte kInstruction_sub_ge_r11_r11_r2_ASR_r3[] = {
1658   0x52, 0xb3, 0x4b, 0xa0 // sub ge r11 r11 r2 ASR r3
1659 };
1660 const byte kInstruction_sub_lt_r0_r0_r14_LSL_r2[] = {
1661   0x1e, 0x02, 0x40, 0xb0 // sub lt r0 r0 r14 LSL r2
1662 };
1663 const byte kInstruction_sub_cs_r8_r9_r11_ROR_r8[] = {
1664   0x7b, 0x88, 0x49, 0x20 // sub cs r8 r9 r11 ROR r8
1665 };
1666 const byte kInstruction_sub_pl_r9_r5_r12_ASR_r14[] = {
1667   0x5c, 0x9e, 0x45, 0x50 // sub pl r9 r5 r12 ASR r14
1668 };
1669 const byte kInstruction_sub_eq_r13_r11_r1_LSR_r1[] = {
1670   0x31, 0xd1, 0x4b, 0x00 // sub eq r13 r11 r1 LSR r1
1671 };
1672 const byte kInstruction_sub_ne_r1_r0_r13_ROR_r0[] = {
1673   0x7d, 0x10, 0x40, 0x10 // sub ne r1 r0 r13 ROR r0
1674 };
1675 const byte kInstruction_sub_hi_r6_r5_r9_LSR_r10[] = {
1676   0x39, 0x6a, 0x45, 0x80 // sub hi r6 r5 r9 LSR r10
1677 };
1678 const byte kInstruction_sub_lt_r4_r7_r7_ASR_r9[] = {
1679   0x57, 0x49, 0x47, 0xb0 // sub lt r4 r7 r7 ASR r9
1680 };
1681 const byte kInstruction_sub_ls_r13_r13_r5_LSR_r1[] = {
1682   0x35, 0xd1, 0x4d, 0x90 // sub ls r13 r13 r5 LSR r1
1683 };
1684 const byte kInstruction_sub_cs_r12_r1_r6_LSR_r14[] = {
1685   0x36, 0xce, 0x41, 0x20 // sub cs r12 r1 r6 LSR r14
1686 };
1687 const byte kInstruction_sub_hi_r11_r0_r5_LSR_r3[] = {
1688   0x35, 0xb3, 0x40, 0x80 // sub hi r11 r0 r5 LSR r3
1689 };
1690 const byte kInstruction_sub_ne_r5_r2_r14_LSR_r1[] = {
1691   0x3e, 0x51, 0x42, 0x10 // sub ne r5 r2 r14 LSR r1
1692 };
1693 const byte kInstruction_sub_le_r6_r12_r9_LSR_r5[] = {
1694   0x39, 0x65, 0x4c, 0xd0 // sub le r6 r12 r9 LSR r5
1695 };
1696 const byte kInstruction_sub_cs_r1_r11_r1_LSL_r2[] = {
1697   0x11, 0x12, 0x4b, 0x20 // sub cs r1 r11 r1 LSL r2
1698 };
1699 const byte kInstruction_sub_al_r14_r10_r8_ASR_r4[] = {
1700   0x58, 0xe4, 0x4a, 0xe0 // sub al r14 r10 r8 ASR r4
1701 };
1702 const byte kInstruction_sub_al_r11_r10_r8_LSL_r6[] = {
1703   0x18, 0xb6, 0x4a, 0xe0 // sub al r11 r10 r8 LSL r6
1704 };
1705 const byte kInstruction_sub_vs_r1_r2_r1_LSL_r11[] = {
1706   0x11, 0x1b, 0x42, 0x60 // sub vs r1 r2 r1 LSL r11
1707 };
1708 const byte kInstruction_sub_cs_r10_r14_r14_LSL_r0[] = {
1709   0x1e, 0xa0, 0x4e, 0x20 // sub cs r10 r14 r14 LSL r0
1710 };
1711 const byte kInstruction_sub_pl_r0_r1_r14_ROR_r10[] = {
1712   0x7e, 0x0a, 0x41, 0x50 // sub pl r0 r1 r14 ROR r10
1713 };
1714 const byte kInstruction_sub_pl_r3_r7_r5_LSR_r1[] = {
1715   0x35, 0x31, 0x47, 0x50 // sub pl r3 r7 r5 LSR r1
1716 };
1717 const byte kInstruction_sub_gt_r2_r14_r10_LSL_r6[] = {
1718   0x1a, 0x26, 0x4e, 0xc0 // sub gt r2 r14 r10 LSL r6
1719 };
1720 const byte kInstruction_sub_le_r7_r7_r8_ROR_r0[] = {
1721   0x78, 0x70, 0x47, 0xd0 // sub le r7 r7 r8 ROR r0
1722 };
1723 const byte kInstruction_sub_cs_r7_r9_r8_LSL_r14[] = {
1724   0x18, 0x7e, 0x49, 0x20 // sub cs r7 r9 r8 LSL r14
1725 };
1726 const byte kInstruction_sub_cs_r11_r4_r3_LSR_r10[] = {
1727   0x33, 0xba, 0x44, 0x20 // sub cs r11 r4 r3 LSR r10
1728 };
1729 const byte kInstruction_sub_cc_r9_r1_r12_ROR_r4[] = {
1730   0x7c, 0x94, 0x41, 0x30 // sub cc r9 r1 r12 ROR r4
1731 };
1732 const byte kInstruction_sub_hi_r10_r0_r10_LSL_r8[] = {
1733   0x1a, 0xa8, 0x40, 0x80 // sub hi r10 r0 r10 LSL r8
1734 };
1735 const byte kInstruction_sub_eq_r14_r1_r0_LSL_r11[] = {
1736   0x10, 0xeb, 0x41, 0x00 // sub eq r14 r1 r0 LSL r11
1737 };
1738 const byte kInstruction_sub_mi_r9_r11_r5_ROR_r5[] = {
1739   0x75, 0x95, 0x4b, 0x40 // sub mi r9 r11 r5 ROR r5
1740 };
1741 const byte kInstruction_sub_le_r5_r9_r2_LSL_r1[] = {
1742   0x12, 0x51, 0x49, 0xd0 // sub le r5 r9 r2 LSL r1
1743 };
1744 const byte kInstruction_sub_pl_r7_r7_r8_ASR_r13[] = {
1745   0x58, 0x7d, 0x47, 0x50 // sub pl r7 r7 r8 ASR r13
1746 };
1747 const byte kInstruction_sub_gt_r14_r13_r10_ASR_r11[] = {
1748   0x5a, 0xeb, 0x4d, 0xc0 // sub gt r14 r13 r10 ASR r11
1749 };
1750 const byte kInstruction_sub_cs_r4_r6_r5_LSR_r7[] = {
1751   0x35, 0x47, 0x46, 0x20 // sub cs r4 r6 r5 LSR r7
1752 };
1753 const byte kInstruction_sub_lt_r2_r7_r7_LSL_r6[] = {
1754   0x17, 0x26, 0x47, 0xb0 // sub lt r2 r7 r7 LSL r6
1755 };
1756 const byte kInstruction_sub_al_r4_r5_r2_ROR_r5[] = {
1757   0x72, 0x45, 0x45, 0xe0 // sub al r4 r5 r2 ROR r5
1758 };
1759 const byte kInstruction_sub_cc_r6_r2_r9_ROR_r7[] = {
1760   0x79, 0x67, 0x42, 0x30 // sub cc r6 r2 r9 ROR r7
1761 };
1762 const byte kInstruction_sub_pl_r4_r0_r0_LSR_r11[] = {
1763   0x30, 0x4b, 0x40, 0x50 // sub pl r4 r0 r0 LSR r11
1764 };
1765 const byte kInstruction_sub_pl_r6_r10_r12_LSL_r11[] = {
1766   0x1c, 0x6b, 0x4a, 0x50 // sub pl r6 r10 r12 LSL r11
1767 };
1768 const byte kInstruction_sub_al_r0_r14_r1_LSR_r6[] = {
1769   0x31, 0x06, 0x4e, 0xe0 // sub al r0 r14 r1 LSR r6
1770 };
1771 const byte kInstruction_sub_cs_r7_r9_r13_LSR_r1[] = {
1772   0x3d, 0x71, 0x49, 0x20 // sub cs r7 r9 r13 LSR r1
1773 };
1774 const byte kInstruction_sub_al_r4_r2_r10_ROR_r3[] = {
1775   0x7a, 0x43, 0x42, 0xe0 // sub al r4 r2 r10 ROR r3
1776 };
1777 const byte kInstruction_sub_gt_r12_r4_r14_ROR_r7[] = {
1778   0x7e, 0xc7, 0x44, 0xc0 // sub gt r12 r4 r14 ROR r7
1779 };
1780 const byte kInstruction_sub_cs_r11_r0_r14_ASR_r7[] = {
1781   0x5e, 0xb7, 0x40, 0x20 // sub cs r11 r0 r14 ASR r7
1782 };
1783 const byte kInstruction_sub_pl_r0_r2_r4_ASR_r14[] = {
1784   0x54, 0x0e, 0x42, 0x50 // sub pl r0 r2 r4 ASR r14
1785 };
1786 const byte kInstruction_sub_mi_r14_r4_r9_LSR_r5[] = {
1787   0x39, 0xe5, 0x44, 0x40 // sub mi r14 r4 r9 LSR r5
1788 };
1789 const byte kInstruction_sub_ge_r13_r0_r1_ROR_r5[] = {
1790   0x71, 0xd5, 0x40, 0xa0 // sub ge r13 r0 r1 ROR r5
1791 };
1792 const byte kInstruction_sub_eq_r12_r14_r0_LSL_r11[] = {
1793   0x10, 0xcb, 0x4e, 0x00 // sub eq r12 r14 r0 LSL r11
1794 };
1795 const byte kInstruction_sub_ge_r6_r4_r10_ROR_r13[] = {
1796   0x7a, 0x6d, 0x44, 0xa0 // sub ge r6 r4 r10 ROR r13
1797 };
1798 const byte kInstruction_sub_lt_r3_r7_r2_ASR_r5[] = {
1799   0x52, 0x35, 0x47, 0xb0 // sub lt r3 r7 r2 ASR r5
1800 };
1801 const byte kInstruction_sub_al_r9_r0_r12_ROR_r0[] = {
1802   0x7c, 0x90, 0x40, 0xe0 // sub al r9 r0 r12 ROR r0
1803 };
1804 const byte kInstruction_sub_le_r1_r9_r7_LSL_r12[] = {
1805   0x17, 0x1c, 0x49, 0xd0 // sub le r1 r9 r7 LSL r12
1806 };
1807 const byte kInstruction_sub_lt_r14_r7_r4_ASR_r7[] = {
1808   0x54, 0xe7, 0x47, 0xb0 // sub lt r14 r7 r4 ASR r7
1809 };
1810 const byte kInstruction_sub_ne_r4_r6_r9_LSR_r8[] = {
1811   0x39, 0x48, 0x46, 0x10 // sub ne r4 r6 r9 LSR r8
1812 };
1813 const byte kInstruction_sub_cc_r0_r5_r1_ASR_r6[] = {
1814   0x51, 0x06, 0x45, 0x30 // sub cc r0 r5 r1 ASR r6
1815 };
1816 const byte kInstruction_sub_cc_r2_r13_r2_ROR_r6[] = {
1817   0x72, 0x26, 0x4d, 0x30 // sub cc r2 r13 r2 ROR r6
1818 };
1819 const byte kInstruction_sub_ge_r10_r0_r9_ROR_r6[] = {
1820   0x79, 0xa6, 0x40, 0xa0 // sub ge r10 r0 r9 ROR r6
1821 };
1822 const byte kInstruction_sub_gt_r8_r1_r11_LSR_r0[] = {
1823   0x3b, 0x80, 0x41, 0xc0 // sub gt r8 r1 r11 LSR r0
1824 };
1825 const byte kInstruction_sub_al_r14_r0_r9_LSL_r0[] = {
1826   0x19, 0xe0, 0x40, 0xe0 // sub al r14 r0 r9 LSL r0
1827 };
1828 const byte kInstruction_sub_hi_r12_r3_r12_ROR_r9[] = {
1829   0x7c, 0xc9, 0x43, 0x80 // sub hi r12 r3 r12 ROR r9
1830 };
1831 const byte kInstruction_sub_eq_r4_r12_r3_LSL_r2[] = {
1832   0x13, 0x42, 0x4c, 0x00 // sub eq r4 r12 r3 LSL r2
1833 };
1834 const byte kInstruction_sub_ne_r5_r3_r4_LSL_r4[] = {
1835   0x14, 0x54, 0x43, 0x10 // sub ne r5 r3 r4 LSL r4
1836 };
1837 const byte kInstruction_sub_vc_r8_r6_r10_LSL_r11[] = {
1838   0x1a, 0x8b, 0x46, 0x70 // sub vc r8 r6 r10 LSL r11
1839 };
1840 const byte kInstruction_sub_lt_r0_r1_r4_ASR_r3[] = {
1841   0x54, 0x03, 0x41, 0xb0 // sub lt r0 r1 r4 ASR r3
1842 };
1843 const byte kInstruction_sub_le_r14_r4_r1_ROR_r7[] = {
1844   0x71, 0xe7, 0x44, 0xd0 // sub le r14 r4 r1 ROR r7
1845 };
1846 const byte kInstruction_sub_al_r12_r12_r5_LSL_r2[] = {
1847   0x15, 0xc2, 0x4c, 0xe0 // sub al r12 r12 r5 LSL r2
1848 };
1849 const byte kInstruction_sub_eq_r10_r3_r10_ROR_r13[] = {
1850   0x7a, 0xad, 0x43, 0x00 // sub eq r10 r3 r10 ROR r13
1851 };
1852 const byte kInstruction_sub_ne_r7_r10_r1_LSR_r14[] = {
1853   0x31, 0x7e, 0x4a, 0x10 // sub ne r7 r10 r1 LSR r14
1854 };
1855 const byte kInstruction_sub_lt_r10_r4_r10_LSR_r5[] = {
1856   0x3a, 0xa5, 0x44, 0xb0 // sub lt r10 r4 r10 LSR r5
1857 };
1858 const byte kInstruction_sub_pl_r0_r14_r0_LSL_r2[] = {
1859   0x10, 0x02, 0x4e, 0x50 // sub pl r0 r14 r0 LSL r2
1860 };
1861 const byte kInstruction_sub_gt_r7_r4_r11_LSL_r3[] = {
1862   0x1b, 0x73, 0x44, 0xc0 // sub gt r7 r4 r11 LSL r3
1863 };
1864 const byte kInstruction_sub_cs_r8_r2_r1_LSR_r8[] = {
1865   0x31, 0x88, 0x42, 0x20 // sub cs r8 r2 r1 LSR r8
1866 };
1867 const byte kInstruction_sub_pl_r9_r11_r4_ASR_r7[] = {
1868   0x54, 0x97, 0x4b, 0x50 // sub pl r9 r11 r4 ASR r7
1869 };
1870 const byte kInstruction_sub_cc_r9_r5_r12_ROR_r4[] = {
1871   0x7c, 0x94, 0x45, 0x30 // sub cc r9 r5 r12 ROR r4
1872 };
1873 const byte kInstruction_sub_vc_r0_r11_r3_LSR_r12[] = {
1874   0x33, 0x0c, 0x4b, 0x70 // sub vc r0 r11 r3 LSR r12
1875 };
1876 const byte kInstruction_sub_gt_r6_r2_r4_LSR_r4[] = {
1877   0x34, 0x64, 0x42, 0xc0 // sub gt r6 r2 r4 LSR r4
1878 };
1879 const byte kInstruction_sub_lt_r4_r2_r0_LSL_r12[] = {
1880   0x10, 0x4c, 0x42, 0xb0 // sub lt r4 r2 r0 LSL r12
1881 };
1882 const byte kInstruction_sub_le_r9_r4_r13_ROR_r5[] = {
1883   0x7d, 0x95, 0x44, 0xd0 // sub le r9 r4 r13 ROR r5
1884 };
1885 const byte kInstruction_sub_vs_r9_r3_r8_LSR_r8[] = {
1886   0x38, 0x98, 0x43, 0x60 // sub vs r9 r3 r8 LSR r8
1887 };
1888 const byte kInstruction_sub_ne_r3_r8_r14_ROR_r8[] = {
1889   0x7e, 0x38, 0x48, 0x10 // sub ne r3 r8 r14 ROR r8
1890 };
1891 const byte kInstruction_sub_vc_r12_r13_r4_LSR_r9[] = {
1892   0x34, 0xc9, 0x4d, 0x70 // sub vc r12 r13 r4 LSR r9
1893 };
1894 const byte kInstruction_sub_cc_r14_r0_r8_LSL_r1[] = {
1895   0x18, 0xe1, 0x40, 0x30 // sub cc r14 r0 r8 LSL r1
1896 };
1897 const byte kInstruction_sub_hi_r6_r3_r5_ASR_r9[] = {
1898   0x55, 0x69, 0x43, 0x80 // sub hi r6 r3 r5 ASR r9
1899 };
1900 const byte kInstruction_sub_ne_r14_r4_r3_LSL_r8[] = {
1901   0x13, 0xe8, 0x44, 0x10 // sub ne r14 r4 r3 LSL r8
1902 };
1903 const byte kInstruction_sub_ge_r1_r10_r13_LSR_r4[] = {
1904   0x3d, 0x14, 0x4a, 0xa0 // sub ge r1 r10 r13 LSR r4
1905 };
1906 const byte kInstruction_sub_vc_r12_r7_r6_ROR_r3[] = {
1907   0x76, 0xc3, 0x47, 0x70 // sub vc r12 r7 r6 ROR r3
1908 };
1909 const byte kInstruction_sub_gt_r0_r6_r7_ROR_r2[] = {
1910   0x77, 0x02, 0x46, 0xc0 // sub gt r0 r6 r7 ROR r2
1911 };
1912 const byte kInstruction_sub_al_r4_r6_r9_LSL_r0[] = {
1913   0x19, 0x40, 0x46, 0xe0 // sub al r4 r6 r9 LSL r0
1914 };
1915 const byte kInstruction_sub_ls_r1_r3_r11_LSR_r11[] = {
1916   0x3b, 0x1b, 0x43, 0x90 // sub ls r1 r3 r11 LSR r11
1917 };
1918 const byte kInstruction_sub_lt_r3_r11_r1_LSR_r14[] = {
1919   0x31, 0x3e, 0x4b, 0xb0 // sub lt r3 r11 r1 LSR r14
1920 };
1921 const byte kInstruction_sub_vc_r6_r13_r7_ROR_r11[] = {
1922   0x77, 0x6b, 0x4d, 0x70 // sub vc r6 r13 r7 ROR r11
1923 };
1924 const byte kInstruction_sub_vc_r5_r14_r13_ROR_r13[] = {
1925   0x7d, 0x5d, 0x4e, 0x70 // sub vc r5 r14 r13 ROR r13
1926 };
1927 const byte kInstruction_sub_vc_r1_r4_r11_LSL_r1[] = {
1928   0x1b, 0x11, 0x44, 0x70 // sub vc r1 r4 r11 LSL r1
1929 };
1930 const byte kInstruction_sub_ls_r7_r3_r5_LSR_r6[] = {
1931   0x35, 0x76, 0x43, 0x90 // sub ls r7 r3 r5 LSR r6
1932 };
1933 const byte kInstruction_sub_vc_r13_r8_r3_ASR_r4[] = {
1934   0x53, 0xd4, 0x48, 0x70 // sub vc r13 r8 r3 ASR r4
1935 };
1936 const byte kInstruction_sub_ls_r2_r3_r10_ROR_r11[] = {
1937   0x7a, 0x2b, 0x43, 0x90 // sub ls r2 r3 r10 ROR r11
1938 };
1939 const byte kInstruction_sub_ge_r6_r1_r12_ASR_r11[] = {
1940   0x5c, 0x6b, 0x41, 0xa0 // sub ge r6 r1 r12 ASR r11
1941 };
1942 const byte kInstruction_sub_lt_r3_r1_r1_ASR_r14[] = {
1943   0x51, 0x3e, 0x41, 0xb0 // sub lt r3 r1 r1 ASR r14
1944 };
1945 const byte kInstruction_sub_hi_r2_r7_r14_LSL_r12[] = {
1946   0x1e, 0x2c, 0x47, 0x80 // sub hi r2 r7 r14 LSL r12
1947 };
1948 const byte kInstruction_sub_ge_r13_r10_r10_LSL_r14[] = {
1949   0x1a, 0xde, 0x4a, 0xa0 // sub ge r13 r10 r10 LSL r14
1950 };
1951 const byte kInstruction_sub_le_r0_r1_r3_LSR_r3[] = {
1952   0x33, 0x03, 0x41, 0xd0 // sub le r0 r1 r3 LSR r3
1953 };
1954 const byte kInstruction_sub_vs_r10_r7_r7_LSR_r6[] = {
1955   0x37, 0xa6, 0x47, 0x60 // sub vs r10 r7 r7 LSR r6
1956 };
1957 const byte kInstruction_sub_al_r6_r3_r6_LSL_r7[] = {
1958   0x16, 0x67, 0x43, 0xe0 // sub al r6 r3 r6 LSL r7
1959 };
1960 const byte kInstruction_sub_ne_r3_r8_r14_ASR_r1[] = {
1961   0x5e, 0x31, 0x48, 0x10 // sub ne r3 r8 r14 ASR r1
1962 };
1963 const byte kInstruction_sub_cc_r4_r10_r4_LSR_r9[] = {
1964   0x34, 0x49, 0x4a, 0x30 // sub cc r4 r10 r4 LSR r9
1965 };
1966 const byte kInstruction_sub_cs_r4_r1_r5_LSR_r10[] = {
1967   0x35, 0x4a, 0x41, 0x20 // sub cs r4 r1 r5 LSR r10
1968 };
1969 const byte kInstruction_sub_eq_r7_r6_r1_LSL_r4[] = {
1970   0x11, 0x74, 0x46, 0x00 // sub eq r7 r6 r1 LSL r4
1971 };
1972 const byte kInstruction_sub_hi_r3_r7_r1_LSL_r5[] = {
1973   0x11, 0x35, 0x47, 0x80 // sub hi r3 r7 r1 LSL r5
1974 };
1975 const byte kInstruction_sub_al_r6_r11_r8_LSR_r12[] = {
1976   0x38, 0x6c, 0x4b, 0xe0 // sub al r6 r11 r8 LSR r12
1977 };
1978 const byte kInstruction_sub_ls_r2_r5_r0_LSR_r5[] = {
1979   0x30, 0x25, 0x45, 0x90 // sub ls r2 r5 r0 LSR r5
1980 };
1981 const byte kInstruction_sub_pl_r4_r5_r13_LSL_r9[] = {
1982   0x1d, 0x49, 0x45, 0x50 // sub pl r4 r5 r13 LSL r9
1983 };
1984 const byte kInstruction_sub_lt_r13_r12_r0_ASR_r8[] = {
1985   0x50, 0xd8, 0x4c, 0xb0 // sub lt r13 r12 r0 ASR r8
1986 };
1987 const byte kInstruction_sub_cc_r11_r5_r0_LSL_r12[] = {
1988   0x10, 0xbc, 0x45, 0x30 // sub cc r11 r5 r0 LSL r12
1989 };
1990 const byte kInstruction_sub_ne_r6_r2_r2_ROR_r0[] = {
1991   0x72, 0x60, 0x42, 0x10 // sub ne r6 r2 r2 ROR r0
1992 };
1993 const byte kInstruction_sub_ne_r9_r13_r12_ASR_r6[] = {
1994   0x5c, 0x96, 0x4d, 0x10 // sub ne r9 r13 r12 ASR r6
1995 };
1996 const byte kInstruction_sub_cs_r8_r6_r10_ROR_r10[] = {
1997   0x7a, 0x8a, 0x46, 0x20 // sub cs r8 r6 r10 ROR r10
1998 };
1999 const byte kInstruction_sub_vs_r10_r6_r1_LSL_r6[] = {
2000   0x11, 0xa6, 0x46, 0x60 // sub vs r10 r6 r1 LSL r6
2001 };
2002 const byte kInstruction_sub_vc_r12_r0_r4_ASR_r10[] = {
2003   0x54, 0xca, 0x40, 0x70 // sub vc r12 r0 r4 ASR r10
2004 };
2005 const byte kInstruction_sub_cs_r10_r2_r11_ROR_r8[] = {
2006   0x7b, 0xa8, 0x42, 0x20 // sub cs r10 r2 r11 ROR r8
2007 };
2008 const byte kInstruction_sub_ne_r0_r9_r14_ASR_r14[] = {
2009   0x5e, 0x0e, 0x49, 0x10 // sub ne r0 r9 r14 ASR r14
2010 };
2011 const byte kInstruction_sub_eq_r0_r10_r1_ASR_r8[] = {
2012   0x51, 0x08, 0x4a, 0x00 // sub eq r0 r10 r1 ASR r8
2013 };
2014 const byte kInstruction_sub_gt_r0_r11_r3_LSR_r0[] = {
2015   0x33, 0x00, 0x4b, 0xc0 // sub gt r0 r11 r3 LSR r0
2016 };
2017 const byte kInstruction_sub_al_r5_r11_r6_ROR_r14[] = {
2018   0x76, 0x5e, 0x4b, 0xe0 // sub al r5 r11 r6 ROR r14
2019 };
2020 const byte kInstruction_sub_ls_r2_r11_r11_ROR_r2[] = {
2021   0x7b, 0x22, 0x4b, 0x90 // sub ls r2 r11 r11 ROR r2
2022 };
2023 const byte kInstruction_sub_cs_r2_r11_r6_ROR_r11[] = {
2024   0x76, 0x2b, 0x4b, 0x20 // sub cs r2 r11 r6 ROR r11
2025 };
2026 const byte kInstruction_sub_cs_r4_r9_r11_ASR_r5[] = {
2027   0x5b, 0x45, 0x49, 0x20 // sub cs r4 r9 r11 ASR r5
2028 };
2029 const byte kInstruction_sub_ls_r5_r0_r2_ASR_r3[] = {
2030   0x52, 0x53, 0x40, 0x90 // sub ls r5 r0 r2 ASR r3
2031 };
2032 const byte kInstruction_sub_cc_r14_r1_r13_LSR_r2[] = {
2033   0x3d, 0xe2, 0x41, 0x30 // sub cc r14 r1 r13 LSR r2
2034 };
2035 const byte kInstruction_sub_lt_r4_r5_r6_ASR_r0[] = {
2036   0x56, 0x40, 0x45, 0xb0 // sub lt r4 r5 r6 ASR r0
2037 };
2038 const byte kInstruction_sub_vc_r0_r12_r6_ASR_r6[] = {
2039   0x56, 0x06, 0x4c, 0x70 // sub vc r0 r12 r6 ASR r6
2040 };
2041 const byte kInstruction_sub_pl_r3_r10_r4_LSR_r8[] = {
2042   0x34, 0x38, 0x4a, 0x50 // sub pl r3 r10 r4 LSR r8
2043 };
2044 const byte kInstruction_sub_cc_r10_r5_r10_ASR_r10[] = {
2045   0x5a, 0xaa, 0x45, 0x30 // sub cc r10 r5 r10 ASR r10
2046 };
2047 const byte kInstruction_sub_pl_r2_r14_r1_ASR_r10[] = {
2048   0x51, 0x2a, 0x4e, 0x50 // sub pl r2 r14 r1 ASR r10
2049 };
2050 const byte kInstruction_sub_eq_r12_r13_r8_ROR_r12[] = {
2051   0x78, 0xcc, 0x4d, 0x00 // sub eq r12 r13 r8 ROR r12
2052 };
2053 const byte kInstruction_sub_gt_r9_r8_r2_LSL_r2[] = {
2054   0x12, 0x92, 0x48, 0xc0 // sub gt r9 r8 r2 LSL r2
2055 };
2056 const byte kInstruction_sub_al_r13_r10_r10_LSL_r9[] = {
2057   0x1a, 0xd9, 0x4a, 0xe0 // sub al r13 r10 r10 LSL r9
2058 };
2059 const byte kInstruction_sub_eq_r8_r8_r6_ROR_r14[] = {
2060   0x76, 0x8e, 0x48, 0x00 // sub eq r8 r8 r6 ROR r14
2061 };
2062 const byte kInstruction_sub_le_r14_r12_r4_ASR_r13[] = {
2063   0x54, 0xed, 0x4c, 0xd0 // sub le r14 r12 r4 ASR r13
2064 };
2065 const byte kInstruction_sub_cc_r3_r6_r12_LSR_r2[] = {
2066   0x3c, 0x32, 0x46, 0x30 // sub cc r3 r6 r12 LSR r2
2067 };
2068 const byte kInstruction_sub_ls_r5_r14_r10_LSL_r6[] = {
2069   0x1a, 0x56, 0x4e, 0x90 // sub ls r5 r14 r10 LSL r6
2070 };
2071 const byte kInstruction_sub_hi_r12_r2_r1_ROR_r3[] = {
2072   0x71, 0xc3, 0x42, 0x80 // sub hi r12 r2 r1 ROR r3
2073 };
2074 const byte kInstruction_sub_vc_r7_r13_r1_LSL_r12[] = {
2075   0x11, 0x7c, 0x4d, 0x70 // sub vc r7 r13 r1 LSL r12
2076 };
2077 const byte kInstruction_sub_cc_r0_r3_r13_LSL_r9[] = {
2078   0x1d, 0x09, 0x43, 0x30 // sub cc r0 r3 r13 LSL r9
2079 };
2080 const byte kInstruction_sub_hi_r0_r11_r5_LSL_r11[] = {
2081   0x15, 0x0b, 0x4b, 0x80 // sub hi r0 r11 r5 LSL r11
2082 };
2083 const byte kInstruction_sub_ge_r9_r6_r14_LSR_r14[] = {
2084   0x3e, 0x9e, 0x46, 0xa0 // sub ge r9 r6 r14 LSR r14
2085 };
2086 const byte kInstruction_sub_vc_r2_r5_r2_ROR_r12[] = {
2087   0x72, 0x2c, 0x45, 0x70 // sub vc r2 r5 r2 ROR r12
2088 };
2089 const byte kInstruction_sub_mi_r9_r6_r9_ASR_r13[] = {
2090   0x59, 0x9d, 0x46, 0x40 // sub mi r9 r6 r9 ASR r13
2091 };
2092 const byte kInstruction_sub_pl_r1_r3_r10_ASR_r2[] = {
2093   0x5a, 0x12, 0x43, 0x50 // sub pl r1 r3 r10 ASR r2
2094 };
2095 const byte kInstruction_sub_le_r10_r9_r7_LSL_r4[] = {
2096   0x17, 0xa4, 0x49, 0xd0 // sub le r10 r9 r7 LSL r4
2097 };
2098 const byte kInstruction_sub_hi_r7_r4_r10_LSR_r6[] = {
2099   0x3a, 0x76, 0x44, 0x80 // sub hi r7 r4 r10 LSR r6
2100 };
2101 const byte kInstruction_sub_cc_r6_r8_r13_LSR_r3[] = {
2102   0x3d, 0x63, 0x48, 0x30 // sub cc r6 r8 r13 LSR r3
2103 };
2104 const byte kInstruction_sub_cs_r4_r9_r6_ASR_r0[] = {
2105   0x56, 0x40, 0x49, 0x20 // sub cs r4 r9 r6 ASR r0
2106 };
2107 const byte kInstruction_sub_ls_r0_r2_r4_ASR_r8[] = {
2108   0x54, 0x08, 0x42, 0x90 // sub ls r0 r2 r4 ASR r8
2109 };
2110 const byte kInstruction_sub_hi_r11_r5_r11_LSR_r1[] = {
2111   0x3b, 0xb1, 0x45, 0x80 // sub hi r11 r5 r11 LSR r1
2112 };
2113 const byte kInstruction_sub_vc_r0_r3_r6_LSR_r7[] = {
2114   0x36, 0x07, 0x43, 0x70 // sub vc r0 r3 r6 LSR r7
2115 };
2116 const byte kInstruction_sub_cs_r13_r10_r8_LSL_r6[] = {
2117   0x18, 0xd6, 0x4a, 0x20 // sub cs r13 r10 r8 LSL r6
2118 };
2119 const byte kInstruction_sub_al_r12_r12_r10_ASR_r13[] = {
2120   0x5a, 0xcd, 0x4c, 0xe0 // sub al r12 r12 r10 ASR r13
2121 };
2122 const byte kInstruction_sub_ge_r7_r7_r2_ASR_r8[] = {
2123   0x52, 0x78, 0x47, 0xa0 // sub ge r7 r7 r2 ASR r8
2124 };
2125 const byte kInstruction_sub_ne_r10_r7_r6_LSL_r14[] = {
2126   0x16, 0xae, 0x47, 0x10 // sub ne r10 r7 r6 LSL r14
2127 };
2128 const byte kInstruction_sub_cs_r9_r9_r14_ROR_r0[] = {
2129   0x7e, 0x90, 0x49, 0x20 // sub cs r9 r9 r14 ROR r0
2130 };
2131 const byte kInstruction_sub_lt_r3_r12_r0_ASR_r12[] = {
2132   0x50, 0x3c, 0x4c, 0xb0 // sub lt r3 r12 r0 ASR r12
2133 };
2134 const byte kInstruction_sub_ne_r6_r9_r3_ASR_r11[] = {
2135   0x53, 0x6b, 0x49, 0x10 // sub ne r6 r9 r3 ASR r11
2136 };
2137 const byte kInstruction_sub_vc_r4_r7_r7_ASR_r7[] = {
2138   0x57, 0x47, 0x47, 0x70 // sub vc r4 r7 r7 ASR r7
2139 };
2140 const byte kInstruction_sub_ne_r0_r9_r5_LSR_r14[] = {
2141   0x35, 0x0e, 0x49, 0x10 // sub ne r0 r9 r5 LSR r14
2142 };
2143 const byte kInstruction_sub_hi_r8_r13_r1_ROR_r0[] = {
2144   0x71, 0x80, 0x4d, 0x80 // sub hi r8 r13 r1 ROR r0
2145 };
2146 const byte kInstruction_sub_cc_r6_r1_r7_ROR_r5[] = {
2147   0x77, 0x65, 0x41, 0x30 // sub cc r6 r1 r7 ROR r5
2148 };
2149 const byte kInstruction_sub_vc_r7_r13_r2_LSL_r4[] = {
2150   0x12, 0x74, 0x4d, 0x70 // sub vc r7 r13 r2 LSL r4
2151 };
2152 const byte kInstruction_sub_al_r4_r2_r3_ROR_r10[] = {
2153   0x73, 0x4a, 0x42, 0xe0 // sub al r4 r2 r3 ROR r10
2154 };
2155 const byte kInstruction_sub_ls_r0_r7_r3_LSR_r12[] = {
2156   0x33, 0x0c, 0x47, 0x90 // sub ls r0 r7 r3 LSR r12
2157 };
2158 const byte kInstruction_sub_ls_r5_r8_r8_ASR_r13[] = {
2159   0x58, 0x5d, 0x48, 0x90 // sub ls r5 r8 r8 ASR r13
2160 };
2161 const byte kInstruction_sub_gt_r0_r6_r12_ASR_r14[] = {
2162   0x5c, 0x0e, 0x46, 0xc0 // sub gt r0 r6 r12 ASR r14
2163 };
2164 const byte kInstruction_sub_vs_r7_r13_r14_LSR_r11[] = {
2165   0x3e, 0x7b, 0x4d, 0x60 // sub vs r7 r13 r14 LSR r11
2166 };
2167 const byte kInstruction_sub_mi_r12_r9_r11_LSL_r13[] = {
2168   0x1b, 0xcd, 0x49, 0x40 // sub mi r12 r9 r11 LSL r13
2169 };
2170 const byte kInstruction_sub_ge_r0_r0_r7_ROR_r13[] = {
2171   0x77, 0x0d, 0x40, 0xa0 // sub ge r0 r0 r7 ROR r13
2172 };
2173 const byte kInstruction_sub_hi_r14_r12_r6_LSR_r8[] = {
2174   0x36, 0xe8, 0x4c, 0x80 // sub hi r14 r12 r6 LSR r8
2175 };
2176 const byte kInstruction_sub_cs_r0_r3_r6_LSL_r6[] = {
2177   0x16, 0x06, 0x43, 0x20 // sub cs r0 r3 r6 LSL r6
2178 };
2179 const byte kInstruction_sub_al_r6_r9_r4_ASR_r3[] = {
2180   0x54, 0x63, 0x49, 0xe0 // sub al r6 r9 r4 ASR r3
2181 };
2182 const byte kInstruction_sub_ls_r5_r6_r1_LSR_r3[] = {
2183   0x31, 0x53, 0x46, 0x90 // sub ls r5 r6 r1 LSR r3
2184 };
2185 const byte kInstruction_sub_ls_r3_r6_r14_ROR_r7[] = {
2186   0x7e, 0x37, 0x46, 0x90 // sub ls r3 r6 r14 ROR r7
2187 };
2188 const byte kInstruction_sub_le_r10_r5_r1_ASR_r12[] = {
2189   0x51, 0xac, 0x45, 0xd0 // sub le r10 r5 r1 ASR r12
2190 };
2191 const byte kInstruction_sub_hi_r3_r6_r10_ASR_r5[] = {
2192   0x5a, 0x35, 0x46, 0x80 // sub hi r3 r6 r10 ASR r5
2193 };
2194 const byte kInstruction_sub_mi_r9_r3_r5_ROR_r8[] = {
2195   0x75, 0x98, 0x43, 0x40 // sub mi r9 r3 r5 ROR r8
2196 };
2197 const byte kInstruction_sub_hi_r10_r13_r8_ROR_r11[] = {
2198   0x78, 0xab, 0x4d, 0x80 // sub hi r10 r13 r8 ROR r11
2199 };
2200 const byte kInstruction_sub_al_r11_r14_r2_ROR_r1[] = {
2201   0x72, 0xb1, 0x4e, 0xe0 // sub al r11 r14 r2 ROR r1
2202 };
2203 const byte kInstruction_sub_gt_r12_r8_r0_ROR_r11[] = {
2204   0x70, 0xcb, 0x48, 0xc0 // sub gt r12 r8 r0 ROR r11
2205 };
2206 const byte kInstruction_sub_vc_r1_r0_r1_ROR_r9[] = {
2207   0x71, 0x19, 0x40, 0x70 // sub vc r1 r0 r1 ROR r9
2208 };
2209 const byte kInstruction_sub_mi_r6_r6_r3_ASR_r5[] = {
2210   0x53, 0x65, 0x46, 0x40 // sub mi r6 r6 r3 ASR r5
2211 };
2212 const byte kInstruction_sub_ge_r12_r12_r4_ROR_r9[] = {
2213   0x74, 0xc9, 0x4c, 0xa0 // sub ge r12 r12 r4 ROR r9
2214 };
2215 const byte kInstruction_sub_ls_r4_r6_r9_ASR_r6[] = {
2216   0x59, 0x46, 0x46, 0x90 // sub ls r4 r6 r9 ASR r6
2217 };
2218 const byte kInstruction_sub_pl_r11_r3_r4_LSR_r9[] = {
2219   0x34, 0xb9, 0x43, 0x50 // sub pl r11 r3 r4 LSR r9
2220 };
2221 const byte kInstruction_sub_hi_r0_r2_r2_ROR_r7[] = {
2222   0x72, 0x07, 0x42, 0x80 // sub hi r0 r2 r2 ROR r7
2223 };
2224 const byte kInstruction_sub_pl_r3_r12_r0_ASR_r2[] = {
2225   0x50, 0x32, 0x4c, 0x50 // sub pl r3 r12 r0 ASR r2
2226 };
2227 const byte kInstruction_sub_ne_r6_r0_r9_LSL_r4[] = {
2228   0x19, 0x64, 0x40, 0x10 // sub ne r6 r0 r9 LSL r4
2229 };
2230 const byte kInstruction_sub_vc_r1_r2_r6_ROR_r13[] = {
2231   0x76, 0x1d, 0x42, 0x70 // sub vc r1 r2 r6 ROR r13
2232 };
2233 const byte kInstruction_sub_ge_r9_r1_r12_LSL_r14[] = {
2234   0x1c, 0x9e, 0x41, 0xa0 // sub ge r9 r1 r12 LSL r14
2235 };
2236 const byte kInstruction_sub_pl_r13_r9_r6_ROR_r14[] = {
2237   0x76, 0xde, 0x49, 0x50 // sub pl r13 r9 r6 ROR r14
2238 };
2239 const byte kInstruction_sub_gt_r0_r13_r13_LSL_r9[] = {
2240   0x1d, 0x09, 0x4d, 0xc0 // sub gt r0 r13 r13 LSL r9
2241 };
2242 const byte kInstruction_sub_mi_r13_r5_r5_ASR_r8[] = {
2243   0x55, 0xd8, 0x45, 0x40 // sub mi r13 r5 r5 ASR r8
2244 };
2245 const byte kInstruction_sub_gt_r1_r4_r0_LSL_r6[] = {
2246   0x10, 0x16, 0x44, 0xc0 // sub gt r1 r4 r0 LSL r6
2247 };
2248 const byte kInstruction_sub_ls_r5_r4_r7_ROR_r4[] = {
2249   0x77, 0x54, 0x44, 0x90 // sub ls r5 r4 r7 ROR r4
2250 };
2251 const byte kInstruction_sub_vc_r8_r8_r0_ROR_r9[] = {
2252   0x70, 0x89, 0x48, 0x70 // sub vc r8 r8 r0 ROR r9
2253 };
2254 const byte kInstruction_sub_mi_r12_r12_r10_ROR_r8[] = {
2255   0x7a, 0xc8, 0x4c, 0x40 // sub mi r12 r12 r10 ROR r8
2256 };
2257 const byte kInstruction_sub_hi_r6_r6_r6_LSL_r2[] = {
2258   0x16, 0x62, 0x46, 0x80 // sub hi r6 r6 r6 LSL r2
2259 };
2260 const byte kInstruction_sub_le_r7_r10_r14_LSL_r1[] = {
2261   0x1e, 0x71, 0x4a, 0xd0 // sub le r7 r10 r14 LSL r1
2262 };
2263 const byte kInstruction_sub_ne_r13_r10_r6_ASR_r9[] = {
2264   0x56, 0xd9, 0x4a, 0x10 // sub ne r13 r10 r6 ASR r9
2265 };
2266 const byte kInstruction_sub_ne_r8_r8_r2_LSR_r13[] = {
2267   0x32, 0x8d, 0x48, 0x10 // sub ne r8 r8 r2 LSR r13
2268 };
2269 const byte kInstruction_sub_mi_r0_r10_r14_ROR_r12[] = {
2270   0x7e, 0x0c, 0x4a, 0x40 // sub mi r0 r10 r14 ROR r12
2271 };
2272 const byte kInstruction_sub_cc_r11_r14_r4_LSL_r5[] = {
2273   0x14, 0xb5, 0x4e, 0x30 // sub cc r11 r14 r4 LSL r5
2274 };
2275 const byte kInstruction_sub_cc_r3_r6_r3_ROR_r4[] = {
2276   0x73, 0x34, 0x46, 0x30 // sub cc r3 r6 r3 ROR r4
2277 };
2278 const byte kInstruction_sub_mi_r11_r1_r7_LSR_r7[] = {
2279   0x37, 0xb7, 0x41, 0x40 // sub mi r11 r1 r7 LSR r7
2280 };
2281 const byte kInstruction_sub_vs_r12_r2_r2_LSL_r12[] = {
2282   0x12, 0xcc, 0x42, 0x60 // sub vs r12 r2 r2 LSL r12
2283 };
2284 const byte kInstruction_sub_pl_r2_r2_r6_LSR_r0[] = {
2285   0x36, 0x20, 0x42, 0x50 // sub pl r2 r2 r6 LSR r0
2286 };
2287 const byte kInstruction_sub_gt_r11_r12_r7_LSR_r12[] = {
2288   0x37, 0xbc, 0x4c, 0xc0 // sub gt r11 r12 r7 LSR r12
2289 };
2290 const byte kInstruction_sub_al_r13_r4_r4_ASR_r12[] = {
2291   0x54, 0xdc, 0x44, 0xe0 // sub al r13 r4 r4 ASR r12
2292 };
2293 const byte kInstruction_sub_le_r9_r1_r9_ROR_r1[] = {
2294   0x79, 0x91, 0x41, 0xd0 // sub le r9 r1 r9 ROR r1
2295 };
2296 const byte kInstruction_sub_le_r1_r12_r8_ASR_r14[] = {
2297   0x58, 0x1e, 0x4c, 0xd0 // sub le r1 r12 r8 ASR r14
2298 };
2299 const byte kInstruction_sub_cs_r1_r0_r7_ROR_r13[] = {
2300   0x77, 0x1d, 0x40, 0x20 // sub cs r1 r0 r7 ROR r13
2301 };
2302 const byte kInstruction_sub_le_r0_r7_r7_ROR_r5[] = {
2303   0x77, 0x05, 0x47, 0xd0 // sub le r0 r7 r7 ROR r5
2304 };
2305 const byte kInstruction_sub_hi_r6_r5_r7_ROR_r4[] = {
2306   0x77, 0x64, 0x45, 0x80 // sub hi r6 r5 r7 ROR r4
2307 };
2308 const byte kInstruction_sub_eq_r6_r14_r13_ASR_r1[] = {
2309   0x5d, 0x61, 0x4e, 0x00 // sub eq r6 r14 r13 ASR r1
2310 };
2311 const byte kInstruction_sub_lt_r1_r14_r13_LSR_r13[] = {
2312   0x3d, 0x1d, 0x4e, 0xb0 // sub lt r1 r14 r13 LSR r13
2313 };
2314 const byte kInstruction_sub_vs_r13_r1_r2_ROR_r6[] = {
2315   0x72, 0xd6, 0x41, 0x60 // sub vs r13 r1 r2 ROR r6
2316 };
2317 const byte kInstruction_sub_gt_r11_r7_r8_ASR_r3[] = {
2318   0x58, 0xb3, 0x47, 0xc0 // sub gt r11 r7 r8 ASR r3
2319 };
2320 const byte kInstruction_sub_hi_r9_r5_r8_ASR_r8[] = {
2321   0x58, 0x98, 0x45, 0x80 // sub hi r9 r5 r8 ASR r8
2322 };
2323 const byte kInstruction_sub_lt_r10_r9_r5_LSL_r8[] = {
2324   0x15, 0xa8, 0x49, 0xb0 // sub lt r10 r9 r5 LSL r8
2325 };
2326 const byte kInstruction_sub_vs_r6_r1_r2_LSL_r4[] = {
2327   0x12, 0x64, 0x41, 0x60 // sub vs r6 r1 r2 LSL r4
2328 };
2329 const byte kInstruction_sub_pl_r13_r4_r10_LSR_r12[] = {
2330   0x3a, 0xdc, 0x44, 0x50 // sub pl r13 r4 r10 LSR r12
2331 };
2332 const byte kInstruction_sub_cs_r9_r8_r8_LSL_r6[] = {
2333   0x18, 0x96, 0x48, 0x20 // sub cs r9 r8 r8 LSL r6
2334 };
2335 const byte kInstruction_sub_ne_r1_r7_r0_ASR_r2[] = {
2336   0x50, 0x12, 0x47, 0x10 // sub ne r1 r7 r0 ASR r2
2337 };
2338 const byte kInstruction_sub_cc_r6_r3_r9_ASR_r3[] = {
2339   0x59, 0x63, 0x43, 0x30 // sub cc r6 r3 r9 ASR r3
2340 };
2341 const byte kInstruction_sub_hi_r13_r14_r7_ROR_r13[] = {
2342   0x77, 0xdd, 0x4e, 0x80 // sub hi r13 r14 r7 ROR r13
2343 };
2344 const byte kInstruction_sub_vc_r7_r11_r0_LSR_r8[] = {
2345   0x30, 0x78, 0x4b, 0x70 // sub vc r7 r11 r0 LSR r8
2346 };
2347 const byte kInstruction_sub_al_r3_r2_r7_LSL_r12[] = {
2348   0x17, 0x3c, 0x42, 0xe0 // sub al r3 r2 r7 LSL r12
2349 };
2350 const byte kInstruction_sub_lt_r0_r5_r5_LSR_r1[] = {
2351   0x35, 0x01, 0x45, 0xb0 // sub lt r0 r5 r5 LSR r1
2352 };
2353 const byte kInstruction_sub_ge_r10_r10_r4_ROR_r11[] = {
2354   0x74, 0xab, 0x4a, 0xa0 // sub ge r10 r10 r4 ROR r11
2355 };
2356 const byte kInstruction_sub_ne_r13_r9_r1_ROR_r12[] = {
2357   0x71, 0xdc, 0x49, 0x10 // sub ne r13 r9 r1 ROR r12
2358 };
2359 const byte kInstruction_sub_eq_r6_r6_r2_ROR_r3[] = {
2360   0x72, 0x63, 0x46, 0x00 // sub eq r6 r6 r2 ROR r3
2361 };
2362 const byte kInstruction_sub_gt_r0_r4_r1_ROR_r5[] = {
2363   0x71, 0x05, 0x44, 0xc0 // sub gt r0 r4 r1 ROR r5
2364 };
2365 const byte kInstruction_sub_lt_r5_r8_r0_ROR_r0[] = {
2366   0x70, 0x50, 0x48, 0xb0 // sub lt r5 r8 r0 ROR r0
2367 };
2368 const byte kInstruction_sub_cs_r5_r13_r2_LSR_r8[] = {
2369   0x32, 0x58, 0x4d, 0x20 // sub cs r5 r13 r2 LSR r8
2370 };
2371 const byte kInstruction_sub_le_r7_r13_r2_LSL_r7[] = {
2372   0x12, 0x77, 0x4d, 0xd0 // sub le r7 r13 r2 LSL r7
2373 };
2374 const byte kInstruction_sub_gt_r7_r1_r3_LSL_r1[] = {
2375   0x13, 0x71, 0x41, 0xc0 // sub gt r7 r1 r3 LSL r1
2376 };
2377 const byte kInstruction_sub_vc_r4_r13_r10_ROR_r8[] = {
2378   0x7a, 0x48, 0x4d, 0x70 // sub vc r4 r13 r10 ROR r8
2379 };
2380 const byte kInstruction_sub_eq_r2_r8_r11_ROR_r4[] = {
2381   0x7b, 0x24, 0x48, 0x00 // sub eq r2 r8 r11 ROR r4
2382 };
2383 const byte kInstruction_sub_le_r10_r1_r6_LSR_r9[] = {
2384   0x36, 0xa9, 0x41, 0xd0 // sub le r10 r1 r6 LSR r9
2385 };
2386 const byte kInstruction_sub_ge_r5_r1_r9_ASR_r10[] = {
2387   0x59, 0x5a, 0x41, 0xa0 // sub ge r5 r1 r9 ASR r10
2388 };
2389 const byte kInstruction_sub_al_r1_r5_r5_LSR_r7[] = {
2390   0x35, 0x17, 0x45, 0xe0 // sub al r1 r5 r5 LSR r7
2391 };
2392 const byte kInstruction_sub_cs_r2_r13_r5_LSR_r8[] = {
2393   0x35, 0x28, 0x4d, 0x20 // sub cs r2 r13 r5 LSR r8
2394 };
2395 const byte kInstruction_sub_le_r6_r6_r3_ROR_r3[] = {
2396   0x73, 0x63, 0x46, 0xd0 // sub le r6 r6 r3 ROR r3
2397 };
2398 const byte kInstruction_sub_le_r5_r1_r7_ROR_r12[] = {
2399   0x77, 0x5c, 0x41, 0xd0 // sub le r5 r1 r7 ROR r12
2400 };
2401 const byte kInstruction_sub_cc_r9_r3_r9_ASR_r4[] = {
2402   0x59, 0x94, 0x43, 0x30 // sub cc r9 r3 r9 ASR r4
2403 };
2404 const byte kInstruction_sub_mi_r6_r2_r9_LSL_r5[] = {
2405   0x19, 0x65, 0x42, 0x40 // sub mi r6 r2 r9 LSL r5
2406 };
2407 const byte kInstruction_sub_cc_r5_r0_r4_ASR_r12[] = {
2408   0x54, 0x5c, 0x40, 0x30 // sub cc r5 r0 r4 ASR r12
2409 };
2410 const byte kInstruction_sub_vc_r8_r13_r12_LSL_r11[] = {
2411   0x1c, 0x8b, 0x4d, 0x70 // sub vc r8 r13 r12 LSL r11
2412 };
2413 const byte kInstruction_sub_lt_r7_r14_r9_LSR_r11[] = {
2414   0x39, 0x7b, 0x4e, 0xb0 // sub lt r7 r14 r9 LSR r11
2415 };
2416 const byte kInstruction_sub_cs_r1_r5_r3_ASR_r1[] = {
2417   0x53, 0x11, 0x45, 0x20 // sub cs r1 r5 r3 ASR r1
2418 };
2419 const byte kInstruction_sub_lt_r14_r11_r6_ASR_r9[] = {
2420   0x56, 0xe9, 0x4b, 0xb0 // sub lt r14 r11 r6 ASR r9
2421 };
2422 const byte kInstruction_sub_gt_r10_r5_r13_LSR_r3[] = {
2423   0x3d, 0xa3, 0x45, 0xc0 // sub gt r10 r5 r13 LSR r3
2424 };
2425 const byte kInstruction_sub_cc_r6_r4_r12_LSL_r4[] = {
2426   0x1c, 0x64, 0x44, 0x30 // sub cc r6 r4 r12 LSL r4
2427 };
2428 const byte kInstruction_sub_ne_r2_r12_r10_ROR_r11[] = {
2429   0x7a, 0x2b, 0x4c, 0x10 // sub ne r2 r12 r10 ROR r11
2430 };
2431 const byte kInstruction_sub_eq_r8_r0_r6_ASR_r10[] = {
2432   0x56, 0x8a, 0x40, 0x00 // sub eq r8 r0 r6 ASR r10
2433 };
2434 const byte kInstruction_sub_cc_r14_r3_r14_LSR_r7[] = {
2435   0x3e, 0xe7, 0x43, 0x30 // sub cc r14 r3 r14 LSR r7
2436 };
2437 const byte kInstruction_sub_lt_r1_r10_r1_ASR_r13[] = {
2438   0x51, 0x1d, 0x4a, 0xb0 // sub lt r1 r10 r1 ASR r13
2439 };
2440 const byte kInstruction_sub_cc_r14_r3_r0_LSL_r12[] = {
2441   0x10, 0xec, 0x43, 0x30 // sub cc r14 r3 r0 LSL r12
2442 };
2443 const byte kInstruction_sub_vs_r8_r10_r7_LSL_r2[] = {
2444   0x17, 0x82, 0x4a, 0x60 // sub vs r8 r10 r7 LSL r2
2445 };
2446 const byte kInstruction_sub_ls_r5_r6_r3_ASR_r2[] = {
2447   0x53, 0x52, 0x46, 0x90 // sub ls r5 r6 r3 ASR r2
2448 };
2449 const byte kInstruction_sub_vc_r11_r5_r13_LSL_r10[] = {
2450   0x1d, 0xba, 0x45, 0x70 // sub vc r11 r5 r13 LSL r10
2451 };
2452 const byte kInstruction_sub_hi_r2_r10_r7_LSR_r0[] = {
2453   0x37, 0x20, 0x4a, 0x80 // sub hi r2 r10 r7 LSR r0
2454 };
2455 const byte kInstruction_sub_ne_r5_r6_r8_ASR_r4[] = {
2456   0x58, 0x54, 0x46, 0x10 // sub ne r5 r6 r8 ASR r4
2457 };
2458 const byte kInstruction_sub_cs_r3_r12_r8_ASR_r5[] = {
2459   0x58, 0x35, 0x4c, 0x20 // sub cs r3 r12 r8 ASR r5
2460 };
2461 const byte kInstruction_sub_ge_r3_r4_r4_LSR_r0[] = {
2462   0x34, 0x30, 0x44, 0xa0 // sub ge r3 r4 r4 LSR r0
2463 };
2464 const byte kInstruction_sub_ge_r13_r13_r6_ROR_r13[] = {
2465   0x76, 0xdd, 0x4d, 0xa0 // sub ge r13 r13 r6 ROR r13
2466 };
2467 const byte kInstruction_sub_eq_r4_r9_r0_LSL_r9[] = {
2468   0x10, 0x49, 0x49, 0x00 // sub eq r4 r9 r0 LSL r9
2469 };
2470 const byte kInstruction_sub_le_r7_r3_r1_ROR_r8[] = {
2471   0x71, 0x78, 0x43, 0xd0 // sub le r7 r3 r1 ROR r8
2472 };
2473 const byte kInstruction_sub_gt_r9_r2_r5_LSL_r4[] = {
2474   0x15, 0x94, 0x42, 0xc0 // sub gt r9 r2 r5 LSL r4
2475 };
2476 const byte kInstruction_sub_gt_r10_r12_r9_ROR_r12[] = {
2477   0x79, 0xac, 0x4c, 0xc0 // sub gt r10 r12 r9 ROR r12
2478 };
2479 const byte kInstruction_sub_hi_r4_r9_r6_LSR_r14[] = {
2480   0x36, 0x4e, 0x49, 0x80 // sub hi r4 r9 r6 LSR r14
2481 };
2482 const byte kInstruction_sub_pl_r1_r10_r9_LSR_r8[] = {
2483   0x39, 0x18, 0x4a, 0x50 // sub pl r1 r10 r9 LSR r8
2484 };
2485 const byte kInstruction_sub_mi_r0_r11_r2_ROR_r13[] = {
2486   0x72, 0x0d, 0x4b, 0x40 // sub mi r0 r11 r2 ROR r13
2487 };
2488 const byte kInstruction_sub_ge_r14_r5_r4_ASR_r2[] = {
2489   0x54, 0xe2, 0x45, 0xa0 // sub ge r14 r5 r4 ASR r2
2490 };
2491 const byte kInstruction_sub_vc_r7_r8_r9_ROR_r10[] = {
2492   0x79, 0x7a, 0x48, 0x70 // sub vc r7 r8 r9 ROR r10
2493 };
2494 const byte kInstruction_sub_cs_r3_r1_r0_ROR_r7[] = {
2495   0x70, 0x37, 0x41, 0x20 // sub cs r3 r1 r0 ROR r7
2496 };
2497 const byte kInstruction_sub_hi_r9_r11_r4_ASR_r14[] = {
2498   0x54, 0x9e, 0x4b, 0x80 // sub hi r9 r11 r4 ASR r14
2499 };
2500 const byte kInstruction_sub_mi_r3_r8_r6_LSR_r12[] = {
2501   0x36, 0x3c, 0x48, 0x40 // sub mi r3 r8 r6 LSR r12
2502 };
2503 const byte kInstruction_sub_vc_r5_r5_r6_LSL_r1[] = {
2504   0x16, 0x51, 0x45, 0x70 // sub vc r5 r5 r6 LSL r1
2505 };
2506 const byte kInstruction_sub_mi_r4_r8_r1_ASR_r3[] = {
2507   0x51, 0x43, 0x48, 0x40 // sub mi r4 r8 r1 ASR r3
2508 };
2509 const byte kInstruction_sub_le_r6_r0_r0_LSL_r0[] = {
2510   0x10, 0x60, 0x40, 0xd0 // sub le r6 r0 r0 LSL r0
2511 };
2512 const byte kInstruction_sub_hi_r8_r11_r8_LSL_r14[] = {
2513   0x18, 0x8e, 0x4b, 0x80 // sub hi r8 r11 r8 LSL r14
2514 };
2515 const byte kInstruction_sub_gt_r14_r8_r12_ASR_r13[] = {
2516   0x5c, 0xed, 0x48, 0xc0 // sub gt r14 r8 r12 ASR r13
2517 };
2518 const byte kInstruction_sub_ge_r7_r7_r4_ROR_r7[] = {
2519   0x74, 0x77, 0x47, 0xa0 // sub ge r7 r7 r4 ROR r7
2520 };
2521 const byte kInstruction_sub_eq_r11_r4_r13_LSL_r3[] = {
2522   0x1d, 0xb3, 0x44, 0x00 // sub eq r11 r4 r13 LSL r3
2523 };
2524 const byte kInstruction_sub_eq_r3_r6_r6_LSL_r10[] = {
2525   0x16, 0x3a, 0x46, 0x00 // sub eq r3 r6 r6 LSL r10
2526 };
2527 const byte kInstruction_sub_al_r3_r10_r11_ROR_r12[] = {
2528   0x7b, 0x3c, 0x4a, 0xe0 // sub al r3 r10 r11 ROR r12
2529 };
2530 const byte kInstruction_sub_pl_r13_r7_r8_LSL_r13[] = {
2531   0x18, 0xdd, 0x47, 0x50 // sub pl r13 r7 r8 LSL r13
2532 };
2533 const byte kInstruction_sub_pl_r9_r2_r11_LSR_r2[] = {
2534   0x3b, 0x92, 0x42, 0x50 // sub pl r9 r2 r11 LSR r2
2535 };
2536 const byte kInstruction_sub_al_r3_r12_r8_LSR_r2[] = {
2537   0x38, 0x32, 0x4c, 0xe0 // sub al r3 r12 r8 LSR r2
2538 };
2539 const byte kInstruction_sub_ne_r4_r14_r6_ROR_r0[] = {
2540   0x76, 0x40, 0x4e, 0x10 // sub ne r4 r14 r6 ROR r0
2541 };
2542 const byte kInstruction_sub_cs_r6_r14_r13_ASR_r3[] = {
2543   0x5d, 0x63, 0x4e, 0x20 // sub cs r6 r14 r13 ASR r3
2544 };
2545 const byte kInstruction_sub_pl_r10_r6_r8_LSR_r7[] = {
2546   0x38, 0xa7, 0x46, 0x50 // sub pl r10 r6 r8 LSR r7
2547 };
2548 const byte kInstruction_sub_ls_r10_r1_r12_ROR_r6[] = {
2549   0x7c, 0xa6, 0x41, 0x90 // sub ls r10 r1 r12 ROR r6
2550 };
2551 const byte kInstruction_sub_eq_r12_r0_r1_LSL_r9[] = {
2552   0x11, 0xc9, 0x40, 0x00 // sub eq r12 r0 r1 LSL r9
2553 };
2554 const byte kInstruction_sub_hi_r11_r14_r8_ROR_r6[] = {
2555   0x78, 0xb6, 0x4e, 0x80 // sub hi r11 r14 r8 ROR r6
2556 };
2557 const byte kInstruction_sub_vc_r9_r2_r5_LSL_r6[] = {
2558   0x15, 0x96, 0x42, 0x70 // sub vc r9 r2 r5 LSL r6
2559 };
2560 const byte kInstruction_sub_ne_r11_r8_r5_LSR_r11[] = {
2561   0x35, 0xbb, 0x48, 0x10 // sub ne r11 r8 r5 LSR r11
2562 };
2563 const byte kInstruction_sub_mi_r1_r12_r3_ASR_r5[] = {
2564   0x53, 0x15, 0x4c, 0x40 // sub mi r1 r12 r3 ASR r5
2565 };
2566 const byte kInstruction_sub_pl_r14_r7_r1_ASR_r12[] = {
2567   0x51, 0xec, 0x47, 0x50 // sub pl r14 r7 r1 ASR r12
2568 };
2569 const byte kInstruction_sub_pl_r9_r4_r1_ASR_r1[] = {
2570   0x51, 0x91, 0x44, 0x50 // sub pl r9 r4 r1 ASR r1
2571 };
2572 const byte kInstruction_sub_ls_r11_r0_r5_ROR_r14[] = {
2573   0x75, 0xbe, 0x40, 0x90 // sub ls r11 r0 r5 ROR r14
2574 };
2575 const byte kInstruction_sub_lt_r13_r10_r14_ROR_r13[] = {
2576   0x7e, 0xdd, 0x4a, 0xb0 // sub lt r13 r10 r14 ROR r13
2577 };
2578 const byte kInstruction_sub_gt_r3_r14_r10_LSR_r4[] = {
2579   0x3a, 0x34, 0x4e, 0xc0 // sub gt r3 r14 r10 LSR r4
2580 };
2581 const byte kInstruction_sub_cc_r1_r0_r5_ROR_r7[] = {
2582   0x75, 0x17, 0x40, 0x30 // sub cc r1 r0 r5 ROR r7
2583 };
2584 const byte kInstruction_sub_hi_r2_r14_r0_LSR_r14[] = {
2585   0x30, 0x2e, 0x4e, 0x80 // sub hi r2 r14 r0 LSR r14
2586 };
2587 const byte kInstruction_sub_pl_r3_r7_r2_ASR_r9[] = {
2588   0x52, 0x39, 0x47, 0x50 // sub pl r3 r7 r2 ASR r9
2589 };
2590 const byte kInstruction_sub_eq_r7_r5_r0_ROR_r6[] = {
2591   0x70, 0x76, 0x45, 0x00 // sub eq r7 r5 r0 ROR r6
2592 };
2593 const byte kInstruction_sub_mi_r14_r9_r14_LSR_r5[] = {
2594   0x3e, 0xe5, 0x49, 0x40 // sub mi r14 r9 r14 LSR r5
2595 };
2596 const byte kInstruction_sub_mi_r6_r1_r1_LSL_r12[] = {
2597   0x11, 0x6c, 0x41, 0x40 // sub mi r6 r1 r1 LSL r12
2598 };
2599 const byte kInstruction_sub_ge_r12_r0_r8_LSR_r0[] = {
2600   0x38, 0xc0, 0x40, 0xa0 // sub ge r12 r0 r8 LSR r0
2601 };
2602 const byte kInstruction_sub_cc_r13_r8_r3_ROR_r7[] = {
2603   0x73, 0xd7, 0x48, 0x30 // sub cc r13 r8 r3 ROR r7
2604 };
2605 const byte kInstruction_sub_vs_r7_r9_r4_LSL_r11[] = {
2606   0x14, 0x7b, 0x49, 0x60 // sub vs r7 r9 r4 LSL r11
2607 };
2608 const byte kInstruction_sub_ge_r9_r10_r9_LSR_r5[] = {
2609   0x39, 0x95, 0x4a, 0xa0 // sub ge r9 r10 r9 LSR r5
2610 };
2611 const byte kInstruction_sub_ls_r5_r3_r0_LSR_r7[] = {
2612   0x30, 0x57, 0x43, 0x90 // sub ls r5 r3 r0 LSR r7
2613 };
2614 const byte kInstruction_sub_eq_r0_r6_r1_LSL_r11[] = {
2615   0x11, 0x0b, 0x46, 0x00 // sub eq r0 r6 r1 LSL r11
2616 };
2617 const byte kInstruction_sub_ge_r9_r7_r0_ROR_r11[] = {
2618   0x70, 0x9b, 0x47, 0xa0 // sub ge r9 r7 r0 ROR r11
2619 };
2620 const byte kInstruction_sub_mi_r4_r2_r3_LSL_r12[] = {
2621   0x13, 0x4c, 0x42, 0x40 // sub mi r4 r2 r3 LSL r12
2622 };
2623 const byte kInstruction_sub_hi_r7_r5_r0_ASR_r5[] = {
2624   0x50, 0x75, 0x45, 0x80 // sub hi r7 r5 r0 ASR r5
2625 };
2626 const byte kInstruction_sub_cc_r7_r13_r7_LSL_r14[] = {
2627   0x17, 0x7e, 0x4d, 0x30 // sub cc r7 r13 r7 LSL r14
2628 };
2629 const byte kInstruction_sub_ne_r2_r11_r2_LSL_r14[] = {
2630   0x12, 0x2e, 0x4b, 0x10 // sub ne r2 r11 r2 LSL r14
2631 };
2632 const byte kInstruction_sub_cc_r7_r5_r3_LSR_r11[] = {
2633   0x33, 0x7b, 0x45, 0x30 // sub cc r7 r5 r3 LSR r11
2634 };
2635 const byte kInstruction_sub_ge_r12_r0_r12_ASR_r10[] = {
2636   0x5c, 0xca, 0x40, 0xa0 // sub ge r12 r0 r12 ASR r10
2637 };
2638 const byte kInstruction_sub_al_r11_r0_r2_LSR_r11[] = {
2639   0x32, 0xbb, 0x40, 0xe0 // sub al r11 r0 r2 LSR r11
2640 };
2641 const byte kInstruction_sub_cc_r1_r12_r1_ROR_r1[] = {
2642   0x71, 0x11, 0x4c, 0x30 // sub cc r1 r12 r1 ROR r1
2643 };
2644 const byte kInstruction_sub_ls_r5_r9_r6_ASR_r4[] = {
2645   0x56, 0x54, 0x49, 0x90 // sub ls r5 r9 r6 ASR r4
2646 };
2647 const byte kInstruction_sub_ne_r5_r13_r2_ROR_r12[] = {
2648   0x72, 0x5c, 0x4d, 0x10 // sub ne r5 r13 r2 ROR r12
2649 };
2650 const byte kInstruction_sub_ge_r9_r10_r12_ROR_r10[] = {
2651   0x7c, 0x9a, 0x4a, 0xa0 // sub ge r9 r10 r12 ROR r10
2652 };
2653 const byte kInstruction_sub_cc_r10_r1_r8_LSR_r12[] = {
2654   0x38, 0xac, 0x41, 0x30 // sub cc r10 r1 r8 LSR r12
2655 };
2656 const byte kInstruction_sub_le_r9_r6_r11_ROR_r3[] = {
2657   0x7b, 0x93, 0x46, 0xd0 // sub le r9 r6 r11 ROR r3
2658 };
2659 const byte kInstruction_sub_le_r9_r9_r13_ASR_r5[] = {
2660   0x5d, 0x95, 0x49, 0xd0 // sub le r9 r9 r13 ASR r5
2661 };
2662 const byte kInstruction_sub_ge_r1_r12_r11_LSL_r12[] = {
2663   0x1b, 0x1c, 0x4c, 0xa0 // sub ge r1 r12 r11 LSL r12
2664 };
2665 const byte kInstruction_sub_vs_r11_r4_r6_LSL_r10[] = {
2666   0x16, 0xba, 0x44, 0x60 // sub vs r11 r4 r6 LSL r10
2667 };
2668 const byte kInstruction_sub_vs_r3_r3_r1_ROR_r2[] = {
2669   0x71, 0x32, 0x43, 0x60 // sub vs r3 r3 r1 ROR r2
2670 };
2671 const byte kInstruction_sub_ne_r12_r8_r12_ASR_r11[] = {
2672   0x5c, 0xcb, 0x48, 0x10 // sub ne r12 r8 r12 ASR r11
2673 };
2674 const byte kInstruction_sub_pl_r4_r8_r1_ROR_r8[] = {
2675   0x71, 0x48, 0x48, 0x50 // sub pl r4 r8 r1 ROR r8
2676 };
2677 const byte kInstruction_sub_gt_r3_r11_r13_ROR_r9[] = {
2678   0x7d, 0x39, 0x4b, 0xc0 // sub gt r3 r11 r13 ROR r9
2679 };
2680 const byte kInstruction_sub_pl_r6_r0_r3_LSR_r9[] = {
2681   0x33, 0x69, 0x40, 0x50 // sub pl r6 r0 r3 LSR r9
2682 };
2683 const byte kInstruction_sub_ne_r5_r7_r9_LSL_r10[] = {
2684   0x19, 0x5a, 0x47, 0x10 // sub ne r5 r7 r9 LSL r10
2685 };
2686 const byte kInstruction_sub_lt_r1_r12_r12_LSR_r8[] = {
2687   0x3c, 0x18, 0x4c, 0xb0 // sub lt r1 r12 r12 LSR r8
2688 };
2689 const byte kInstruction_sub_cc_r2_r0_r0_ROR_r5[] = {
2690   0x70, 0x25, 0x40, 0x30 // sub cc r2 r0 r0 ROR r5
2691 };
2692 const byte kInstruction_sub_vc_r7_r11_r8_LSR_r14[] = {
2693   0x38, 0x7e, 0x4b, 0x70 // sub vc r7 r11 r8 LSR r14
2694 };
2695 const byte kInstruction_sub_ge_r0_r11_r6_ROR_r10[] = {
2696   0x76, 0x0a, 0x4b, 0xa0 // sub ge r0 r11 r6 ROR r10
2697 };
2698 const byte kInstruction_sub_vs_r0_r9_r1_LSR_r0[] = {
2699   0x31, 0x00, 0x49, 0x60 // sub vs r0 r9 r1 LSR r0
2700 };
2701 const byte kInstruction_sub_gt_r13_r7_r11_LSR_r1[] = {
2702   0x3b, 0xd1, 0x47, 0xc0 // sub gt r13 r7 r11 LSR r1
2703 };
2704 const byte kInstruction_sub_eq_r9_r10_r2_ROR_r12[] = {
2705   0x72, 0x9c, 0x4a, 0x00 // sub eq r9 r10 r2 ROR r12
2706 };
2707 const byte kInstruction_sub_eq_r0_r4_r0_LSR_r3[] = {
2708   0x30, 0x03, 0x44, 0x00 // sub eq r0 r4 r0 LSR r3
2709 };
2710 const byte kInstruction_sub_cs_r14_r2_r9_ASR_r12[] = {
2711   0x59, 0xec, 0x42, 0x20 // sub cs r14 r2 r9 ASR r12
2712 };
2713 const byte kInstruction_sub_lt_r9_r4_r9_ASR_r8[] = {
2714   0x59, 0x98, 0x44, 0xb0 // sub lt r9 r4 r9 ASR r8
2715 };
2716 const byte kInstruction_sub_vs_r6_r12_r3_LSL_r11[] = {
2717   0x13, 0x6b, 0x4c, 0x60 // sub vs r6 r12 r3 LSL r11
2718 };
2719 const byte kInstruction_sub_ge_r9_r14_r10_ROR_r0[] = {
2720   0x7a, 0x90, 0x4e, 0xa0 // sub ge r9 r14 r10 ROR r0
2721 };
2722 const byte kInstruction_sub_pl_r10_r2_r5_LSL_r12[] = {
2723   0x15, 0xac, 0x42, 0x50 // sub pl r10 r2 r5 LSL r12
2724 };
2725 const byte kInstruction_sub_al_r8_r0_r6_ROR_r6[] = {
2726   0x76, 0x86, 0x40, 0xe0 // sub al r8 r0 r6 ROR r6
2727 };
2728 const byte kInstruction_sub_le_r9_r7_r7_LSR_r11[] = {
2729   0x37, 0x9b, 0x47, 0xd0 // sub le r9 r7 r7 LSR r11
2730 };
2731 const byte kInstruction_sub_vc_r3_r4_r5_LSR_r1[] = {
2732   0x35, 0x31, 0x44, 0x70 // sub vc r3 r4 r5 LSR r1
2733 };
2734 const byte kInstruction_sub_cc_r13_r1_r4_LSR_r11[] = {
2735   0x34, 0xdb, 0x41, 0x30 // sub cc r13 r1 r4 LSR r11
2736 };
2737 const byte kInstruction_sub_vc_r13_r4_r0_LSL_r10[] = {
2738   0x10, 0xda, 0x44, 0x70 // sub vc r13 r4 r0 LSL r10
2739 };
2740 const byte kInstruction_sub_vc_r5_r0_r1_LSR_r1[] = {
2741   0x31, 0x51, 0x40, 0x70 // sub vc r5 r0 r1 LSR r1
2742 };
2743 const byte kInstruction_sub_ls_r5_r11_r1_ASR_r9[] = {
2744   0x51, 0x59, 0x4b, 0x90 // sub ls r5 r11 r1 ASR r9
2745 };
2746 const byte kInstruction_sub_vs_r3_r2_r8_ASR_r1[] = {
2747   0x58, 0x31, 0x42, 0x60 // sub vs r3 r2 r8 ASR r1
2748 };
2749 const byte kInstruction_sub_hi_r8_r4_r6_ASR_r4[] = {
2750   0x56, 0x84, 0x44, 0x80 // sub hi r8 r4 r6 ASR r4
2751 };
2752 const byte kInstruction_sub_mi_r11_r12_r14_ASR_r13[] = {
2753   0x5e, 0xbd, 0x4c, 0x40 // sub mi r11 r12 r14 ASR r13
2754 };
2755 const byte kInstruction_sub_gt_r7_r12_r12_LSL_r14[] = {
2756   0x1c, 0x7e, 0x4c, 0xc0 // sub gt r7 r12 r12 LSL r14
2757 };
2758 const byte kInstruction_sub_ge_r11_r4_r9_LSR_r7[] = {
2759   0x39, 0xb7, 0x44, 0xa0 // sub ge r11 r4 r9 LSR r7
2760 };
2761 const byte kInstruction_sub_vs_r0_r4_r10_LSL_r2[] = {
2762   0x1a, 0x02, 0x44, 0x60 // sub vs r0 r4 r10 LSL r2
2763 };
2764 const byte kInstruction_sub_pl_r6_r4_r13_ASR_r0[] = {
2765   0x5d, 0x60, 0x44, 0x50 // sub pl r6 r4 r13 ASR r0
2766 };
2767 const byte kInstruction_sub_eq_r2_r3_r11_ROR_r1[] = {
2768   0x7b, 0x21, 0x43, 0x00 // sub eq r2 r3 r11 ROR r1
2769 };
2770 const byte kInstruction_sub_vs_r10_r9_r0_LSL_r4[] = {
2771   0x10, 0xa4, 0x49, 0x60 // sub vs r10 r9 r0 LSL r4
2772 };
2773 const byte kInstruction_sub_cs_r0_r7_r10_LSL_r0[] = {
2774   0x1a, 0x00, 0x47, 0x20 // sub cs r0 r7 r10 LSL r0
2775 };
2776 const byte kInstruction_sub_eq_r11_r2_r3_ASR_r13[] = {
2777   0x53, 0xbd, 0x42, 0x00 // sub eq r11 r2 r3 ASR r13
2778 };
2779 const byte kInstruction_sub_eq_r14_r3_r7_ASR_r14[] = {
2780   0x57, 0xee, 0x43, 0x00 // sub eq r14 r3 r7 ASR r14
2781 };
2782 const byte kInstruction_sub_gt_r0_r2_r0_LSL_r12[] = {
2783   0x10, 0x0c, 0x42, 0xc0 // sub gt r0 r2 r0 LSL r12
2784 };
2785 const byte kInstruction_sub_mi_r0_r12_r6_LSR_r13[] = {
2786   0x36, 0x0d, 0x4c, 0x40 // sub mi r0 r12 r6 LSR r13
2787 };
2788 const byte kInstruction_sub_gt_r4_r4_r9_LSR_r12[] = {
2789   0x39, 0x4c, 0x44, 0xc0 // sub gt r4 r4 r9 LSR r12
2790 };
2791 const byte kInstruction_sub_vc_r6_r7_r10_ROR_r2[] = {
2792   0x7a, 0x62, 0x47, 0x70 // sub vc r6 r7 r10 ROR r2
2793 };
2794 const byte kInstruction_sub_lt_r10_r8_r13_ROR_r13[] = {
2795   0x7d, 0xad, 0x48, 0xb0 // sub lt r10 r8 r13 ROR r13
2796 };
2797 const byte kInstruction_sub_lt_r13_r10_r4_ROR_r0[] = {
2798   0x74, 0xd0, 0x4a, 0xb0 // sub lt r13 r10 r4 ROR r0
2799 };
2800 const byte kInstruction_sub_pl_r1_r6_r0_LSR_r12[] = {
2801   0x30, 0x1c, 0x46, 0x50 // sub pl r1 r6 r0 LSR r12
2802 };
2803 const byte kInstruction_sub_ge_r14_r7_r1_LSR_r8[] = {
2804   0x31, 0xe8, 0x47, 0xa0 // sub ge r14 r7 r1 LSR r8
2805 };
2806 const byte kInstruction_sub_cc_r8_r13_r6_LSL_r13[] = {
2807   0x16, 0x8d, 0x4d, 0x30 // sub cc r8 r13 r6 LSL r13
2808 };
2809 const byte kInstruction_sub_gt_r13_r4_r7_LSR_r2[] = {
2810   0x37, 0xd2, 0x44, 0xc0 // sub gt r13 r4 r7 LSR r2
2811 };
2812 const byte kInstruction_sub_eq_r11_r3_r5_LSR_r3[] = {
2813   0x35, 0xb3, 0x43, 0x00 // sub eq r11 r3 r5 LSR r3
2814 };
2815 const byte kInstruction_sub_vc_r8_r11_r2_ROR_r7[] = {
2816   0x72, 0x87, 0x4b, 0x70 // sub vc r8 r11 r2 ROR r7
2817 };
2818 const byte kInstruction_sub_vc_r11_r2_r0_LSL_r2[] = {
2819   0x10, 0xb2, 0x42, 0x70 // sub vc r11 r2 r0 LSL r2
2820 };
2821 const byte kInstruction_sub_cs_r9_r11_r11_LSL_r11[] = {
2822   0x1b, 0x9b, 0x4b, 0x20 // sub cs r9 r11 r11 LSL r11
2823 };
2824 const byte kInstruction_sub_ge_r14_r4_r12_LSL_r11[] = {
2825   0x1c, 0xeb, 0x44, 0xa0 // sub ge r14 r4 r12 LSL r11
2826 };
2827 const byte kInstruction_sub_vs_r4_r10_r3_LSL_r1[] = {
2828   0x13, 0x41, 0x4a, 0x60 // sub vs r4 r10 r3 LSL r1
2829 };
2830 const byte kInstruction_sub_mi_r13_r1_r8_LSR_r2[] = {
2831   0x38, 0xd2, 0x41, 0x40 // sub mi r13 r1 r8 LSR r2
2832 };
2833 const byte kInstruction_sub_le_r3_r13_r13_LSL_r8[] = {
2834   0x1d, 0x38, 0x4d, 0xd0 // sub le r3 r13 r13 LSL r8
2835 };
2836 const byte kInstruction_sub_mi_r9_r12_r8_LSR_r14[] = {
2837   0x38, 0x9e, 0x4c, 0x40 // sub mi r9 r12 r8 LSR r14
2838 };
2839 const byte kInstruction_sub_pl_r7_r11_r10_ASR_r2[] = {
2840   0x5a, 0x72, 0x4b, 0x50 // sub pl r7 r11 r10 ASR r2
2841 };
2842 const byte kInstruction_sub_lt_r12_r2_r9_ASR_r5[] = {
2843   0x59, 0xc5, 0x42, 0xb0 // sub lt r12 r2 r9 ASR r5
2844 };
2845 const byte kInstruction_sub_gt_r13_r0_r5_LSL_r2[] = {
2846   0x15, 0xd2, 0x40, 0xc0 // sub gt r13 r0 r5 LSL r2
2847 };
2848 const byte kInstruction_sub_le_r5_r10_r9_ROR_r0[] = {
2849   0x79, 0x50, 0x4a, 0xd0 // sub le r5 r10 r9 ROR r0
2850 };
2851 const byte kInstruction_sub_lt_r6_r1_r4_ASR_r11[] = {
2852   0x54, 0x6b, 0x41, 0xb0 // sub lt r6 r1 r4 ASR r11
2853 };
2854 const byte kInstruction_sub_pl_r11_r5_r14_LSR_r4[] = {
2855   0x3e, 0xb4, 0x45, 0x50 // sub pl r11 r5 r14 LSR r4
2856 };
2857 const byte kInstruction_sub_eq_r9_r0_r6_ROR_r9[] = {
2858   0x76, 0x99, 0x40, 0x00 // sub eq r9 r0 r6 ROR r9
2859 };
2860 const byte kInstruction_sub_mi_r3_r11_r2_ASR_r4[] = {
2861   0x52, 0x34, 0x4b, 0x40 // sub mi r3 r11 r2 ASR r4
2862 };
2863 const byte kInstruction_sub_pl_r13_r8_r0_ROR_r6[] = {
2864   0x70, 0xd6, 0x48, 0x50 // sub pl r13 r8 r0 ROR r6
2865 };
2866 const byte kInstruction_sub_vc_r8_r2_r6_ASR_r4[] = {
2867   0x56, 0x84, 0x42, 0x70 // sub vc r8 r2 r6 ASR r4
2868 };
2869 const byte kInstruction_sub_ge_r1_r0_r4_ASR_r1[] = {
2870   0x54, 0x11, 0x40, 0xa0 // sub ge r1 r0 r4 ASR r1
2871 };
2872 const byte kInstruction_sub_vc_r2_r4_r13_LSL_r13[] = {
2873   0x1d, 0x2d, 0x44, 0x70 // sub vc r2 r4 r13 LSL r13
2874 };
2875 const byte kInstruction_sub_lt_r4_r3_r5_ASR_r11[] = {
2876   0x55, 0x4b, 0x43, 0xb0 // sub lt r4 r3 r5 ASR r11
2877 };
2878 const byte kInstruction_sub_pl_r5_r12_r3_LSL_r4[] = {
2879   0x13, 0x54, 0x4c, 0x50 // sub pl r5 r12 r3 LSL r4
2880 };
2881 const byte kInstruction_sub_pl_r14_r6_r6_LSR_r10[] = {
2882   0x36, 0xea, 0x46, 0x50 // sub pl r14 r6 r6 LSR r10
2883 };
2884 const byte kInstruction_sub_gt_r14_r13_r3_LSL_r9[] = {
2885   0x13, 0xe9, 0x4d, 0xc0 // sub gt r14 r13 r3 LSL r9
2886 };
2887 const byte kInstruction_sub_pl_r10_r9_r4_LSL_r3[] = {
2888   0x14, 0xa3, 0x49, 0x50 // sub pl r10 r9 r4 LSL r3
2889 };
2890 const byte kInstruction_sub_al_r10_r8_r4_ROR_r1[] = {
2891   0x74, 0xa1, 0x48, 0xe0 // sub al r10 r8 r4 ROR r1
2892 };
2893 const byte kInstruction_sub_pl_r14_r9_r11_ASR_r13[] = {
2894   0x5b, 0xed, 0x49, 0x50 // sub pl r14 r9 r11 ASR r13
2895 };
2896 const byte kInstruction_sub_cc_r8_r1_r4_ROR_r12[] = {
2897   0x74, 0x8c, 0x41, 0x30 // sub cc r8 r1 r4 ROR r12
2898 };
2899 const byte kInstruction_sub_vs_r5_r14_r7_LSR_r0[] = {
2900   0x37, 0x50, 0x4e, 0x60 // sub vs r5 r14 r7 LSR r0
2901 };
2902 const byte kInstruction_sub_gt_r1_r10_r13_ROR_r9[] = {
2903   0x7d, 0x19, 0x4a, 0xc0 // sub gt r1 r10 r13 ROR r9
2904 };
2905 const byte kInstruction_sub_mi_r8_r14_r9_LSR_r5[] = {
2906   0x39, 0x85, 0x4e, 0x40 // sub mi r8 r14 r9 LSR r5
2907 };
2908 const byte kInstruction_sub_ge_r12_r10_r7_ROR_r2[] = {
2909   0x77, 0xc2, 0x4a, 0xa0 // sub ge r12 r10 r7 ROR r2
2910 };
2911 const byte kInstruction_sub_al_r11_r8_r1_LSR_r10[] = {
2912   0x31, 0xba, 0x48, 0xe0 // sub al r11 r8 r1 LSR r10
2913 };
2914 const byte kInstruction_sub_al_r7_r13_r11_LSL_r14[] = {
2915   0x1b, 0x7e, 0x4d, 0xe0 // sub al r7 r13 r11 LSL r14
2916 };
2917 const byte kInstruction_sub_vc_r13_r11_r11_ASR_r9[] = {
2918   0x5b, 0xd9, 0x4b, 0x70 // sub vc r13 r11 r11 ASR r9
2919 };
2920 const byte kInstruction_sub_gt_r10_r5_r11_LSR_r14[] = {
2921   0x3b, 0xae, 0x45, 0xc0 // sub gt r10 r5 r11 LSR r14
2922 };
2923 const byte kInstruction_sub_vc_r10_r11_r7_ROR_r3[] = {
2924   0x77, 0xa3, 0x4b, 0x70 // sub vc r10 r11 r7 ROR r3
2925 };
2926 const byte kInstruction_sub_le_r10_r2_r7_LSL_r6[] = {
2927   0x17, 0xa6, 0x42, 0xd0 // sub le r10 r2 r7 LSL r6
2928 };
2929 const byte kInstruction_sub_al_r1_r3_r6_ASR_r5[] = {
2930   0x56, 0x15, 0x43, 0xe0 // sub al r1 r3 r6 ASR r5
2931 };
2932 const byte kInstruction_sub_cs_r14_r9_r7_LSL_r12[] = {
2933   0x17, 0xec, 0x49, 0x20 // sub cs r14 r9 r7 LSL r12
2934 };
2935 const byte kInstruction_sub_ls_r10_r1_r4_LSL_r4[] = {
2936   0x14, 0xa4, 0x41, 0x90 // sub ls r10 r1 r4 LSL r4
2937 };
2938 const byte kInstruction_sub_vs_r2_r5_r4_ROR_r3[] = {
2939   0x74, 0x23, 0x45, 0x60 // sub vs r2 r5 r4 ROR r3
2940 };
2941 const byte kInstruction_sub_vs_r1_r7_r10_ASR_r0[] = {
2942   0x5a, 0x10, 0x47, 0x60 // sub vs r1 r7 r10 ASR r0
2943 };
2944 const byte kInstruction_sub_cs_r10_r12_r0_LSR_r4[] = {
2945   0x30, 0xa4, 0x4c, 0x20 // sub cs r10 r12 r0 LSR r4
2946 };
2947 const byte kInstruction_sub_vs_r8_r8_r1_LSR_r13[] = {
2948   0x31, 0x8d, 0x48, 0x60 // sub vs r8 r8 r1 LSR r13
2949 };
2950 const byte kInstruction_sub_mi_r14_r5_r9_LSR_r7[] = {
2951   0x39, 0xe7, 0x45, 0x40 // sub mi r14 r5 r9 LSR r7
2952 };
2953 const byte kInstruction_sub_vs_r6_r6_r14_ASR_r8[] = {
2954   0x5e, 0x68, 0x46, 0x60 // sub vs r6 r6 r14 ASR r8
2955 };
2956 const byte kInstruction_sub_vc_r0_r1_r14_ROR_r0[] = {
2957   0x7e, 0x00, 0x41, 0x70 // sub vc r0 r1 r14 ROR r0
2958 };
2959 const byte kInstruction_sub_ls_r9_r3_r11_ASR_r3[] = {
2960   0x5b, 0x93, 0x43, 0x90 // sub ls r9 r3 r11 ASR r3
2961 };
2962 const byte kInstruction_sub_ls_r1_r12_r1_ASR_r6[] = {
2963   0x51, 0x16, 0x4c, 0x90 // sub ls r1 r12 r1 ASR r6
2964 };
2965 const byte kInstruction_sub_hi_r6_r10_r0_ASR_r2[] = {
2966   0x50, 0x62, 0x4a, 0x80 // sub hi r6 r10 r0 ASR r2
2967 };
2968 const byte kInstruction_sub_vc_r6_r14_r7_ASR_r1[] = {
2969   0x57, 0x61, 0x4e, 0x70 // sub vc r6 r14 r7 ASR r1
2970 };
2971 const byte kInstruction_sub_eq_r14_r11_r10_LSL_r13[] = {
2972   0x1a, 0xed, 0x4b, 0x00 // sub eq r14 r11 r10 LSL r13
2973 };
2974 const byte kInstruction_sub_ge_r6_r12_r5_LSR_r9[] = {
2975   0x35, 0x69, 0x4c, 0xa0 // sub ge r6 r12 r5 LSR r9
2976 };
2977 const byte kInstruction_sub_mi_r1_r5_r0_ROR_r9[] = {
2978   0x70, 0x19, 0x45, 0x40 // sub mi r1 r5 r0 ROR r9
2979 };
2980 const byte kInstruction_sub_al_r7_r8_r2_ROR_r4[] = {
2981   0x72, 0x74, 0x48, 0xe0 // sub al r7 r8 r2 ROR r4
2982 };
2983 const byte kInstruction_sub_hi_r8_r1_r5_ASR_r10[] = {
2984   0x55, 0x8a, 0x41, 0x80 // sub hi r8 r1 r5 ASR r10
2985 };
2986 const byte kInstruction_sub_ne_r14_r5_r0_LSR_r7[] = {
2987   0x30, 0xe7, 0x45, 0x10 // sub ne r14 r5 r0 LSR r7
2988 };
2989 const byte kInstruction_sub_vc_r3_r13_r9_LSL_r9[] = {
2990   0x19, 0x39, 0x4d, 0x70 // sub vc r3 r13 r9 LSL r9
2991 };
2992 const byte kInstruction_sub_vs_r2_r2_r7_LSL_r5[] = {
2993   0x17, 0x25, 0x42, 0x60 // sub vs r2 r2 r7 LSL r5
2994 };
2995 const byte kInstruction_sub_vc_r7_r3_r6_ASR_r6[] = {
2996   0x56, 0x76, 0x43, 0x70 // sub vc r7 r3 r6 ASR r6
2997 };
2998 const byte kInstruction_sub_eq_r2_r5_r8_ROR_r1[] = {
2999   0x78, 0x21, 0x45, 0x00 // sub eq r2 r5 r8 ROR r1
3000 };
3001 const byte kInstruction_sub_eq_r0_r0_r10_ROR_r3[] = {
3002   0x7a, 0x03, 0x40, 0x00 // sub eq r0 r0 r10 ROR r3
3003 };
3004 const byte kInstruction_sub_lt_r6_r1_r0_ROR_r9[] = {
3005   0x70, 0x69, 0x41, 0xb0 // sub lt r6 r1 r0 ROR r9
3006 };
3007 const byte kInstruction_sub_ls_r7_r7_r12_LSR_r5[] = {
3008   0x3c, 0x75, 0x47, 0x90 // sub ls r7 r7 r12 LSR r5
3009 };
3010 const byte kInstruction_sub_vs_r0_r9_r7_ROR_r14[] = {
3011   0x77, 0x0e, 0x49, 0x60 // sub vs r0 r9 r7 ROR r14
3012 };
3013 const byte kInstruction_sub_al_r0_r8_r2_ROR_r2[] = {
3014   0x72, 0x02, 0x48, 0xe0 // sub al r0 r8 r2 ROR r2
3015 };
3016 const byte kInstruction_sub_vc_r1_r14_r14_LSL_r11[] = {
3017   0x1e, 0x1b, 0x4e, 0x70 // sub vc r1 r14 r14 LSL r11
3018 };
3019 const byte kInstruction_sub_ge_r9_r14_r10_ASR_r11[] = {
3020   0x5a, 0x9b, 0x4e, 0xa0 // sub ge r9 r14 r10 ASR r11
3021 };
3022 const byte kInstruction_sub_vs_r0_r3_r9_LSL_r4[] = {
3023   0x19, 0x04, 0x43, 0x60 // sub vs r0 r3 r9 LSL r4
3024 };
3025 const byte kInstruction_sub_pl_r14_r13_r7_LSR_r14[] = {
3026   0x37, 0xee, 0x4d, 0x50 // sub pl r14 r13 r7 LSR r14
3027 };
3028 const byte kInstruction_sub_le_r2_r4_r6_LSR_r3[] = {
3029   0x36, 0x23, 0x44, 0xd0 // sub le r2 r4 r6 LSR r3
3030 };
3031 const byte kInstruction_sub_vc_r7_r14_r6_LSR_r10[] = {
3032   0x36, 0x7a, 0x4e, 0x70 // sub vc r7 r14 r6 LSR r10
3033 };
3034 const byte kInstruction_sub_mi_r13_r11_r14_ASR_r7[] = {
3035   0x5e, 0xd7, 0x4b, 0x40 // sub mi r13 r11 r14 ASR r7
3036 };
3037 const TestResult kReferencesub[] = {
3038   {
3039     ARRAY_SIZE(kInstruction_sub_mi_r8_r10_r8_LSL_r0),
3040     kInstruction_sub_mi_r8_r10_r8_LSL_r0,
3041   },
3042   {
3043     ARRAY_SIZE(kInstruction_sub_cc_r11_r4_r13_ROR_r8),
3044     kInstruction_sub_cc_r11_r4_r13_ROR_r8,
3045   },
3046   {
3047     ARRAY_SIZE(kInstruction_sub_al_r13_r11_r3_ROR_r4),
3048     kInstruction_sub_al_r13_r11_r3_ROR_r4,
3049   },
3050   {
3051     ARRAY_SIZE(kInstruction_sub_gt_r11_r5_r4_LSR_r11),
3052     kInstruction_sub_gt_r11_r5_r4_LSR_r11,
3053   },
3054   {
3055     ARRAY_SIZE(kInstruction_sub_vs_r12_r0_r8_ROR_r13),
3056     kInstruction_sub_vs_r12_r0_r8_ROR_r13,
3057   },
3058   {
3059     ARRAY_SIZE(kInstruction_sub_pl_r10_r12_r5_LSL_r5),
3060     kInstruction_sub_pl_r10_r12_r5_LSL_r5,
3061   },
3062   {
3063     ARRAY_SIZE(kInstruction_sub_ls_r10_r2_r2_LSL_r9),
3064     kInstruction_sub_ls_r10_r2_r2_LSL_r9,
3065   },
3066   {
3067     ARRAY_SIZE(kInstruction_sub_eq_r12_r7_r9_LSR_r7),
3068     kInstruction_sub_eq_r12_r7_r9_LSR_r7,
3069   },
3070   {
3071     ARRAY_SIZE(kInstruction_sub_mi_r3_r13_r0_ROR_r11),
3072     kInstruction_sub_mi_r3_r13_r0_ROR_r11,
3073   },
3074   {
3075     ARRAY_SIZE(kInstruction_sub_lt_r9_r0_r9_ASR_r12),
3076     kInstruction_sub_lt_r9_r0_r9_ASR_r12,
3077   },
3078   {
3079     ARRAY_SIZE(kInstruction_sub_le_r12_r8_r14_ROR_r1),
3080     kInstruction_sub_le_r12_r8_r14_ROR_r1,
3081   },
3082   {
3083     ARRAY_SIZE(kInstruction_sub_cc_r7_r1_r14_LSL_r0),
3084     kInstruction_sub_cc_r7_r1_r14_LSL_r0,
3085   },
3086   {
3087     ARRAY_SIZE(kInstruction_sub_le_r11_r13_r3_ROR_r6),
3088     kInstruction_sub_le_r11_r13_r3_ROR_r6,
3089   },
3090   {
3091     ARRAY_SIZE(kInstruction_sub_al_r5_r8_r9_ASR_r14),
3092     kInstruction_sub_al_r5_r8_r9_ASR_r14,
3093   },
3094   {
3095     ARRAY_SIZE(kInstruction_sub_hi_r1_r2_r7_ASR_r13),
3096     kInstruction_sub_hi_r1_r2_r7_ASR_r13,
3097   },
3098   {
3099     ARRAY_SIZE(kInstruction_sub_al_r13_r8_r7_LSR_r12),
3100     kInstruction_sub_al_r13_r8_r7_LSR_r12,
3101   },
3102   {
3103     ARRAY_SIZE(kInstruction_sub_vc_r3_r6_r4_ASR_r4),
3104     kInstruction_sub_vc_r3_r6_r4_ASR_r4,
3105   },
3106   {
3107     ARRAY_SIZE(kInstruction_sub_lt_r12_r4_r6_LSL_r5),
3108     kInstruction_sub_lt_r12_r4_r6_LSL_r5,
3109   },
3110   {
3111     ARRAY_SIZE(kInstruction_sub_ls_r13_r5_r11_ROR_r8),
3112     kInstruction_sub_ls_r13_r5_r11_ROR_r8,
3113   },
3114   {
3115     ARRAY_SIZE(kInstruction_sub_vc_r11_r10_r11_LSL_r9),
3116     kInstruction_sub_vc_r11_r10_r11_LSL_r9,
3117   },
3118   {
3119     ARRAY_SIZE(kInstruction_sub_al_r13_r14_r10_LSR_r4),
3120     kInstruction_sub_al_r13_r14_r10_LSR_r4,
3121   },
3122   {
3123     ARRAY_SIZE(kInstruction_sub_ge_r12_r13_r6_ASR_r12),
3124     kInstruction_sub_ge_r12_r13_r6_ASR_r12,
3125   },
3126   {
3127     ARRAY_SIZE(kInstruction_sub_ne_r14_r6_r12_ROR_r0),
3128     kInstruction_sub_ne_r14_r6_r12_ROR_r0,
3129   },
3130   {
3131     ARRAY_SIZE(kInstruction_sub_ls_r13_r14_r14_ASR_r13),
3132     kInstruction_sub_ls_r13_r14_r14_ASR_r13,
3133   },
3134   {
3135     ARRAY_SIZE(kInstruction_sub_lt_r10_r13_r7_ROR_r8),
3136     kInstruction_sub_lt_r10_r13_r7_ROR_r8,
3137   },
3138   {
3139     ARRAY_SIZE(kInstruction_sub_lt_r8_r8_r9_ASR_r0),
3140     kInstruction_sub_lt_r8_r8_r9_ASR_r0,
3141   },
3142   {
3143     ARRAY_SIZE(kInstruction_sub_ne_r7_r5_r4_LSR_r8),
3144     kInstruction_sub_ne_r7_r5_r4_LSR_r8,
3145   },
3146   {
3147     ARRAY_SIZE(kInstruction_sub_mi_r11_r5_r1_LSL_r13),
3148     kInstruction_sub_mi_r11_r5_r1_LSL_r13,
3149   },
3150   {
3151     ARRAY_SIZE(kInstruction_sub_ge_r14_r1_r2_LSL_r1),
3152     kInstruction_sub_ge_r14_r1_r2_LSL_r1,
3153   },
3154   {
3155     ARRAY_SIZE(kInstruction_sub_ls_r6_r11_r4_ASR_r11),
3156     kInstruction_sub_ls_r6_r11_r4_ASR_r11,
3157   },
3158   {
3159     ARRAY_SIZE(kInstruction_sub_hi_r11_r12_r4_LSR_r13),
3160     kInstruction_sub_hi_r11_r12_r4_LSR_r13,
3161   },
3162   {
3163     ARRAY_SIZE(kInstruction_sub_le_r9_r3_r0_LSL_r7),
3164     kInstruction_sub_le_r9_r3_r0_LSL_r7,
3165   },
3166   {
3167     ARRAY_SIZE(kInstruction_sub_ls_r8_r7_r4_ASR_r3),
3168     kInstruction_sub_ls_r8_r7_r4_ASR_r3,
3169   },
3170   {
3171     ARRAY_SIZE(kInstruction_sub_pl_r9_r13_r11_LSL_r7),
3172     kInstruction_sub_pl_r9_r13_r11_LSL_r7,
3173   },
3174   {
3175     ARRAY_SIZE(kInstruction_sub_eq_r12_r7_r11_ASR_r3),
3176     kInstruction_sub_eq_r12_r7_r11_ASR_r3,
3177   },
3178   {
3179     ARRAY_SIZE(kInstruction_sub_mi_r3_r9_r13_ROR_r10),
3180     kInstruction_sub_mi_r3_r9_r13_ROR_r10,
3181   },
3182   {
3183     ARRAY_SIZE(kInstruction_sub_mi_r14_r8_r10_ROR_r10),
3184     kInstruction_sub_mi_r14_r8_r10_ROR_r10,
3185   },
3186   {
3187     ARRAY_SIZE(kInstruction_sub_lt_r5_r3_r5_LSL_r1),
3188     kInstruction_sub_lt_r5_r3_r5_LSL_r1,
3189   },
3190   {
3191     ARRAY_SIZE(kInstruction_sub_ne_r12_r6_r1_LSL_r7),
3192     kInstruction_sub_ne_r12_r6_r1_LSL_r7,
3193   },
3194   {
3195     ARRAY_SIZE(kInstruction_sub_lt_r3_r6_r5_ASR_r1),
3196     kInstruction_sub_lt_r3_r6_r5_ASR_r1,
3197   },
3198   {
3199     ARRAY_SIZE(kInstruction_sub_lt_r14_r0_r0_LSR_r11),
3200     kInstruction_sub_lt_r14_r0_r0_LSR_r11,
3201   },
3202   {
3203     ARRAY_SIZE(kInstruction_sub_eq_r11_r10_r4_LSL_r14),
3204     kInstruction_sub_eq_r11_r10_r4_LSL_r14,
3205   },
3206   {
3207     ARRAY_SIZE(kInstruction_sub_lt_r2_r14_r11_LSL_r9),
3208     kInstruction_sub_lt_r2_r14_r11_LSL_r9,
3209   },
3210   {
3211     ARRAY_SIZE(kInstruction_sub_mi_r0_r6_r14_ASR_r11),
3212     kInstruction_sub_mi_r0_r6_r14_ASR_r11,
3213   },
3214   {
3215     ARRAY_SIZE(kInstruction_sub_le_r4_r6_r3_LSR_r11),
3216     kInstruction_sub_le_r4_r6_r3_LSR_r11,
3217   },
3218   {
3219     ARRAY_SIZE(kInstruction_sub_cs_r2_r6_r1_ROR_r5),
3220     kInstruction_sub_cs_r2_r6_r1_ROR_r5,
3221   },
3222   {
3223     ARRAY_SIZE(kInstruction_sub_ne_r10_r9_r10_ROR_r4),
3224     kInstruction_sub_ne_r10_r9_r10_ROR_r4,
3225   },
3226   {
3227     ARRAY_SIZE(kInstruction_sub_pl_r7_r9_r11_LSR_r14),
3228     kInstruction_sub_pl_r7_r9_r11_LSR_r14,
3229   },
3230   {
3231     ARRAY_SIZE(kInstruction_sub_pl_r11_r8_r3_ASR_r5),
3232     kInstruction_sub_pl_r11_r8_r3_ASR_r5,
3233   },
3234   {
3235     ARRAY_SIZE(kInstruction_sub_le_r10_r4_r10_ROR_r8),
3236     kInstruction_sub_le_r10_r4_r10_ROR_r8,
3237   },
3238   {
3239     ARRAY_SIZE(kInstruction_sub_ne_r8_r14_r8_LSL_r5),
3240     kInstruction_sub_ne_r8_r14_r8_LSL_r5,
3241   },
3242   {
3243     ARRAY_SIZE(kInstruction_sub_eq_r12_r5_r2_LSL_r11),
3244     kInstruction_sub_eq_r12_r5_r2_LSL_r11,
3245   },
3246   {
3247     ARRAY_SIZE(kInstruction_sub_pl_r9_r9_r8_ASR_r2),
3248     kInstruction_sub_pl_r9_r9_r8_ASR_r2,
3249   },
3250   {
3251     ARRAY_SIZE(kInstruction_sub_hi_r8_r12_r3_LSL_r5),
3252     kInstruction_sub_hi_r8_r12_r3_LSL_r5,
3253   },
3254   {
3255     ARRAY_SIZE(kInstruction_sub_eq_r6_r5_r9_LSL_r3),
3256     kInstruction_sub_eq_r6_r5_r9_LSL_r3,
3257   },
3258   {
3259     ARRAY_SIZE(kInstruction_sub_lt_r5_r1_r9_LSR_r6),
3260     kInstruction_sub_lt_r5_r1_r9_LSR_r6,
3261   },
3262   {
3263     ARRAY_SIZE(kInstruction_sub_hi_r9_r9_r0_LSL_r5),
3264     kInstruction_sub_hi_r9_r9_r0_LSL_r5,
3265   },
3266   {
3267     ARRAY_SIZE(kInstruction_sub_cs_r6_r6_r5_LSL_r8),
3268     kInstruction_sub_cs_r6_r6_r5_LSL_r8,
3269   },
3270   {
3271     ARRAY_SIZE(kInstruction_sub_cs_r0_r1_r6_LSR_r12),
3272     kInstruction_sub_cs_r0_r1_r6_LSR_r12,
3273   },
3274   {
3275     ARRAY_SIZE(kInstruction_sub_cc_r4_r6_r13_ASR_r6),
3276     kInstruction_sub_cc_r4_r6_r13_ASR_r6,
3277   },
3278   {
3279     ARRAY_SIZE(kInstruction_sub_hi_r11_r8_r10_LSR_r5),
3280     kInstruction_sub_hi_r11_r8_r10_LSR_r5,
3281   },
3282   {
3283     ARRAY_SIZE(kInstruction_sub_ls_r8_r1_r14_ROR_r14),
3284     kInstruction_sub_ls_r8_r1_r14_ROR_r14,
3285   },
3286   {
3287     ARRAY_SIZE(kInstruction_sub_pl_r8_r2_r12_ASR_r7),
3288     kInstruction_sub_pl_r8_r2_r12_ASR_r7,
3289   },
3290   {
3291     ARRAY_SIZE(kInstruction_sub_gt_r14_r7_r5_ROR_r11),
3292     kInstruction_sub_gt_r14_r7_r5_ROR_r11,
3293   },
3294   {
3295     ARRAY_SIZE(kInstruction_sub_eq_r3_r6_r13_ROR_r0),
3296     kInstruction_sub_eq_r3_r6_r13_ROR_r0,
3297   },
3298   {
3299     ARRAY_SIZE(kInstruction_sub_le_r4_r8_r8_ROR_r11),
3300     kInstruction_sub_le_r4_r8_r8_ROR_r11,
3301   },
3302   {
3303     ARRAY_SIZE(kInstruction_sub_ge_r2_r7_r5_ASR_r6),
3304     kInstruction_sub_ge_r2_r7_r5_ASR_r6,
3305   },
3306   {
3307     ARRAY_SIZE(kInstruction_sub_cc_r8_r12_r5_LSL_r11),
3308     kInstruction_sub_cc_r8_r12_r5_LSL_r11,
3309   },
3310   {
3311     ARRAY_SIZE(kInstruction_sub_vc_r11_r10_r3_ROR_r5),
3312     kInstruction_sub_vc_r11_r10_r3_ROR_r5,
3313   },
3314   {
3315     ARRAY_SIZE(kInstruction_sub_vc_r11_r9_r11_LSL_r6),
3316     kInstruction_sub_vc_r11_r9_r11_LSL_r6,
3317   },
3318   {
3319     ARRAY_SIZE(kInstruction_sub_lt_r6_r5_r0_ROR_r9),
3320     kInstruction_sub_lt_r6_r5_r0_ROR_r9,
3321   },
3322   {
3323     ARRAY_SIZE(kInstruction_sub_cs_r13_r7_r11_ASR_r9),
3324     kInstruction_sub_cs_r13_r7_r11_ASR_r9,
3325   },
3326   {
3327     ARRAY_SIZE(kInstruction_sub_cs_r9_r7_r9_ROR_r11),
3328     kInstruction_sub_cs_r9_r7_r9_ROR_r11,
3329   },
3330   {
3331     ARRAY_SIZE(kInstruction_sub_ls_r14_r3_r2_ASR_r11),
3332     kInstruction_sub_ls_r14_r3_r2_ASR_r11,
3333   },
3334   {
3335     ARRAY_SIZE(kInstruction_sub_vc_r0_r1_r1_LSR_r0),
3336     kInstruction_sub_vc_r0_r1_r1_LSR_r0,
3337   },
3338   {
3339     ARRAY_SIZE(kInstruction_sub_mi_r10_r8_r8_LSR_r13),
3340     kInstruction_sub_mi_r10_r8_r8_LSR_r13,
3341   },
3342   {
3343     ARRAY_SIZE(kInstruction_sub_pl_r8_r14_r3_LSL_r8),
3344     kInstruction_sub_pl_r8_r14_r3_LSL_r8,
3345   },
3346   {
3347     ARRAY_SIZE(kInstruction_sub_ne_r6_r4_r1_LSL_r12),
3348     kInstruction_sub_ne_r6_r4_r1_LSL_r12,
3349   },
3350   {
3351     ARRAY_SIZE(kInstruction_sub_lt_r2_r2_r7_ROR_r0),
3352     kInstruction_sub_lt_r2_r2_r7_ROR_r0,
3353   },
3354   {
3355     ARRAY_SIZE(kInstruction_sub_lt_r2_r4_r13_ASR_r5),
3356     kInstruction_sub_lt_r2_r4_r13_ASR_r5,
3357   },
3358   {
3359     ARRAY_SIZE(kInstruction_sub_eq_r8_r1_r2_ROR_r13),
3360     kInstruction_sub_eq_r8_r1_r2_ROR_r13,
3361   },
3362   {
3363     ARRAY_SIZE(kInstruction_sub_lt_r1_r8_r10_LSR_r7),
3364     kInstruction_sub_lt_r1_r8_r10_LSR_r7,
3365   },
3366   {
3367     ARRAY_SIZE(kInstruction_sub_cs_r7_r5_r9_LSL_r9),
3368     kInstruction_sub_cs_r7_r5_r9_LSL_r9,
3369   },
3370   {
3371     ARRAY_SIZE(kInstruction_sub_mi_r8_r0_r6_LSL_r8),
3372     kInstruction_sub_mi_r8_r0_r6_LSL_r8,
3373   },
3374   {
3375     ARRAY_SIZE(kInstruction_sub_cs_r7_r12_r3_ROR_r6),
3376     kInstruction_sub_cs_r7_r12_r3_ROR_r6,
3377   },
3378   {
3379     ARRAY_SIZE(kInstruction_sub_vs_r13_r8_r13_LSR_r4),
3380     kInstruction_sub_vs_r13_r8_r13_LSR_r4,
3381   },
3382   {
3383     ARRAY_SIZE(kInstruction_sub_cc_r4_r13_r7_ROR_r11),
3384     kInstruction_sub_cc_r4_r13_r7_ROR_r11,
3385   },
3386   {
3387     ARRAY_SIZE(kInstruction_sub_ge_r10_r5_r9_LSR_r13),
3388     kInstruction_sub_ge_r10_r5_r9_LSR_r13,
3389   },
3390   {
3391     ARRAY_SIZE(kInstruction_sub_cc_r0_r5_r9_ASR_r4),
3392     kInstruction_sub_cc_r0_r5_r9_ASR_r4,
3393   },
3394   {
3395     ARRAY_SIZE(kInstruction_sub_cc_r1_r5_r8_LSR_r12),
3396     kInstruction_sub_cc_r1_r5_r8_LSR_r12,
3397   },
3398   {
3399     ARRAY_SIZE(kInstruction_sub_ls_r12_r3_r5_LSL_r6),
3400     kInstruction_sub_ls_r12_r3_r5_LSL_r6,
3401   },
3402   {
3403     ARRAY_SIZE(kInstruction_sub_cs_r10_r0_r4_ASR_r7),
3404     kInstruction_sub_cs_r10_r0_r4_ASR_r7,
3405   },
3406   {
3407     ARRAY_SIZE(kInstruction_sub_ge_r10_r13_r14_ROR_r6),
3408     kInstruction_sub_ge_r10_r13_r14_ROR_r6,
3409   },
3410   {
3411     ARRAY_SIZE(kInstruction_sub_al_r9_r0_r9_ROR_r3),
3412     kInstruction_sub_al_r9_r0_r9_ROR_r3,
3413   },
3414   {
3415     ARRAY_SIZE(kInstruction_sub_vs_r4_r5_r12_ASR_r6),
3416     kInstruction_sub_vs_r4_r5_r12_ASR_r6,
3417   },
3418   {
3419     ARRAY_SIZE(kInstruction_sub_lt_r4_r1_r14_LSL_r12),
3420     kInstruction_sub_lt_r4_r1_r14_LSL_r12,
3421   },
3422   {
3423     ARRAY_SIZE(kInstruction_sub_cs_r14_r11_r8_ROR_r4),
3424     kInstruction_sub_cs_r14_r11_r8_ROR_r4,
3425   },
3426   {
3427     ARRAY_SIZE(kInstruction_sub_hi_r12_r0_r14_LSR_r11),
3428     kInstruction_sub_hi_r12_r0_r14_LSR_r11,
3429   },
3430   {
3431     ARRAY_SIZE(kInstruction_sub_le_r8_r6_r4_ASR_r7),
3432     kInstruction_sub_le_r8_r6_r4_ASR_r7,
3433   },
3434   {
3435     ARRAY_SIZE(kInstruction_sub_mi_r13_r4_r14_LSR_r10),
3436     kInstruction_sub_mi_r13_r4_r14_LSR_r10,
3437   },
3438   {
3439     ARRAY_SIZE(kInstruction_sub_vs_r11_r10_r5_LSL_r10),
3440     kInstruction_sub_vs_r11_r10_r5_LSL_r10,
3441   },
3442   {
3443     ARRAY_SIZE(kInstruction_sub_cc_r4_r0_r5_LSR_r2),
3444     kInstruction_sub_cc_r4_r0_r5_LSR_r2,
3445   },
3446   {
3447     ARRAY_SIZE(kInstruction_sub_pl_r9_r14_r0_LSL_r3),
3448     kInstruction_sub_pl_r9_r14_r0_LSL_r3,
3449   },
3450   {
3451     ARRAY_SIZE(kInstruction_sub_vc_r7_r2_r14_ASR_r1),
3452     kInstruction_sub_vc_r7_r2_r14_ASR_r1,
3453   },
3454   {
3455     ARRAY_SIZE(kInstruction_sub_gt_r4_r14_r1_ROR_r10),
3456     kInstruction_sub_gt_r4_r14_r1_ROR_r10,
3457   },
3458   {
3459     ARRAY_SIZE(kInstruction_sub_lt_r6_r4_r10_LSL_r7),
3460     kInstruction_sub_lt_r6_r4_r10_LSL_r7,
3461   },
3462   {
3463     ARRAY_SIZE(kInstruction_sub_hi_r1_r14_r5_LSL_r12),
3464     kInstruction_sub_hi_r1_r14_r5_LSL_r12,
3465   },
3466   {
3467     ARRAY_SIZE(kInstruction_sub_cc_r14_r12_r4_ASR_r14),
3468     kInstruction_sub_cc_r14_r12_r4_ASR_r14,
3469   },
3470   {
3471     ARRAY_SIZE(kInstruction_sub_cc_r0_r8_r5_ROR_r8),
3472     kInstruction_sub_cc_r0_r8_r5_ROR_r8,
3473   },
3474   {
3475     ARRAY_SIZE(kInstruction_sub_gt_r9_r9_r0_ASR_r4),
3476     kInstruction_sub_gt_r9_r9_r0_ASR_r4,
3477   },
3478   {
3479     ARRAY_SIZE(kInstruction_sub_mi_r8_r11_r12_ASR_r4),
3480     kInstruction_sub_mi_r8_r11_r12_ASR_r4,
3481   },
3482   {
3483     ARRAY_SIZE(kInstruction_sub_vs_r0_r12_r0_LSR_r11),
3484     kInstruction_sub_vs_r0_r12_r0_LSR_r11,
3485   },
3486   {
3487     ARRAY_SIZE(kInstruction_sub_ge_r0_r9_r1_ASR_r0),
3488     kInstruction_sub_ge_r0_r9_r1_ASR_r0,
3489   },
3490   {
3491     ARRAY_SIZE(kInstruction_sub_al_r10_r11_r5_LSR_r4),
3492     kInstruction_sub_al_r10_r11_r5_LSR_r4,
3493   },
3494   {
3495     ARRAY_SIZE(kInstruction_sub_eq_r0_r6_r8_LSR_r10),
3496     kInstruction_sub_eq_r0_r6_r8_LSR_r10,
3497   },
3498   {
3499     ARRAY_SIZE(kInstruction_sub_cc_r13_r12_r14_ROR_r9),
3500     kInstruction_sub_cc_r13_r12_r14_ROR_r9,
3501   },
3502   {
3503     ARRAY_SIZE(kInstruction_sub_ls_r4_r11_r0_LSL_r14),
3504     kInstruction_sub_ls_r4_r11_r0_LSL_r14,
3505   },
3506   {
3507     ARRAY_SIZE(kInstruction_sub_hi_r1_r6_r12_LSR_r13),
3508     kInstruction_sub_hi_r1_r6_r12_LSR_r13,
3509   },
3510   {
3511     ARRAY_SIZE(kInstruction_sub_cs_r7_r11_r1_ASR_r5),
3512     kInstruction_sub_cs_r7_r11_r1_ASR_r5,
3513   },
3514   {
3515     ARRAY_SIZE(kInstruction_sub_cc_r7_r5_r4_ASR_r11),
3516     kInstruction_sub_cc_r7_r5_r4_ASR_r11,
3517   },
3518   {
3519     ARRAY_SIZE(kInstruction_sub_hi_r7_r2_r5_ROR_r5),
3520     kInstruction_sub_hi_r7_r2_r5_ROR_r5,
3521   },
3522   {
3523     ARRAY_SIZE(kInstruction_sub_vc_r11_r9_r7_LSL_r14),
3524     kInstruction_sub_vc_r11_r9_r7_LSL_r14,
3525   },
3526   {
3527     ARRAY_SIZE(kInstruction_sub_le_r12_r1_r3_ROR_r7),
3528     kInstruction_sub_le_r12_r1_r3_ROR_r7,
3529   },
3530   {
3531     ARRAY_SIZE(kInstruction_sub_al_r8_r14_r0_ASR_r12),
3532     kInstruction_sub_al_r8_r14_r0_ASR_r12,
3533   },
3534   {
3535     ARRAY_SIZE(kInstruction_sub_vc_r14_r3_r0_ROR_r1),
3536     kInstruction_sub_vc_r14_r3_r0_ROR_r1,
3537   },
3538   {
3539     ARRAY_SIZE(kInstruction_sub_pl_r10_r8_r3_ROR_r4),
3540     kInstruction_sub_pl_r10_r8_r3_ROR_r4,
3541   },
3542   {
3543     ARRAY_SIZE(kInstruction_sub_al_r9_r14_r12_LSL_r4),
3544     kInstruction_sub_al_r9_r14_r12_LSL_r4,
3545   },
3546   {
3547     ARRAY_SIZE(kInstruction_sub_vs_r8_r3_r14_ASR_r7),
3548     kInstruction_sub_vs_r8_r3_r14_ASR_r7,
3549   },
3550   {
3551     ARRAY_SIZE(kInstruction_sub_hi_r4_r8_r13_LSL_r1),
3552     kInstruction_sub_hi_r4_r8_r13_LSL_r1,
3553   },
3554   {
3555     ARRAY_SIZE(kInstruction_sub_al_r6_r11_r11_LSL_r14),
3556     kInstruction_sub_al_r6_r11_r11_LSL_r14,
3557   },
3558   {
3559     ARRAY_SIZE(kInstruction_sub_al_r7_r2_r4_LSR_r1),
3560     kInstruction_sub_al_r7_r2_r4_LSR_r1,
3561   },
3562   {
3563     ARRAY_SIZE(kInstruction_sub_vc_r5_r10_r3_ASR_r8),
3564     kInstruction_sub_vc_r5_r10_r3_ASR_r8,
3565   },
3566   {
3567     ARRAY_SIZE(kInstruction_sub_cc_r3_r10_r9_ROR_r11),
3568     kInstruction_sub_cc_r3_r10_r9_ROR_r11,
3569   },
3570   {
3571     ARRAY_SIZE(kInstruction_sub_eq_r11_r9_r8_LSL_r2),
3572     kInstruction_sub_eq_r11_r9_r8_LSL_r2,
3573   },
3574   {
3575     ARRAY_SIZE(kInstruction_sub_mi_r6_r9_r5_ASR_r12),
3576     kInstruction_sub_mi_r6_r9_r5_ASR_r12,
3577   },
3578   {
3579     ARRAY_SIZE(kInstruction_sub_hi_r6_r6_r0_ASR_r9),
3580     kInstruction_sub_hi_r6_r6_r0_ASR_r9,
3581   },
3582   {
3583     ARRAY_SIZE(kInstruction_sub_ge_r12_r13_r1_LSL_r9),
3584     kInstruction_sub_ge_r12_r13_r1_LSL_r9,
3585   },
3586   {
3587     ARRAY_SIZE(kInstruction_sub_le_r4_r9_r14_ASR_r2),
3588     kInstruction_sub_le_r4_r9_r14_ASR_r2,
3589   },
3590   {
3591     ARRAY_SIZE(kInstruction_sub_gt_r5_r3_r9_ROR_r5),
3592     kInstruction_sub_gt_r5_r3_r9_ROR_r5,
3593   },
3594   {
3595     ARRAY_SIZE(kInstruction_sub_al_r14_r5_r13_ROR_r7),
3596     kInstruction_sub_al_r14_r5_r13_ROR_r7,
3597   },
3598   {
3599     ARRAY_SIZE(kInstruction_sub_lt_r2_r1_r14_ASR_r8),
3600     kInstruction_sub_lt_r2_r1_r14_ASR_r8,
3601   },
3602   {
3603     ARRAY_SIZE(kInstruction_sub_al_r12_r7_r8_LSL_r11),
3604     kInstruction_sub_al_r12_r7_r8_LSL_r11,
3605   },
3606   {
3607     ARRAY_SIZE(kInstruction_sub_ne_r4_r12_r14_LSL_r1),
3608     kInstruction_sub_ne_r4_r12_r14_LSL_r1,
3609   },
3610   {
3611     ARRAY_SIZE(kInstruction_sub_vs_r7_r14_r4_LSL_r6),
3612     kInstruction_sub_vs_r7_r14_r4_LSL_r6,
3613   },
3614   {
3615     ARRAY_SIZE(kInstruction_sub_ge_r12_r5_r11_ASR_r4),
3616     kInstruction_sub_ge_r12_r5_r11_ASR_r4,
3617   },
3618   {
3619     ARRAY_SIZE(kInstruction_sub_gt_r4_r10_r6_LSR_r6),
3620     kInstruction_sub_gt_r4_r10_r6_LSR_r6,
3621   },
3622   {
3623     ARRAY_SIZE(kInstruction_sub_cc_r14_r8_r14_LSR_r8),
3624     kInstruction_sub_cc_r14_r8_r14_LSR_r8,
3625   },
3626   {
3627     ARRAY_SIZE(kInstruction_sub_al_r1_r14_r11_LSR_r7),
3628     kInstruction_sub_al_r1_r14_r11_LSR_r7,
3629   },
3630   {
3631     ARRAY_SIZE(kInstruction_sub_pl_r13_r6_r5_ASR_r14),
3632     kInstruction_sub_pl_r13_r6_r5_ASR_r14,
3633   },
3634   {
3635     ARRAY_SIZE(kInstruction_sub_cc_r10_r6_r9_ROR_r13),
3636     kInstruction_sub_cc_r10_r6_r9_ROR_r13,
3637   },
3638   {
3639     ARRAY_SIZE(kInstruction_sub_ne_r0_r4_r7_ROR_r13),
3640     kInstruction_sub_ne_r0_r4_r7_ROR_r13,
3641   },
3642   {
3643     ARRAY_SIZE(kInstruction_sub_vc_r12_r0_r14_LSL_r13),
3644     kInstruction_sub_vc_r12_r0_r14_LSL_r13,
3645   },
3646   {
3647     ARRAY_SIZE(kInstruction_sub_al_r10_r13_r13_ROR_r5),
3648     kInstruction_sub_al_r10_r13_r13_ROR_r5,
3649   },
3650   {
3651     ARRAY_SIZE(kInstruction_sub_cs_r10_r3_r0_ROR_r7),
3652     kInstruction_sub_cs_r10_r3_r0_ROR_r7,
3653   },
3654   {
3655     ARRAY_SIZE(kInstruction_sub_ge_r10_r14_r14_ROR_r6),
3656     kInstruction_sub_ge_r10_r14_r14_ROR_r6,
3657   },
3658   {
3659     ARRAY_SIZE(kInstruction_sub_pl_r0_r10_r10_LSL_r4),
3660     kInstruction_sub_pl_r0_r10_r10_LSL_r4,
3661   },
3662   {
3663     ARRAY_SIZE(kInstruction_sub_vs_r1_r2_r7_ASR_r6),
3664     kInstruction_sub_vs_r1_r2_r7_ASR_r6,
3665   },
3666   {
3667     ARRAY_SIZE(kInstruction_sub_cs_r9_r11_r9_LSL_r9),
3668     kInstruction_sub_cs_r9_r11_r9_LSL_r9,
3669   },
3670   {
3671     ARRAY_SIZE(kInstruction_sub_eq_r10_r8_r4_LSL_r6),
3672     kInstruction_sub_eq_r10_r8_r4_LSL_r6,
3673   },
3674   {
3675     ARRAY_SIZE(kInstruction_sub_vc_r8_r5_r12_LSL_r8),
3676     kInstruction_sub_vc_r8_r5_r12_LSL_r8,
3677   },
3678   {
3679     ARRAY_SIZE(kInstruction_sub_pl_r1_r13_r11_LSL_r8),
3680     kInstruction_sub_pl_r1_r13_r11_LSL_r8,
3681   },
3682   {
3683     ARRAY_SIZE(kInstruction_sub_le_r9_r10_r5_ROR_r4),
3684     kInstruction_sub_le_r9_r10_r5_ROR_r4,
3685   },
3686   {
3687     ARRAY_SIZE(kInstruction_sub_vs_r8_r3_r0_ASR_r11),
3688     kInstruction_sub_vs_r8_r3_r0_ASR_r11,
3689   },
3690   {
3691     ARRAY_SIZE(kInstruction_sub_hi_r12_r0_r13_LSL_r2),
3692     kInstruction_sub_hi_r12_r0_r13_LSL_r2,
3693   },
3694   {
3695     ARRAY_SIZE(kInstruction_sub_lt_r4_r2_r8_LSL_r5),
3696     kInstruction_sub_lt_r4_r2_r8_LSL_r5,
3697   },
3698   {
3699     ARRAY_SIZE(kInstruction_sub_ge_r9_r4_r13_LSL_r13),
3700     kInstruction_sub_ge_r9_r4_r13_LSL_r13,
3701   },
3702   {
3703     ARRAY_SIZE(kInstruction_sub_ge_r0_r2_r1_ROR_r8),
3704     kInstruction_sub_ge_r0_r2_r1_ROR_r8,
3705   },
3706   {
3707     ARRAY_SIZE(kInstruction_sub_le_r6_r13_r9_LSR_r0),
3708     kInstruction_sub_le_r6_r13_r9_LSR_r0,
3709   },
3710   {
3711     ARRAY_SIZE(kInstruction_sub_ls_r13_r7_r4_ASR_r3),
3712     kInstruction_sub_ls_r13_r7_r4_ASR_r3,
3713   },
3714   {
3715     ARRAY_SIZE(kInstruction_sub_vc_r8_r13_r6_LSR_r14),
3716     kInstruction_sub_vc_r8_r13_r6_LSR_r14,
3717   },
3718   {
3719     ARRAY_SIZE(kInstruction_sub_pl_r10_r5_r3_LSR_r9),
3720     kInstruction_sub_pl_r10_r5_r3_LSR_r9,
3721   },
3722   {
3723     ARRAY_SIZE(kInstruction_sub_al_r6_r3_r14_LSR_r7),
3724     kInstruction_sub_al_r6_r3_r14_LSR_r7,
3725   },
3726   {
3727     ARRAY_SIZE(kInstruction_sub_cc_r3_r5_r3_ROR_r10),
3728     kInstruction_sub_cc_r3_r5_r3_ROR_r10,
3729   },
3730   {
3731     ARRAY_SIZE(kInstruction_sub_cs_r4_r11_r2_LSR_r10),
3732     kInstruction_sub_cs_r4_r11_r2_LSR_r10,
3733   },
3734   {
3735     ARRAY_SIZE(kInstruction_sub_lt_r6_r10_r5_ASR_r8),
3736     kInstruction_sub_lt_r6_r10_r5_ASR_r8,
3737   },
3738   {
3739     ARRAY_SIZE(kInstruction_sub_ge_r0_r13_r10_ASR_r8),
3740     kInstruction_sub_ge_r0_r13_r10_ASR_r8,
3741   },
3742   {
3743     ARRAY_SIZE(kInstruction_sub_cs_r8_r8_r0_LSL_r9),
3744     kInstruction_sub_cs_r8_r8_r0_LSL_r9,
3745   },
3746   {
3747     ARRAY_SIZE(kInstruction_sub_gt_r1_r1_r1_ASR_r2),
3748     kInstruction_sub_gt_r1_r1_r1_ASR_r2,
3749   },
3750   {
3751     ARRAY_SIZE(kInstruction_sub_al_r5_r0_r14_ROR_r3),
3752     kInstruction_sub_al_r5_r0_r14_ROR_r3,
3753   },
3754   {
3755     ARRAY_SIZE(kInstruction_sub_mi_r3_r9_r14_LSL_r9),
3756     kInstruction_sub_mi_r3_r9_r14_LSL_r9,
3757   },
3758   {
3759     ARRAY_SIZE(kInstruction_sub_ls_r9_r6_r5_LSL_r9),
3760     kInstruction_sub_ls_r9_r6_r5_LSL_r9,
3761   },
3762   {
3763     ARRAY_SIZE(kInstruction_sub_lt_r13_r3_r1_LSL_r13),
3764     kInstruction_sub_lt_r13_r3_r1_LSL_r13,
3765   },
3766   {
3767     ARRAY_SIZE(kInstruction_sub_lt_r9_r14_r3_ASR_r3),
3768     kInstruction_sub_lt_r9_r14_r3_ASR_r3,
3769   },
3770   {
3771     ARRAY_SIZE(kInstruction_sub_cc_r5_r4_r1_LSR_r0),
3772     kInstruction_sub_cc_r5_r4_r1_LSR_r0,
3773   },
3774   {
3775     ARRAY_SIZE(kInstruction_sub_cs_r9_r7_r8_ASR_r0),
3776     kInstruction_sub_cs_r9_r7_r8_ASR_r0,
3777   },
3778   {
3779     ARRAY_SIZE(kInstruction_sub_ge_r8_r6_r14_ROR_r7),
3780     kInstruction_sub_ge_r8_r6_r14_ROR_r7,
3781   },
3782   {
3783     ARRAY_SIZE(kInstruction_sub_le_r14_r8_r12_LSL_r0),
3784     kInstruction_sub_le_r14_r8_r12_LSL_r0,
3785   },
3786   {
3787     ARRAY_SIZE(kInstruction_sub_mi_r0_r13_r14_ASR_r3),
3788     kInstruction_sub_mi_r0_r13_r14_ASR_r3,
3789   },
3790   {
3791     ARRAY_SIZE(kInstruction_sub_cs_r7_r4_r9_ROR_r8),
3792     kInstruction_sub_cs_r7_r4_r9_ROR_r8,
3793   },
3794   {
3795     ARRAY_SIZE(kInstruction_sub_ne_r4_r6_r11_ROR_r2),
3796     kInstruction_sub_ne_r4_r6_r11_ROR_r2,
3797   },
3798   {
3799     ARRAY_SIZE(kInstruction_sub_gt_r8_r8_r9_ROR_r12),
3800     kInstruction_sub_gt_r8_r8_r9_ROR_r12,
3801   },
3802   {
3803     ARRAY_SIZE(kInstruction_sub_hi_r1_r2_r0_LSR_r13),
3804     kInstruction_sub_hi_r1_r2_r0_LSR_r13,
3805   },
3806   {
3807     ARRAY_SIZE(kInstruction_sub_ge_r14_r12_r6_ASR_r5),
3808     kInstruction_sub_ge_r14_r12_r6_ASR_r5,
3809   },
3810   {
3811     ARRAY_SIZE(kInstruction_sub_ge_r5_r4_r7_LSR_r14),
3812     kInstruction_sub_ge_r5_r4_r7_LSR_r14,
3813   },
3814   {
3815     ARRAY_SIZE(kInstruction_sub_cc_r13_r11_r10_LSR_r2),
3816     kInstruction_sub_cc_r13_r11_r10_LSR_r2,
3817   },
3818   {
3819     ARRAY_SIZE(kInstruction_sub_mi_r3_r9_r14_LSR_r14),
3820     kInstruction_sub_mi_r3_r9_r14_LSR_r14,
3821   },
3822   {
3823     ARRAY_SIZE(kInstruction_sub_ne_r10_r3_r4_LSR_r3),
3824     kInstruction_sub_ne_r10_r3_r4_LSR_r3,
3825   },
3826   {
3827     ARRAY_SIZE(kInstruction_sub_ls_r14_r9_r6_LSL_r9),
3828     kInstruction_sub_ls_r14_r9_r6_LSL_r9,
3829   },
3830   {
3831     ARRAY_SIZE(kInstruction_sub_ls_r8_r2_r8_ROR_r7),
3832     kInstruction_sub_ls_r8_r2_r8_ROR_r7,
3833   },
3834   {
3835     ARRAY_SIZE(kInstruction_sub_ne_r2_r6_r3_ROR_r3),
3836     kInstruction_sub_ne_r2_r6_r3_ROR_r3,
3837   },
3838   {
3839     ARRAY_SIZE(kInstruction_sub_mi_r12_r3_r11_ASR_r11),
3840     kInstruction_sub_mi_r12_r3_r11_ASR_r11,
3841   },
3842   {
3843     ARRAY_SIZE(kInstruction_sub_le_r7_r10_r11_LSL_r9),
3844     kInstruction_sub_le_r7_r10_r11_LSL_r9,
3845   },
3846   {
3847     ARRAY_SIZE(kInstruction_sub_al_r1_r2_r10_ROR_r8),
3848     kInstruction_sub_al_r1_r2_r10_ROR_r8,
3849   },
3850   {
3851     ARRAY_SIZE(kInstruction_sub_cc_r7_r9_r14_LSL_r7),
3852     kInstruction_sub_cc_r7_r9_r14_LSL_r7,
3853   },
3854   {
3855     ARRAY_SIZE(kInstruction_sub_cc_r9_r3_r5_LSL_r8),
3856     kInstruction_sub_cc_r9_r3_r5_LSL_r8,
3857   },
3858   {
3859     ARRAY_SIZE(kInstruction_sub_hi_r8_r3_r8_ROR_r2),
3860     kInstruction_sub_hi_r8_r3_r8_ROR_r2,
3861   },
3862   {
3863     ARRAY_SIZE(kInstruction_sub_pl_r10_r13_r14_LSR_r10),
3864     kInstruction_sub_pl_r10_r13_r14_LSR_r10,
3865   },
3866   {
3867     ARRAY_SIZE(kInstruction_sub_lt_r13_r4_r13_LSR_r12),
3868     kInstruction_sub_lt_r13_r4_r13_LSR_r12,
3869   },
3870   {
3871     ARRAY_SIZE(kInstruction_sub_ls_r12_r14_r11_LSR_r13),
3872     kInstruction_sub_ls_r12_r14_r11_LSR_r13,
3873   },
3874   {
3875     ARRAY_SIZE(kInstruction_sub_vs_r11_r10_r10_ASR_r2),
3876     kInstruction_sub_vs_r11_r10_r10_ASR_r2,
3877   },
3878   {
3879     ARRAY_SIZE(kInstruction_sub_cc_r5_r8_r13_LSL_r10),
3880     kInstruction_sub_cc_r5_r8_r13_LSL_r10,
3881   },
3882   {
3883     ARRAY_SIZE(kInstruction_sub_cs_r7_r4_r11_LSR_r14),
3884     kInstruction_sub_cs_r7_r4_r11_LSR_r14,
3885   },
3886   {
3887     ARRAY_SIZE(kInstruction_sub_lt_r1_r12_r7_ASR_r11),
3888     kInstruction_sub_lt_r1_r12_r7_ASR_r11,
3889   },
3890   {
3891     ARRAY_SIZE(kInstruction_sub_vc_r11_r4_r4_LSL_r10),
3892     kInstruction_sub_vc_r11_r4_r4_LSL_r10,
3893   },
3894   {
3895     ARRAY_SIZE(kInstruction_sub_vc_r7_r4_r6_LSR_r7),
3896     kInstruction_sub_vc_r7_r4_r6_LSR_r7,
3897   },
3898   {
3899     ARRAY_SIZE(kInstruction_sub_vc_r0_r3_r0_ASR_r14),
3900     kInstruction_sub_vc_r0_r3_r0_ASR_r14,
3901   },
3902   {
3903     ARRAY_SIZE(kInstruction_sub_mi_r11_r8_r13_ASR_r8),
3904     kInstruction_sub_mi_r11_r8_r13_ASR_r8,
3905   },
3906   {
3907     ARRAY_SIZE(kInstruction_sub_gt_r13_r14_r6_LSL_r11),
3908     kInstruction_sub_gt_r13_r14_r6_LSL_r11,
3909   },
3910   {
3911     ARRAY_SIZE(kInstruction_sub_cs_r3_r2_r6_LSL_r8),
3912     kInstruction_sub_cs_r3_r2_r6_LSL_r8,
3913   },
3914   {
3915     ARRAY_SIZE(kInstruction_sub_ne_r7_r5_r5_LSL_r8),
3916     kInstruction_sub_ne_r7_r5_r5_LSL_r8,
3917   },
3918   {
3919     ARRAY_SIZE(kInstruction_sub_lt_r0_r12_r6_LSR_r0),
3920     kInstruction_sub_lt_r0_r12_r6_LSR_r0,
3921   },
3922   {
3923     ARRAY_SIZE(kInstruction_sub_ls_r11_r9_r12_ROR_r2),
3924     kInstruction_sub_ls_r11_r9_r12_ROR_r2,
3925   },
3926   {
3927     ARRAY_SIZE(kInstruction_sub_ls_r6_r0_r8_LSR_r4),
3928     kInstruction_sub_ls_r6_r0_r8_LSR_r4,
3929   },
3930   {
3931     ARRAY_SIZE(kInstruction_sub_lt_r6_r7_r0_ROR_r13),
3932     kInstruction_sub_lt_r6_r7_r0_ROR_r13,
3933   },
3934   {
3935     ARRAY_SIZE(kInstruction_sub_gt_r14_r4_r1_LSL_r8),
3936     kInstruction_sub_gt_r14_r4_r1_LSL_r8,
3937   },
3938   {
3939     ARRAY_SIZE(kInstruction_sub_al_r14_r5_r6_LSL_r7),
3940     kInstruction_sub_al_r14_r5_r6_LSL_r7,
3941   },
3942   {
3943     ARRAY_SIZE(kInstruction_sub_ge_r9_r6_r4_LSR_r8),
3944     kInstruction_sub_ge_r9_r6_r4_LSR_r8,
3945   },
3946   {
3947     ARRAY_SIZE(kInstruction_sub_lt_r2_r14_r13_ROR_r3),
3948     kInstruction_sub_lt_r2_r14_r13_ROR_r3,
3949   },
3950   {
3951     ARRAY_SIZE(kInstruction_sub_al_r11_r1_r13_LSR_r9),
3952     kInstruction_sub_al_r11_r1_r13_LSR_r9,
3953   },
3954   {
3955     ARRAY_SIZE(kInstruction_sub_vs_r8_r2_r5_LSL_r11),
3956     kInstruction_sub_vs_r8_r2_r5_LSL_r11,
3957   },
3958   {
3959     ARRAY_SIZE(kInstruction_sub_pl_r8_r14_r8_LSL_r7),
3960     kInstruction_sub_pl_r8_r14_r8_LSL_r7,
3961   },
3962   {
3963     ARRAY_SIZE(kInstruction_sub_cs_r10_r5_r5_ASR_r4),
3964     kInstruction_sub_cs_r10_r5_r5_ASR_r4,
3965   },
3966   {
3967     ARRAY_SIZE(kInstruction_sub_eq_r12_r14_r9_LSR_r11),
3968     kInstruction_sub_eq_r12_r14_r9_LSR_r11,
3969   },
3970   {
3971     ARRAY_SIZE(kInstruction_sub_lt_r1_r3_r3_LSL_r1),
3972     kInstruction_sub_lt_r1_r3_r3_LSL_r1,
3973   },
3974   {
3975     ARRAY_SIZE(kInstruction_sub_le_r4_r13_r4_ASR_r8),
3976     kInstruction_sub_le_r4_r13_r4_ASR_r8,
3977   },
3978   {
3979     ARRAY_SIZE(kInstruction_sub_ne_r5_r4_r2_LSL_r8),
3980     kInstruction_sub_ne_r5_r4_r2_LSL_r8,
3981   },
3982   {
3983     ARRAY_SIZE(kInstruction_sub_le_r3_r14_r13_LSR_r1),
3984     kInstruction_sub_le_r3_r14_r13_LSR_r1,
3985   },
3986   {
3987     ARRAY_SIZE(kInstruction_sub_cc_r6_r3_r5_LSL_r1),
3988     kInstruction_sub_cc_r6_r3_r5_LSL_r1,
3989   },
3990   {
3991     ARRAY_SIZE(kInstruction_sub_lt_r9_r6_r11_LSR_r14),
3992     kInstruction_sub_lt_r9_r6_r11_LSR_r14,
3993   },
3994   {
3995     ARRAY_SIZE(kInstruction_sub_cc_r13_r8_r10_ROR_r1),
3996     kInstruction_sub_cc_r13_r8_r10_ROR_r1,
3997   },
3998   {
3999     ARRAY_SIZE(kInstruction_sub_lt_r7_r10_r11_LSR_r2),
4000     kInstruction_sub_lt_r7_r10_r11_LSR_r2,
4001   },
4002   {
4003     ARRAY_SIZE(kInstruction_sub_pl_r0_r9_r5_LSR_r8),
4004     kInstruction_sub_pl_r0_r9_r5_LSR_r8,
4005   },
4006   {
4007     ARRAY_SIZE(kInstruction_sub_eq_r8_r9_r11_LSR_r13),
4008     kInstruction_sub_eq_r8_r9_r11_LSR_r13,
4009   },
4010   {
4011     ARRAY_SIZE(kInstruction_sub_hi_r10_r1_r9_ROR_r12),
4012     kInstruction_sub_hi_r10_r1_r9_ROR_r12,
4013   },
4014   {
4015     ARRAY_SIZE(kInstruction_sub_pl_r13_r1_r14_LSL_r14),
4016     kInstruction_sub_pl_r13_r1_r14_LSL_r14,
4017   },
4018   {
4019     ARRAY_SIZE(kInstruction_sub_eq_r13_r3_r7_LSR_r13),
4020     kInstruction_sub_eq_r13_r3_r7_LSR_r13,
4021   },
4022   {
4023     ARRAY_SIZE(kInstruction_sub_eq_r3_r6_r6_ASR_r14),
4024     kInstruction_sub_eq_r3_r6_r6_ASR_r14,
4025   },
4026   {
4027     ARRAY_SIZE(kInstruction_sub_gt_r5_r4_r8_ROR_r13),
4028     kInstruction_sub_gt_r5_r4_r8_ROR_r13,
4029   },
4030   {
4031     ARRAY_SIZE(kInstruction_sub_al_r9_r7_r0_ROR_r3),
4032     kInstruction_sub_al_r9_r7_r0_ROR_r3,
4033   },
4034   {
4035     ARRAY_SIZE(kInstruction_sub_mi_r13_r11_r3_LSL_r1),
4036     kInstruction_sub_mi_r13_r11_r3_LSL_r1,
4037   },
4038   {
4039     ARRAY_SIZE(kInstruction_sub_ls_r11_r14_r6_LSL_r14),
4040     kInstruction_sub_ls_r11_r14_r6_LSL_r14,
4041   },
4042   {
4043     ARRAY_SIZE(kInstruction_sub_al_r14_r3_r7_LSL_r9),
4044     kInstruction_sub_al_r14_r3_r7_LSL_r9,
4045   },
4046   {
4047     ARRAY_SIZE(kInstruction_sub_cs_r14_r2_r14_LSL_r13),
4048     kInstruction_sub_cs_r14_r2_r14_LSL_r13,
4049   },
4050   {
4051     ARRAY_SIZE(kInstruction_sub_ls_r11_r10_r6_ASR_r11),
4052     kInstruction_sub_ls_r11_r10_r6_ASR_r11,
4053   },
4054   {
4055     ARRAY_SIZE(kInstruction_sub_pl_r13_r4_r2_LSL_r4),
4056     kInstruction_sub_pl_r13_r4_r2_LSL_r4,
4057   },
4058   {
4059     ARRAY_SIZE(kInstruction_sub_mi_r8_r10_r5_ASR_r0),
4060     kInstruction_sub_mi_r8_r10_r5_ASR_r0,
4061   },
4062   {
4063     ARRAY_SIZE(kInstruction_sub_cs_r2_r1_r6_ASR_r4),
4064     kInstruction_sub_cs_r2_r1_r6_ASR_r4,
4065   },
4066   {
4067     ARRAY_SIZE(kInstruction_sub_cc_r0_r11_r8_LSR_r14),
4068     kInstruction_sub_cc_r0_r11_r8_LSR_r14,
4069   },
4070   {
4071     ARRAY_SIZE(kInstruction_sub_ge_r5_r4_r6_ROR_r1),
4072     kInstruction_sub_ge_r5_r4_r6_ROR_r1,
4073   },
4074   {
4075     ARRAY_SIZE(kInstruction_sub_cs_r0_r14_r3_LSR_r11),
4076     kInstruction_sub_cs_r0_r14_r3_LSR_r11,
4077   },
4078   {
4079     ARRAY_SIZE(kInstruction_sub_ge_r9_r4_r10_LSR_r13),
4080     kInstruction_sub_ge_r9_r4_r10_LSR_r13,
4081   },
4082   {
4083     ARRAY_SIZE(kInstruction_sub_ne_r11_r0_r9_LSL_r8),
4084     kInstruction_sub_ne_r11_r0_r9_LSL_r8,
4085   },
4086   {
4087     ARRAY_SIZE(kInstruction_sub_vs_r4_r1_r0_LSL_r8),
4088     kInstruction_sub_vs_r4_r1_r0_LSL_r8,
4089   },
4090   {
4091     ARRAY_SIZE(kInstruction_sub_le_r5_r5_r4_ROR_r10),
4092     kInstruction_sub_le_r5_r5_r4_ROR_r10,
4093   },
4094   {
4095     ARRAY_SIZE(kInstruction_sub_al_r9_r5_r0_ROR_r6),
4096     kInstruction_sub_al_r9_r5_r0_ROR_r6,
4097   },
4098   {
4099     ARRAY_SIZE(kInstruction_sub_hi_r6_r6_r9_LSR_r12),
4100     kInstruction_sub_hi_r6_r6_r9_LSR_r12,
4101   },
4102   {
4103     ARRAY_SIZE(kInstruction_sub_lt_r1_r4_r9_ROR_r4),
4104     kInstruction_sub_lt_r1_r4_r9_ROR_r4,
4105   },
4106   {
4107     ARRAY_SIZE(kInstruction_sub_vc_r4_r7_r0_ROR_r11),
4108     kInstruction_sub_vc_r4_r7_r0_ROR_r11,
4109   },
4110   {
4111     ARRAY_SIZE(kInstruction_sub_gt_r1_r4_r2_ROR_r8),
4112     kInstruction_sub_gt_r1_r4_r2_ROR_r8,
4113   },
4114   {
4115     ARRAY_SIZE(kInstruction_sub_ne_r4_r5_r9_LSL_r6),
4116     kInstruction_sub_ne_r4_r5_r9_LSL_r6,
4117   },
4118   {
4119     ARRAY_SIZE(kInstruction_sub_gt_r3_r4_r10_LSR_r5),
4120     kInstruction_sub_gt_r3_r4_r10_LSR_r5,
4121   },
4122   {
4123     ARRAY_SIZE(kInstruction_sub_al_r7_r9_r2_ROR_r2),
4124     kInstruction_sub_al_r7_r9_r2_ROR_r2,
4125   },
4126   {
4127     ARRAY_SIZE(kInstruction_sub_le_r3_r8_r2_LSL_r2),
4128     kInstruction_sub_le_r3_r8_r2_LSL_r2,
4129   },
4130   {
4131     ARRAY_SIZE(kInstruction_sub_hi_r3_r8_r0_LSL_r1),
4132     kInstruction_sub_hi_r3_r8_r0_LSL_r1,
4133   },
4134   {
4135     ARRAY_SIZE(kInstruction_sub_ge_r11_r4_r4_LSL_r14),
4136     kInstruction_sub_ge_r11_r4_r4_LSL_r14,
4137   },
4138   {
4139     ARRAY_SIZE(kInstruction_sub_mi_r8_r14_r1_LSR_r13),
4140     kInstruction_sub_mi_r8_r14_r1_LSR_r13,
4141   },
4142   {
4143     ARRAY_SIZE(kInstruction_sub_pl_r6_r1_r10_LSL_r0),
4144     kInstruction_sub_pl_r6_r1_r10_LSL_r0,
4145   },
4146   {
4147     ARRAY_SIZE(kInstruction_sub_eq_r11_r7_r13_LSL_r0),
4148     kInstruction_sub_eq_r11_r7_r13_LSL_r0,
4149   },
4150   {
4151     ARRAY_SIZE(kInstruction_sub_cc_r4_r9_r11_LSR_r1),
4152     kInstruction_sub_cc_r4_r9_r11_LSR_r1,
4153   },
4154   {
4155     ARRAY_SIZE(kInstruction_sub_cc_r8_r2_r3_LSR_r8),
4156     kInstruction_sub_cc_r8_r2_r3_LSR_r8,
4157   },
4158   {
4159     ARRAY_SIZE(kInstruction_sub_ne_r5_r1_r14_LSL_r12),
4160     kInstruction_sub_ne_r5_r1_r14_LSL_r12,
4161   },
4162   {
4163     ARRAY_SIZE(kInstruction_sub_le_r13_r5_r2_ASR_r1),
4164     kInstruction_sub_le_r13_r5_r2_ASR_r1,
4165   },
4166   {
4167     ARRAY_SIZE(kInstruction_sub_al_r0_r5_r0_LSL_r4),
4168     kInstruction_sub_al_r0_r5_r0_LSL_r4,
4169   },
4170   {
4171     ARRAY_SIZE(kInstruction_sub_mi_r3_r1_r4_LSR_r3),
4172     kInstruction_sub_mi_r3_r1_r4_LSR_r3,
4173   },
4174   {
4175     ARRAY_SIZE(kInstruction_sub_cs_r3_r7_r0_ROR_r8),
4176     kInstruction_sub_cs_r3_r7_r0_ROR_r8,
4177   },
4178   {
4179     ARRAY_SIZE(kInstruction_sub_cs_r11_r14_r4_LSR_r13),
4180     kInstruction_sub_cs_r11_r14_r4_LSR_r13,
4181   },
4182   {
4183     ARRAY_SIZE(kInstruction_sub_vs_r11_r10_r8_ASR_r3),
4184     kInstruction_sub_vs_r11_r10_r8_ASR_r3,
4185   },
4186   {
4187     ARRAY_SIZE(kInstruction_sub_gt_r10_r8_r9_LSL_r13),
4188     kInstruction_sub_gt_r10_r8_r9_LSL_r13,
4189   },
4190   {
4191     ARRAY_SIZE(kInstruction_sub_eq_r10_r1_r8_ASR_r9),
4192     kInstruction_sub_eq_r10_r1_r8_ASR_r9,
4193   },
4194   {
4195     ARRAY_SIZE(kInstruction_sub_al_r2_r1_r10_ASR_r8),
4196     kInstruction_sub_al_r2_r1_r10_ASR_r8,
4197   },
4198   {
4199     ARRAY_SIZE(kInstruction_sub_al_r7_r1_r7_ROR_r11),
4200     kInstruction_sub_al_r7_r1_r7_ROR_r11,
4201   },
4202   {
4203     ARRAY_SIZE(kInstruction_sub_cs_r0_r5_r6_ASR_r1),
4204     kInstruction_sub_cs_r0_r5_r6_ASR_r1,
4205   },
4206   {
4207     ARRAY_SIZE(kInstruction_sub_lt_r12_r11_r10_LSR_r14),
4208     kInstruction_sub_lt_r12_r11_r10_LSR_r14,
4209   },
4210   {
4211     ARRAY_SIZE(kInstruction_sub_pl_r13_r7_r5_LSL_r2),
4212     kInstruction_sub_pl_r13_r7_r5_LSL_r2,
4213   },
4214   {
4215     ARRAY_SIZE(kInstruction_sub_ne_r2_r0_r12_LSL_r11),
4216     kInstruction_sub_ne_r2_r0_r12_LSL_r11,
4217   },
4218   {
4219     ARRAY_SIZE(kInstruction_sub_ls_r14_r9_r12_ROR_r6),
4220     kInstruction_sub_ls_r14_r9_r12_ROR_r6,
4221   },
4222   {
4223     ARRAY_SIZE(kInstruction_sub_cc_r9_r2_r8_ASR_r3),
4224     kInstruction_sub_cc_r9_r2_r8_ASR_r3,
4225   },
4226   {
4227     ARRAY_SIZE(kInstruction_sub_pl_r12_r11_r0_ASR_r7),
4228     kInstruction_sub_pl_r12_r11_r0_ASR_r7,
4229   },
4230   {
4231     ARRAY_SIZE(kInstruction_sub_vs_r12_r2_r3_ROR_r1),
4232     kInstruction_sub_vs_r12_r2_r3_ROR_r1,
4233   },
4234   {
4235     ARRAY_SIZE(kInstruction_sub_al_r3_r1_r8_LSL_r4),
4236     kInstruction_sub_al_r3_r1_r8_LSL_r4,
4237   },
4238   {
4239     ARRAY_SIZE(kInstruction_sub_mi_r7_r9_r13_ASR_r5),
4240     kInstruction_sub_mi_r7_r9_r13_ASR_r5,
4241   },
4242   {
4243     ARRAY_SIZE(kInstruction_sub_vs_r13_r4_r10_ROR_r9),
4244     kInstruction_sub_vs_r13_r4_r10_ROR_r9,
4245   },
4246   {
4247     ARRAY_SIZE(kInstruction_sub_eq_r8_r2_r3_LSR_r2),
4248     kInstruction_sub_eq_r8_r2_r3_LSR_r2,
4249   },
4250   {
4251     ARRAY_SIZE(kInstruction_sub_cs_r0_r3_r11_LSR_r7),
4252     kInstruction_sub_cs_r0_r3_r11_LSR_r7,
4253   },
4254   {
4255     ARRAY_SIZE(kInstruction_sub_pl_r2_r10_r9_ASR_r13),
4256     kInstruction_sub_pl_r2_r10_r9_ASR_r13,
4257   },
4258   {
4259     ARRAY_SIZE(kInstruction_sub_eq_r14_r0_r7_ASR_r0),
4260     kInstruction_sub_eq_r14_r0_r7_ASR_r0,
4261   },
4262   {
4263     ARRAY_SIZE(kInstruction_sub_lt_r12_r11_r7_ROR_r7),
4264     kInstruction_sub_lt_r12_r11_r7_ROR_r7,
4265   },
4266   {
4267     ARRAY_SIZE(kInstruction_sub_eq_r4_r10_r1_LSL_r2),
4268     kInstruction_sub_eq_r4_r10_r1_LSL_r2,
4269   },
4270   {
4271     ARRAY_SIZE(kInstruction_sub_al_r7_r14_r12_ASR_r6),
4272     kInstruction_sub_al_r7_r14_r12_ASR_r6,
4273   },
4274   {
4275     ARRAY_SIZE(kInstruction_sub_al_r2_r5_r13_ASR_r1),
4276     kInstruction_sub_al_r2_r5_r13_ASR_r1,
4277   },
4278   {
4279     ARRAY_SIZE(kInstruction_sub_hi_r0_r3_r14_LSL_r11),
4280     kInstruction_sub_hi_r0_r3_r14_LSL_r11,
4281   },
4282   {
4283     ARRAY_SIZE(kInstruction_sub_vs_r5_r6_r9_LSR_r13),
4284     kInstruction_sub_vs_r5_r6_r9_LSR_r13,
4285   },
4286   {
4287     ARRAY_SIZE(kInstruction_sub_hi_r14_r0_r14_ROR_r14),
4288     kInstruction_sub_hi_r14_r0_r14_ROR_r14,
4289   },
4290   {
4291     ARRAY_SIZE(kInstruction_sub_eq_r9_r3_r13_ROR_r9),
4292     kInstruction_sub_eq_r9_r3_r13_ROR_r9,
4293   },
4294   {
4295     ARRAY_SIZE(kInstruction_sub_hi_r6_r8_r1_ASR_r14),
4296     kInstruction_sub_hi_r6_r8_r1_ASR_r14,
4297   },
4298   {
4299     ARRAY_SIZE(kInstruction_sub_vs_r13_r2_r8_LSR_r7),
4300     kInstruction_sub_vs_r13_r2_r8_LSR_r7,
4301   },
4302   {
4303     ARRAY_SIZE(kInstruction_sub_cc_r13_r0_r8_LSR_r7),
4304     kInstruction_sub_cc_r13_r0_r8_LSR_r7,
4305   },
4306   {
4307     ARRAY_SIZE(kInstruction_sub_le_r12_r0_r11_ASR_r9),
4308     kInstruction_sub_le_r12_r0_r11_ASR_r9,
4309   },
4310   {
4311     ARRAY_SIZE(kInstruction_sub_le_r8_r8_r1_LSR_r6),
4312     kInstruction_sub_le_r8_r8_r1_LSR_r6,
4313   },
4314   {
4315     ARRAY_SIZE(kInstruction_sub_cs_r5_r14_r7_ASR_r3),
4316     kInstruction_sub_cs_r5_r14_r7_ASR_r3,
4317   },
4318   {
4319     ARRAY_SIZE(kInstruction_sub_eq_r13_r13_r10_ROR_r12),
4320     kInstruction_sub_eq_r13_r13_r10_ROR_r12,
4321   },
4322   {
4323     ARRAY_SIZE(kInstruction_sub_lt_r4_r7_r7_LSR_r5),
4324     kInstruction_sub_lt_r4_r7_r7_LSR_r5,
4325   },
4326   {
4327     ARRAY_SIZE(kInstruction_sub_le_r6_r13_r10_LSR_r2),
4328     kInstruction_sub_le_r6_r13_r10_LSR_r2,
4329   },
4330   {
4331     ARRAY_SIZE(kInstruction_sub_eq_r10_r13_r10_ASR_r8),
4332     kInstruction_sub_eq_r10_r13_r10_ASR_r8,
4333   },
4334   {
4335     ARRAY_SIZE(kInstruction_sub_ne_r6_r5_r12_LSR_r12),
4336     kInstruction_sub_ne_r6_r5_r12_LSR_r12,
4337   },
4338   {
4339     ARRAY_SIZE(kInstruction_sub_vc_r10_r8_r10_ROR_r8),
4340     kInstruction_sub_vc_r10_r8_r10_ROR_r8,
4341   },
4342   {
4343     ARRAY_SIZE(kInstruction_sub_gt_r10_r1_r8_LSR_r1),
4344     kInstruction_sub_gt_r10_r1_r8_LSR_r1,
4345   },
4346   {
4347     ARRAY_SIZE(kInstruction_sub_pl_r5_r12_r9_LSR_r13),
4348     kInstruction_sub_pl_r5_r12_r9_LSR_r13,
4349   },
4350   {
4351     ARRAY_SIZE(kInstruction_sub_gt_r10_r6_r4_ROR_r12),
4352     kInstruction_sub_gt_r10_r6_r4_ROR_r12,
4353   },
4354   {
4355     ARRAY_SIZE(kInstruction_sub_cs_r14_r10_r10_ASR_r6),
4356     kInstruction_sub_cs_r14_r10_r10_ASR_r6,
4357   },
4358   {
4359     ARRAY_SIZE(kInstruction_sub_le_r6_r8_r2_ROR_r7),
4360     kInstruction_sub_le_r6_r8_r2_ROR_r7,
4361   },
4362   {
4363     ARRAY_SIZE(kInstruction_sub_le_r13_r12_r0_ROR_r14),
4364     kInstruction_sub_le_r13_r12_r0_ROR_r14,
4365   },
4366   {
4367     ARRAY_SIZE(kInstruction_sub_le_r7_r6_r0_ASR_r10),
4368     kInstruction_sub_le_r7_r6_r0_ASR_r10,
4369   },
4370   {
4371     ARRAY_SIZE(kInstruction_sub_cs_r10_r4_r1_ASR_r10),
4372     kInstruction_sub_cs_r10_r4_r1_ASR_r10,
4373   },
4374   {
4375     ARRAY_SIZE(kInstruction_sub_ne_r12_r9_r11_ASR_r6),
4376     kInstruction_sub_ne_r12_r9_r11_ASR_r6,
4377   },
4378   {
4379     ARRAY_SIZE(kInstruction_sub_vs_r9_r14_r6_ASR_r12),
4380     kInstruction_sub_vs_r9_r14_r6_ASR_r12,
4381   },
4382   {
4383     ARRAY_SIZE(kInstruction_sub_mi_r1_r8_r0_ASR_r7),
4384     kInstruction_sub_mi_r1_r8_r0_ASR_r7,
4385   },
4386   {
4387     ARRAY_SIZE(kInstruction_sub_gt_r11_r2_r3_ROR_r11),
4388     kInstruction_sub_gt_r11_r2_r3_ROR_r11,
4389   },
4390   {
4391     ARRAY_SIZE(kInstruction_sub_cs_r3_r1_r12_LSR_r0),
4392     kInstruction_sub_cs_r3_r1_r12_LSR_r0,
4393   },
4394   {
4395     ARRAY_SIZE(kInstruction_sub_hi_r12_r14_r11_LSL_r2),
4396     kInstruction_sub_hi_r12_r14_r11_LSL_r2,
4397   },
4398   {
4399     ARRAY_SIZE(kInstruction_sub_mi_r10_r11_r14_LSL_r10),
4400     kInstruction_sub_mi_r10_r11_r14_LSL_r10,
4401   },
4402   {
4403     ARRAY_SIZE(kInstruction_sub_al_r11_r6_r13_ASR_r2),
4404     kInstruction_sub_al_r11_r6_r13_ASR_r2,
4405   },
4406   {
4407     ARRAY_SIZE(kInstruction_sub_gt_r2_r14_r3_ROR_r6),
4408     kInstruction_sub_gt_r2_r14_r3_ROR_r6,
4409   },
4410   {
4411     ARRAY_SIZE(kInstruction_sub_hi_r1_r10_r6_LSR_r6),
4412     kInstruction_sub_hi_r1_r10_r6_LSR_r6,
4413   },
4414   {
4415     ARRAY_SIZE(kInstruction_sub_gt_r2_r8_r3_LSL_r6),
4416     kInstruction_sub_gt_r2_r8_r3_LSL_r6,
4417   },
4418   {
4419     ARRAY_SIZE(kInstruction_sub_ls_r13_r4_r12_ROR_r13),
4420     kInstruction_sub_ls_r13_r4_r12_ROR_r13,
4421   },
4422   {
4423     ARRAY_SIZE(kInstruction_sub_vs_r13_r11_r7_ROR_r8),
4424     kInstruction_sub_vs_r13_r11_r7_ROR_r8,
4425   },
4426   {
4427     ARRAY_SIZE(kInstruction_sub_hi_r5_r12_r14_LSR_r3),
4428     kInstruction_sub_hi_r5_r12_r14_LSR_r3,
4429   },
4430   {
4431     ARRAY_SIZE(kInstruction_sub_cs_r14_r8_r3_ROR_r13),
4432     kInstruction_sub_cs_r14_r8_r3_ROR_r13,
4433   },
4434   {
4435     ARRAY_SIZE(kInstruction_sub_cs_r9_r10_r0_LSL_r10),
4436     kInstruction_sub_cs_r9_r10_r0_LSL_r10,
4437   },
4438   {
4439     ARRAY_SIZE(kInstruction_sub_lt_r0_r13_r12_ASR_r5),
4440     kInstruction_sub_lt_r0_r13_r12_ASR_r5,
4441   },
4442   {
4443     ARRAY_SIZE(kInstruction_sub_cs_r4_r5_r7_ROR_r7),
4444     kInstruction_sub_cs_r4_r5_r7_ROR_r7,
4445   },
4446   {
4447     ARRAY_SIZE(kInstruction_sub_lt_r0_r14_r7_LSR_r7),
4448     kInstruction_sub_lt_r0_r14_r7_LSR_r7,
4449   },
4450   {
4451     ARRAY_SIZE(kInstruction_sub_hi_r10_r5_r3_LSL_r10),
4452     kInstruction_sub_hi_r10_r5_r3_LSL_r10,
4453   },
4454   {
4455     ARRAY_SIZE(kInstruction_sub_ls_r6_r2_r4_ROR_r0),
4456     kInstruction_sub_ls_r6_r2_r4_ROR_r0,
4457   },
4458   {
4459     ARRAY_SIZE(kInstruction_sub_hi_r9_r7_r7_ASR_r10),
4460     kInstruction_sub_hi_r9_r7_r7_ASR_r10,
4461   },
4462   {
4463     ARRAY_SIZE(kInstruction_sub_cc_r0_r9_r4_LSR_r2),
4464     kInstruction_sub_cc_r0_r9_r4_LSR_r2,
4465   },
4466   {
4467     ARRAY_SIZE(kInstruction_sub_le_r3_r14_r2_ASR_r0),
4468     kInstruction_sub_le_r3_r14_r2_ASR_r0,
4469   },
4470   {
4471     ARRAY_SIZE(kInstruction_sub_pl_r2_r8_r7_LSL_r13),
4472     kInstruction_sub_pl_r2_r8_r7_LSL_r13,
4473   },
4474   {
4475     ARRAY_SIZE(kInstruction_sub_al_r10_r1_r9_LSR_r6),
4476     kInstruction_sub_al_r10_r1_r9_LSR_r6,
4477   },
4478   {
4479     ARRAY_SIZE(kInstruction_sub_vs_r1_r6_r14_ASR_r14),
4480     kInstruction_sub_vs_r1_r6_r14_ASR_r14,
4481   },
4482   {
4483     ARRAY_SIZE(kInstruction_sub_lt_r3_r3_r13_LSR_r0),
4484     kInstruction_sub_lt_r3_r3_r13_LSR_r0,
4485   },
4486   {
4487     ARRAY_SIZE(kInstruction_sub_le_r9_r3_r2_ASR_r11),
4488     kInstruction_sub_le_r9_r3_r2_ASR_r11,
4489   },
4490   {
4491     ARRAY_SIZE(kInstruction_sub_mi_r4_r14_r6_LSL_r11),
4492     kInstruction_sub_mi_r4_r14_r6_LSL_r11,
4493   },
4494   {
4495     ARRAY_SIZE(kInstruction_sub_ne_r7_r5_r14_ASR_r9),
4496     kInstruction_sub_ne_r7_r5_r14_ASR_r9,
4497   },
4498   {
4499     ARRAY_SIZE(kInstruction_sub_cs_r11_r11_r13_LSR_r11),
4500     kInstruction_sub_cs_r11_r11_r13_LSR_r11,
4501   },
4502   {
4503     ARRAY_SIZE(kInstruction_sub_lt_r12_r9_r5_LSR_r9),
4504     kInstruction_sub_lt_r12_r9_r5_LSR_r9,
4505   },
4506   {
4507     ARRAY_SIZE(kInstruction_sub_hi_r13_r1_r10_LSL_r4),
4508     kInstruction_sub_hi_r13_r1_r10_LSL_r4,
4509   },
4510   {
4511     ARRAY_SIZE(kInstruction_sub_mi_r14_r6_r8_ASR_r14),
4512     kInstruction_sub_mi_r14_r6_r8_ASR_r14,
4513   },
4514   {
4515     ARRAY_SIZE(kInstruction_sub_vc_r3_r2_r6_ASR_r3),
4516     kInstruction_sub_vc_r3_r2_r6_ASR_r3,
4517   },
4518   {
4519     ARRAY_SIZE(kInstruction_sub_ne_r13_r14_r0_ASR_r2),
4520     kInstruction_sub_ne_r13_r14_r0_ASR_r2,
4521   },
4522   {
4523     ARRAY_SIZE(kInstruction_sub_gt_r2_r14_r5_ROR_r1),
4524     kInstruction_sub_gt_r2_r14_r5_ROR_r1,
4525   },
4526   {
4527     ARRAY_SIZE(kInstruction_sub_ls_r7_r7_r9_LSR_r10),
4528     kInstruction_sub_ls_r7_r7_r9_LSR_r10,
4529   },
4530   {
4531     ARRAY_SIZE(kInstruction_sub_gt_r2_r12_r8_ASR_r5),
4532     kInstruction_sub_gt_r2_r12_r8_ASR_r5,
4533   },
4534   {
4535     ARRAY_SIZE(kInstruction_sub_lt_r13_r2_r11_ROR_r6),
4536     kInstruction_sub_lt_r13_r2_r11_ROR_r6,
4537   },
4538   {
4539     ARRAY_SIZE(kInstruction_sub_cc_r2_r13_r13_ASR_r1),
4540     kInstruction_sub_cc_r2_r13_r13_ASR_r1,
4541   },
4542   {
4543     ARRAY_SIZE(kInstruction_sub_vs_r0_r6_r14_ROR_r3),
4544     kInstruction_sub_vs_r0_r6_r14_ROR_r3,
4545   },
4546   {
4547     ARRAY_SIZE(kInstruction_sub_vs_r2_r13_r8_LSL_r9),
4548     kInstruction_sub_vs_r2_r13_r8_LSL_r9,
4549   },
4550   {
4551     ARRAY_SIZE(kInstruction_sub_pl_r2_r12_r12_ROR_r6),
4552     kInstruction_sub_pl_r2_r12_r12_ROR_r6,
4553   },
4554   {
4555     ARRAY_SIZE(kInstruction_sub_vc_r4_r0_r12_ASR_r13),
4556     kInstruction_sub_vc_r4_r0_r12_ASR_r13,
4557   },
4558   {
4559     ARRAY_SIZE(kInstruction_sub_mi_r8_r12_r7_ASR_r7),
4560     kInstruction_sub_mi_r8_r12_r7_ASR_r7,
4561   },
4562   {
4563     ARRAY_SIZE(kInstruction_sub_al_r13_r5_r0_LSL_r5),
4564     kInstruction_sub_al_r13_r5_r0_LSL_r5,
4565   },
4566   {
4567     ARRAY_SIZE(kInstruction_sub_le_r9_r1_r12_LSR_r8),
4568     kInstruction_sub_le_r9_r1_r12_LSR_r8,
4569   },
4570   {
4571     ARRAY_SIZE(kInstruction_sub_vs_r5_r10_r13_ROR_r1),
4572     kInstruction_sub_vs_r5_r10_r13_ROR_r1,
4573   },
4574   {
4575     ARRAY_SIZE(kInstruction_sub_vs_r8_r5_r0_LSR_r11),
4576     kInstruction_sub_vs_r8_r5_r0_LSR_r11,
4577   },
4578   {
4579     ARRAY_SIZE(kInstruction_sub_ne_r7_r2_r0_LSL_r4),
4580     kInstruction_sub_ne_r7_r2_r0_LSL_r4,
4581   },
4582   {
4583     ARRAY_SIZE(kInstruction_sub_lt_r6_r6_r9_LSL_r10),
4584     kInstruction_sub_lt_r6_r6_r9_LSL_r10,
4585   },
4586   {
4587     ARRAY_SIZE(kInstruction_sub_cs_r13_r3_r4_ROR_r12),
4588     kInstruction_sub_cs_r13_r3_r4_ROR_r12,
4589   },
4590   {
4591     ARRAY_SIZE(kInstruction_sub_ne_r11_r11_r0_LSL_r7),
4592     kInstruction_sub_ne_r11_r11_r0_LSL_r7,
4593   },
4594   {
4595     ARRAY_SIZE(kInstruction_sub_pl_r3_r14_r12_LSR_r13),
4596     kInstruction_sub_pl_r3_r14_r12_LSR_r13,
4597   },
4598   {
4599     ARRAY_SIZE(kInstruction_sub_al_r2_r14_r3_LSL_r11),
4600     kInstruction_sub_al_r2_r14_r3_LSL_r11,
4601   },
4602   {
4603     ARRAY_SIZE(kInstruction_sub_vc_r4_r6_r3_LSR_r7),
4604     kInstruction_sub_vc_r4_r6_r3_LSR_r7,
4605   },
4606   {
4607     ARRAY_SIZE(kInstruction_sub_ls_r6_r2_r1_LSR_r6),
4608     kInstruction_sub_ls_r6_r2_r1_LSR_r6,
4609   },
4610   {
4611     ARRAY_SIZE(kInstruction_sub_le_r0_r2_r5_ASR_r3),
4612     kInstruction_sub_le_r0_r2_r5_ASR_r3,
4613   },
4614   {
4615     ARRAY_SIZE(kInstruction_sub_ge_r12_r9_r12_ROR_r13),
4616     kInstruction_sub_ge_r12_r9_r12_ROR_r13,
4617   },
4618   {
4619     ARRAY_SIZE(kInstruction_sub_cc_r10_r5_r3_ROR_r12),
4620     kInstruction_sub_cc_r10_r5_r3_ROR_r12,
4621   },
4622   {
4623     ARRAY_SIZE(kInstruction_sub_mi_r14_r0_r10_ASR_r4),
4624     kInstruction_sub_mi_r14_r0_r10_ASR_r4,
4625   },
4626   {
4627     ARRAY_SIZE(kInstruction_sub_al_r12_r0_r3_ROR_r13),
4628     kInstruction_sub_al_r12_r0_r3_ROR_r13,
4629   },
4630   {
4631     ARRAY_SIZE(kInstruction_sub_hi_r1_r8_r13_ASR_r2),
4632     kInstruction_sub_hi_r1_r8_r13_ASR_r2,
4633   },
4634   {
4635     ARRAY_SIZE(kInstruction_sub_ls_r7_r9_r9_ASR_r2),
4636     kInstruction_sub_ls_r7_r9_r9_ASR_r2,
4637   },
4638   {
4639     ARRAY_SIZE(kInstruction_sub_ls_r9_r13_r6_ROR_r11),
4640     kInstruction_sub_ls_r9_r13_r6_ROR_r11,
4641   },
4642   {
4643     ARRAY_SIZE(kInstruction_sub_pl_r11_r12_r14_LSL_r14),
4644     kInstruction_sub_pl_r11_r12_r14_LSL_r14,
4645   },
4646   {
4647     ARRAY_SIZE(kInstruction_sub_eq_r1_r3_r10_ASR_r9),
4648     kInstruction_sub_eq_r1_r3_r10_ASR_r9,
4649   },
4650   {
4651     ARRAY_SIZE(kInstruction_sub_al_r1_r6_r6_LSL_r9),
4652     kInstruction_sub_al_r1_r6_r6_LSL_r9,
4653   },
4654   {
4655     ARRAY_SIZE(kInstruction_sub_ne_r4_r14_r7_ROR_r12),
4656     kInstruction_sub_ne_r4_r14_r7_ROR_r12,
4657   },
4658   {
4659     ARRAY_SIZE(kInstruction_sub_vc_r2_r13_r1_ROR_r7),
4660     kInstruction_sub_vc_r2_r13_r1_ROR_r7,
4661   },
4662   {
4663     ARRAY_SIZE(kInstruction_sub_cs_r13_r12_r8_LSR_r11),
4664     kInstruction_sub_cs_r13_r12_r8_LSR_r11,
4665   },
4666   {
4667     ARRAY_SIZE(kInstruction_sub_le_r10_r14_r12_LSL_r4),
4668     kInstruction_sub_le_r10_r14_r12_LSL_r4,
4669   },
4670   {
4671     ARRAY_SIZE(kInstruction_sub_cs_r14_r9_r4_ROR_r13),
4672     kInstruction_sub_cs_r14_r9_r4_ROR_r13,
4673   },
4674   {
4675     ARRAY_SIZE(kInstruction_sub_ge_r10_r12_r8_ASR_r14),
4676     kInstruction_sub_ge_r10_r12_r8_ASR_r14,
4677   },
4678   {
4679     ARRAY_SIZE(kInstruction_sub_cs_r14_r10_r3_LSL_r13),
4680     kInstruction_sub_cs_r14_r10_r3_LSL_r13,
4681   },
4682   {
4683     ARRAY_SIZE(kInstruction_sub_lt_r4_r3_r10_LSR_r2),
4684     kInstruction_sub_lt_r4_r3_r10_LSR_r2,
4685   },
4686   {
4687     ARRAY_SIZE(kInstruction_sub_ls_r13_r12_r8_ASR_r14),
4688     kInstruction_sub_ls_r13_r12_r8_ASR_r14,
4689   },
4690   {
4691     ARRAY_SIZE(kInstruction_sub_ge_r3_r2_r0_ASR_r8),
4692     kInstruction_sub_ge_r3_r2_r0_ASR_r8,
4693   },
4694   {
4695     ARRAY_SIZE(kInstruction_sub_vs_r3_r7_r1_LSL_r0),
4696     kInstruction_sub_vs_r3_r7_r1_LSL_r0,
4697   },
4698   {
4699     ARRAY_SIZE(kInstruction_sub_lt_r5_r13_r7_LSR_r7),
4700     kInstruction_sub_lt_r5_r13_r7_LSR_r7,
4701   },
4702   {
4703     ARRAY_SIZE(kInstruction_sub_ls_r8_r4_r3_ROR_r14),
4704     kInstruction_sub_ls_r8_r4_r3_ROR_r14,
4705   },
4706   {
4707     ARRAY_SIZE(kInstruction_sub_vc_r5_r4_r13_LSL_r12),
4708     kInstruction_sub_vc_r5_r4_r13_LSL_r12,
4709   },
4710   {
4711     ARRAY_SIZE(kInstruction_sub_pl_r6_r10_r11_LSR_r2),
4712     kInstruction_sub_pl_r6_r10_r11_LSR_r2,
4713   },
4714   {
4715     ARRAY_SIZE(kInstruction_sub_ne_r4_r0_r6_ASR_r10),
4716     kInstruction_sub_ne_r4_r0_r6_ASR_r10,
4717   },
4718   {
4719     ARRAY_SIZE(kInstruction_sub_vc_r2_r6_r7_LSR_r4),
4720     kInstruction_sub_vc_r2_r6_r7_LSR_r4,
4721   },
4722   {
4723     ARRAY_SIZE(kInstruction_sub_pl_r4_r12_r1_ROR_r14),
4724     kInstruction_sub_pl_r4_r12_r1_ROR_r14,
4725   },
4726   {
4727     ARRAY_SIZE(kInstruction_sub_cs_r13_r1_r10_LSL_r12),
4728     kInstruction_sub_cs_r13_r1_r10_LSL_r12,
4729   },
4730   {
4731     ARRAY_SIZE(kInstruction_sub_al_r7_r12_r7_LSL_r10),
4732     kInstruction_sub_al_r7_r12_r7_LSL_r10,
4733   },
4734   {
4735     ARRAY_SIZE(kInstruction_sub_ge_r1_r9_r13_LSR_r8),
4736     kInstruction_sub_ge_r1_r9_r13_LSR_r8,
4737   },
4738   {
4739     ARRAY_SIZE(kInstruction_sub_eq_r12_r5_r11_ASR_r2),
4740     kInstruction_sub_eq_r12_r5_r11_ASR_r2,
4741   },
4742   {
4743     ARRAY_SIZE(kInstruction_sub_ls_r7_r9_r3_ASR_r14),
4744     kInstruction_sub_ls_r7_r9_r3_ASR_r14,
4745   },
4746   {
4747     ARRAY_SIZE(kInstruction_sub_pl_r5_r10_r3_LSL_r12),
4748     kInstruction_sub_pl_r5_r10_r3_LSL_r12,
4749   },
4750   {
4751     ARRAY_SIZE(kInstruction_sub_vs_r5_r14_r11_ASR_r13),
4752     kInstruction_sub_vs_r5_r14_r11_ASR_r13,
4753   },
4754   {
4755     ARRAY_SIZE(kInstruction_sub_al_r9_r2_r8_LSR_r10),
4756     kInstruction_sub_al_r9_r2_r8_LSR_r10,
4757   },
4758   {
4759     ARRAY_SIZE(kInstruction_sub_cc_r11_r12_r6_ROR_r11),
4760     kInstruction_sub_cc_r11_r12_r6_ROR_r11,
4761   },
4762   {
4763     ARRAY_SIZE(kInstruction_sub_ge_r10_r3_r1_LSR_r5),
4764     kInstruction_sub_ge_r10_r3_r1_LSR_r5,
4765   },
4766   {
4767     ARRAY_SIZE(kInstruction_sub_lt_r13_r4_r7_ROR_r0),
4768     kInstruction_sub_lt_r13_r4_r7_ROR_r0,
4769   },
4770   {
4771     ARRAY_SIZE(kInstruction_sub_ne_r2_r12_r12_LSR_r0),
4772     kInstruction_sub_ne_r2_r12_r12_LSR_r0,
4773   },
4774   {
4775     ARRAY_SIZE(kInstruction_sub_gt_r2_r10_r14_ASR_r10),
4776     kInstruction_sub_gt_r2_r10_r14_ASR_r10,
4777   },
4778   {
4779     ARRAY_SIZE(kInstruction_sub_cc_r5_r6_r10_ASR_r11),
4780     kInstruction_sub_cc_r5_r6_r10_ASR_r11,
4781   },
4782   {
4783     ARRAY_SIZE(kInstruction_sub_hi_r8_r13_r1_ROR_r9),
4784     kInstruction_sub_hi_r8_r13_r1_ROR_r9,
4785   },
4786   {
4787     ARRAY_SIZE(kInstruction_sub_cc_r3_r1_r14_LSR_r3),
4788     kInstruction_sub_cc_r3_r1_r14_LSR_r3,
4789   },
4790   {
4791     ARRAY_SIZE(kInstruction_sub_lt_r11_r9_r8_ASR_r13),
4792     kInstruction_sub_lt_r11_r9_r8_ASR_r13,
4793   },
4794   {
4795     ARRAY_SIZE(kInstruction_sub_mi_r0_r3_r13_ASR_r5),
4796     kInstruction_sub_mi_r0_r3_r13_ASR_r5,
4797   },
4798   {
4799     ARRAY_SIZE(kInstruction_sub_vc_r7_r6_r10_ASR_r6),
4800     kInstruction_sub_vc_r7_r6_r10_ASR_r6,
4801   },
4802   {
4803     ARRAY_SIZE(kInstruction_sub_mi_r2_r6_r4_LSL_r9),
4804     kInstruction_sub_mi_r2_r6_r4_LSL_r9,
4805   },
4806   {
4807     ARRAY_SIZE(kInstruction_sub_ne_r12_r9_r4_ROR_r6),
4808     kInstruction_sub_ne_r12_r9_r4_ROR_r6,
4809   },
4810   {
4811     ARRAY_SIZE(kInstruction_sub_hi_r4_r3_r0_ROR_r4),
4812     kInstruction_sub_hi_r4_r3_r0_ROR_r4,
4813   },
4814   {
4815     ARRAY_SIZE(kInstruction_sub_gt_r9_r2_r11_LSL_r13),
4816     kInstruction_sub_gt_r9_r2_r11_LSL_r13,
4817   },
4818   {
4819     ARRAY_SIZE(kInstruction_sub_eq_r14_r4_r3_LSL_r10),
4820     kInstruction_sub_eq_r14_r4_r3_LSL_r10,
4821   },
4822   {
4823     ARRAY_SIZE(kInstruction_sub_le_r8_r2_r12_LSL_r10),
4824     kInstruction_sub_le_r8_r2_r12_LSL_r10,
4825   },
4826   {
4827     ARRAY_SIZE(kInstruction_sub_ls_r8_r0_r1_ASR_r8),
4828     kInstruction_sub_ls_r8_r0_r1_ASR_r8,
4829   },
4830   {
4831     ARRAY_SIZE(kInstruction_sub_cc_r13_r9_r7_LSR_r3),
4832     kInstruction_sub_cc_r13_r9_r7_LSR_r3,
4833   },
4834   {
4835     ARRAY_SIZE(kInstruction_sub_gt_r6_r0_r7_ROR_r9),
4836     kInstruction_sub_gt_r6_r0_r7_ROR_r9,
4837   },
4838   {
4839     ARRAY_SIZE(kInstruction_sub_hi_r14_r12_r6_LSR_r12),
4840     kInstruction_sub_hi_r14_r12_r6_LSR_r12,
4841   },
4842   {
4843     ARRAY_SIZE(kInstruction_sub_cs_r3_r7_r10_LSR_r8),
4844     kInstruction_sub_cs_r3_r7_r10_LSR_r8,
4845   },
4846   {
4847     ARRAY_SIZE(kInstruction_sub_le_r7_r7_r7_LSL_r11),
4848     kInstruction_sub_le_r7_r7_r7_LSL_r11,
4849   },
4850   {
4851     ARRAY_SIZE(kInstruction_sub_le_r11_r11_r14_ASR_r3),
4852     kInstruction_sub_le_r11_r11_r14_ASR_r3,
4853   },
4854   {
4855     ARRAY_SIZE(kInstruction_sub_vc_r13_r5_r6_LSL_r13),
4856     kInstruction_sub_vc_r13_r5_r6_LSL_r13,
4857   },
4858   {
4859     ARRAY_SIZE(kInstruction_sub_cc_r12_r3_r12_LSL_r8),
4860     kInstruction_sub_cc_r12_r3_r12_LSL_r8,
4861   },
4862   {
4863     ARRAY_SIZE(kInstruction_sub_gt_r4_r14_r12_ASR_r11),
4864     kInstruction_sub_gt_r4_r14_r12_ASR_r11,
4865   },
4866   {
4867     ARRAY_SIZE(kInstruction_sub_cs_r9_r6_r7_LSL_r10),
4868     kInstruction_sub_cs_r9_r6_r7_LSL_r10,
4869   },
4870   {
4871     ARRAY_SIZE(kInstruction_sub_ge_r9_r5_r3_ROR_r5),
4872     kInstruction_sub_ge_r9_r5_r3_ROR_r5,
4873   },
4874   {
4875     ARRAY_SIZE(kInstruction_sub_vc_r4_r5_r14_LSR_r4),
4876     kInstruction_sub_vc_r4_r5_r14_LSR_r4,
4877   },
4878   {
4879     ARRAY_SIZE(kInstruction_sub_ne_r13_r12_r2_ASR_r14),
4880     kInstruction_sub_ne_r13_r12_r2_ASR_r14,
4881   },
4882   {
4883     ARRAY_SIZE(kInstruction_sub_gt_r2_r9_r11_LSR_r13),
4884     kInstruction_sub_gt_r2_r9_r11_LSR_r13,
4885   },
4886   {
4887     ARRAY_SIZE(kInstruction_sub_mi_r10_r11_r8_LSR_r1),
4888     kInstruction_sub_mi_r10_r11_r8_LSR_r1,
4889   },
4890   {
4891     ARRAY_SIZE(kInstruction_sub_hi_r6_r8_r1_ASR_r6),
4892     kInstruction_sub_hi_r6_r8_r1_ASR_r6,
4893   },
4894   {
4895     ARRAY_SIZE(kInstruction_sub_eq_r10_r12_r5_ROR_r11),
4896     kInstruction_sub_eq_r10_r12_r5_ROR_r11,
4897   },
4898   {
4899     ARRAY_SIZE(kInstruction_sub_mi_r9_r6_r4_LSL_r1),
4900     kInstruction_sub_mi_r9_r6_r4_LSL_r1,
4901   },
4902   {
4903     ARRAY_SIZE(kInstruction_sub_vc_r14_r6_r0_ROR_r7),
4904     kInstruction_sub_vc_r14_r6_r0_ROR_r7,
4905   },
4906   {
4907     ARRAY_SIZE(kInstruction_sub_mi_r10_r3_r12_LSL_r2),
4908     kInstruction_sub_mi_r10_r3_r12_LSL_r2,
4909   },
4910   {
4911     ARRAY_SIZE(kInstruction_sub_pl_r9_r6_r9_LSR_r14),
4912     kInstruction_sub_pl_r9_r6_r9_LSR_r14,
4913   },
4914   {
4915     ARRAY_SIZE(kInstruction_sub_al_r10_r5_r10_ROR_r1),
4916     kInstruction_sub_al_r10_r5_r10_ROR_r1,
4917   },
4918   {
4919     ARRAY_SIZE(kInstruction_sub_ne_r9_r6_r2_ASR_r3),
4920     kInstruction_sub_ne_r9_r6_r2_ASR_r3,
4921   },
4922   {
4923     ARRAY_SIZE(kInstruction_sub_hi_r4_r9_r4_LSL_r6),
4924     kInstruction_sub_hi_r4_r9_r4_LSL_r6,
4925   },
4926   {
4927     ARRAY_SIZE(kInstruction_sub_vs_r1_r9_r7_ASR_r7),
4928     kInstruction_sub_vs_r1_r9_r7_ASR_r7,
4929   },
4930   {
4931     ARRAY_SIZE(kInstruction_sub_ne_r10_r13_r9_ASR_r14),
4932     kInstruction_sub_ne_r10_r13_r9_ASR_r14,
4933   },
4934   {
4935     ARRAY_SIZE(kInstruction_sub_gt_r11_r13_r12_ASR_r12),
4936     kInstruction_sub_gt_r11_r13_r12_ASR_r12,
4937   },
4938   {
4939     ARRAY_SIZE(kInstruction_sub_lt_r3_r5_r0_LSR_r10),
4940     kInstruction_sub_lt_r3_r5_r0_LSR_r10,
4941   },
4942   {
4943     ARRAY_SIZE(kInstruction_sub_gt_r4_r8_r13_ROR_r7),
4944     kInstruction_sub_gt_r4_r8_r13_ROR_r7,
4945   },
4946   {
4947     ARRAY_SIZE(kInstruction_sub_ls_r14_r14_r0_ASR_r3),
4948     kInstruction_sub_ls_r14_r14_r0_ASR_r3,
4949   },
4950   {
4951     ARRAY_SIZE(kInstruction_sub_vc_r2_r7_r9_ASR_r5),
4952     kInstruction_sub_vc_r2_r7_r9_ASR_r5,
4953   },
4954   {
4955     ARRAY_SIZE(kInstruction_sub_mi_r9_r3_r10_LSR_r10),
4956     kInstruction_sub_mi_r9_r3_r10_LSR_r10,
4957   },
4958   {
4959     ARRAY_SIZE(kInstruction_sub_gt_r11_r10_r3_ASR_r11),
4960     kInstruction_sub_gt_r11_r10_r3_ASR_r11,
4961   },
4962   {
4963     ARRAY_SIZE(kInstruction_sub_cc_r3_r14_r2_ROR_r12),
4964     kInstruction_sub_cc_r3_r14_r2_ROR_r12,
4965   },
4966   {
4967     ARRAY_SIZE(kInstruction_sub_ls_r3_r5_r14_ROR_r12),
4968     kInstruction_sub_ls_r3_r5_r14_ROR_r12,
4969   },
4970   {
4971     ARRAY_SIZE(kInstruction_sub_al_r6_r0_r11_ASR_r0),
4972     kInstruction_sub_al_r6_r0_r11_ASR_r0,
4973   },
4974   {
4975     ARRAY_SIZE(kInstruction_sub_al_r14_r12_r13_LSL_r8),
4976     kInstruction_sub_al_r14_r12_r13_LSL_r8,
4977   },
4978   {
4979     ARRAY_SIZE(kInstruction_sub_cs_r12_r9_r14_ROR_r4),
4980     kInstruction_sub_cs_r12_r9_r14_ROR_r4,
4981   },
4982   {
4983     ARRAY_SIZE(kInstruction_sub_vs_r4_r9_r6_LSL_r10),
4984     kInstruction_sub_vs_r4_r9_r6_LSL_r10,
4985   },
4986   {
4987     ARRAY_SIZE(kInstruction_sub_eq_r6_r1_r4_ASR_r6),
4988     kInstruction_sub_eq_r6_r1_r4_ASR_r6,
4989   },
4990   {
4991     ARRAY_SIZE(kInstruction_sub_ge_r6_r11_r2_LSR_r10),
4992     kInstruction_sub_ge_r6_r11_r2_LSR_r10,
4993   },
4994   {
4995     ARRAY_SIZE(kInstruction_sub_cc_r10_r14_r4_LSR_r0),
4996     kInstruction_sub_cc_r10_r14_r4_LSR_r0,
4997   },
4998   {
4999     ARRAY_SIZE(kInstruction_sub_ge_r0_r12_r1_ROR_r5),
5000     kInstruction_sub_ge_r0_r12_r1_ROR_r5,
5001   },
5002   {
5003     ARRAY_SIZE(kInstruction_sub_ls_r1_r13_r10_ASR_r5),
5004     kInstruction_sub_ls_r1_r13_r10_ASR_r5,
5005   },
5006   {
5007     ARRAY_SIZE(kInstruction_sub_cc_r9_r8_r5_ASR_r5),
5008     kInstruction_sub_cc_r9_r8_r5_ASR_r5,
5009   },
5010   {
5011     ARRAY_SIZE(kInstruction_sub_ls_r6_r5_r1_LSL_r11),
5012     kInstruction_sub_ls_r6_r5_r1_LSL_r11,
5013   },
5014   {
5015     ARRAY_SIZE(kInstruction_sub_ne_r2_r12_r1_ROR_r10),
5016     kInstruction_sub_ne_r2_r12_r1_ROR_r10,
5017   },
5018   {
5019     ARRAY_SIZE(kInstruction_sub_cc_r2_r9_r9_LSR_r1),
5020     kInstruction_sub_cc_r2_r9_r9_LSR_r1,
5021   },
5022   {
5023     ARRAY_SIZE(kInstruction_sub_ne_r1_r8_r1_ASR_r14),
5024     kInstruction_sub_ne_r1_r8_r1_ASR_r14,
5025   },
5026   {
5027     ARRAY_SIZE(kInstruction_sub_lt_r9_r2_r1_LSR_r10),
5028     kInstruction_sub_lt_r9_r2_r1_LSR_r10,
5029   },
5030   {
5031     ARRAY_SIZE(kInstruction_sub_cc_r14_r11_r9_ROR_r6),
5032     kInstruction_sub_cc_r14_r11_r9_ROR_r6,
5033   },
5034   {
5035     ARRAY_SIZE(kInstruction_sub_eq_r3_r12_r13_ASR_r0),
5036     kInstruction_sub_eq_r3_r12_r13_ASR_r0,
5037   },
5038   {
5039     ARRAY_SIZE(kInstruction_sub_le_r6_r6_r6_ASR_r2),
5040     kInstruction_sub_le_r6_r6_r6_ASR_r2,
5041   },
5042   {
5043     ARRAY_SIZE(kInstruction_sub_mi_r11_r14_r4_ASR_r1),
5044     kInstruction_sub_mi_r11_r14_r4_ASR_r1,
5045   },
5046   {
5047     ARRAY_SIZE(kInstruction_sub_ls_r5_r9_r10_LSL_r9),
5048     kInstruction_sub_ls_r5_r9_r10_LSL_r9,
5049   },
5050   {
5051     ARRAY_SIZE(kInstruction_sub_vc_r12_r9_r3_LSR_r10),
5052     kInstruction_sub_vc_r12_r9_r3_LSR_r10,
5053   },
5054   {
5055     ARRAY_SIZE(kInstruction_sub_lt_r12_r0_r4_ASR_r0),
5056     kInstruction_sub_lt_r12_r0_r4_ASR_r0,
5057   },
5058   {
5059     ARRAY_SIZE(kInstruction_sub_mi_r0_r10_r6_ROR_r9),
5060     kInstruction_sub_mi_r0_r10_r6_ROR_r9,
5061   },
5062   {
5063     ARRAY_SIZE(kInstruction_sub_hi_r7_r10_r1_LSL_r7),
5064     kInstruction_sub_hi_r7_r10_r1_LSL_r7,
5065   },
5066   {
5067     ARRAY_SIZE(kInstruction_sub_ls_r2_r0_r14_ROR_r5),
5068     kInstruction_sub_ls_r2_r0_r14_ROR_r5,
5069   },
5070   {
5071     ARRAY_SIZE(kInstruction_sub_cs_r12_r14_r12_LSR_r10),
5072     kInstruction_sub_cs_r12_r14_r12_LSR_r10,
5073   },
5074   {
5075     ARRAY_SIZE(kInstruction_sub_le_r9_r0_r6_ROR_r2),
5076     kInstruction_sub_le_r9_r0_r6_ROR_r2,
5077   },
5078   {
5079     ARRAY_SIZE(kInstruction_sub_cc_r3_r10_r4_LSR_r12),
5080     kInstruction_sub_cc_r3_r10_r4_LSR_r12,
5081   },
5082   {
5083     ARRAY_SIZE(kInstruction_sub_mi_r4_r5_r2_ASR_r14),
5084     kInstruction_sub_mi_r4_r5_r2_ASR_r14,
5085   },
5086   {
5087     ARRAY_SIZE(kInstruction_sub_vc_r12_r8_r10_ROR_r14),
5088     kInstruction_sub_vc_r12_r8_r10_ROR_r14,
5089   },
5090   {
5091     ARRAY_SIZE(kInstruction_sub_al_r5_r14_r4_ASR_r10),
5092     kInstruction_sub_al_r5_r14_r4_ASR_r10,
5093   },
5094   {
5095     ARRAY_SIZE(kInstruction_sub_ls_r13_r8_r3_ASR_r1),
5096     kInstruction_sub_ls_r13_r8_r3_ASR_r1,
5097   },
5098   {
5099     ARRAY_SIZE(kInstruction_sub_le_r10_r1_r2_LSR_r4),
5100     kInstruction_sub_le_r10_r1_r2_LSR_r4,
5101   },
5102   {
5103     ARRAY_SIZE(kInstruction_sub_ne_r0_r2_r10_ROR_r7),
5104     kInstruction_sub_ne_r0_r2_r10_ROR_r7,
5105   },
5106   {
5107     ARRAY_SIZE(kInstruction_sub_vs_r11_r13_r11_LSR_r12),
5108     kInstruction_sub_vs_r11_r13_r11_LSR_r12,
5109   },
5110   {
5111     ARRAY_SIZE(kInstruction_sub_vs_r10_r10_r8_ROR_r8),
5112     kInstruction_sub_vs_r10_r10_r8_ROR_r8,
5113   },
5114   {
5115     ARRAY_SIZE(kInstruction_sub_ne_r7_r2_r9_LSL_r11),
5116     kInstruction_sub_ne_r7_r2_r9_LSL_r11,
5117   },
5118   {
5119     ARRAY_SIZE(kInstruction_sub_mi_r5_r12_r11_ASR_r5),
5120     kInstruction_sub_mi_r5_r12_r11_ASR_r5,
5121   },
5122   {
5123     ARRAY_SIZE(kInstruction_sub_le_r1_r10_r5_ROR_r5),
5124     kInstruction_sub_le_r1_r10_r5_ROR_r5,
5125   },
5126   {
5127     ARRAY_SIZE(kInstruction_sub_cc_r3_r14_r3_ASR_r6),
5128     kInstruction_sub_cc_r3_r14_r3_ASR_r6,
5129   },
5130   {
5131     ARRAY_SIZE(kInstruction_sub_vc_r4_r4_r0_ROR_r2),
5132     kInstruction_sub_vc_r4_r4_r0_ROR_r2,
5133   },
5134   {
5135     ARRAY_SIZE(kInstruction_sub_le_r3_r4_r12_ROR_r14),
5136     kInstruction_sub_le_r3_r4_r12_ROR_r14,
5137   },
5138   {
5139     ARRAY_SIZE(kInstruction_sub_al_r3_r7_r14_LSL_r11),
5140     kInstruction_sub_al_r3_r7_r14_LSL_r11,
5141   },
5142   {
5143     ARRAY_SIZE(kInstruction_sub_vc_r8_r11_r0_LSL_r11),
5144     kInstruction_sub_vc_r8_r11_r0_LSL_r11,
5145   },
5146   {
5147     ARRAY_SIZE(kInstruction_sub_vs_r12_r9_r14_LSR_r2),
5148     kInstruction_sub_vs_r12_r9_r14_LSR_r2,
5149   },
5150   {
5151     ARRAY_SIZE(kInstruction_sub_hi_r3_r5_r5_ROR_r6),
5152     kInstruction_sub_hi_r3_r5_r5_ROR_r6,
5153   },
5154   {
5155     ARRAY_SIZE(kInstruction_sub_cs_r9_r3_r13_ASR_r7),
5156     kInstruction_sub_cs_r9_r3_r13_ASR_r7,
5157   },
5158   {
5159     ARRAY_SIZE(kInstruction_sub_eq_r14_r3_r6_LSR_r5),
5160     kInstruction_sub_eq_r14_r3_r6_LSR_r5,
5161   },
5162   {
5163     ARRAY_SIZE(kInstruction_sub_lt_r8_r3_r4_LSR_r13),
5164     kInstruction_sub_lt_r8_r3_r4_LSR_r13,
5165   },
5166   {
5167     ARRAY_SIZE(kInstruction_sub_vc_r7_r4_r12_ROR_r6),
5168     kInstruction_sub_vc_r7_r4_r12_ROR_r6,
5169   },
5170   {
5171     ARRAY_SIZE(kInstruction_sub_vs_r5_r3_r3_ASR_r1),
5172     kInstruction_sub_vs_r5_r3_r3_ASR_r1,
5173   },
5174   {
5175     ARRAY_SIZE(kInstruction_sub_le_r5_r6_r1_ROR_r7),
5176     kInstruction_sub_le_r5_r6_r1_ROR_r7,
5177   },
5178   {
5179     ARRAY_SIZE(kInstruction_sub_ge_r11_r5_r11_LSL_r12),
5180     kInstruction_sub_ge_r11_r5_r11_LSL_r12,
5181   },
5182   {
5183     ARRAY_SIZE(kInstruction_sub_lt_r0_r3_r7_ASR_r14),
5184     kInstruction_sub_lt_r0_r3_r7_ASR_r14,
5185   },
5186   {
5187     ARRAY_SIZE(kInstruction_sub_cs_r9_r2_r10_LSL_r1),
5188     kInstruction_sub_cs_r9_r2_r10_LSL_r1,
5189   },
5190   {
5191     ARRAY_SIZE(kInstruction_sub_cs_r6_r8_r6_ASR_r1),
5192     kInstruction_sub_cs_r6_r8_r6_ASR_r1,
5193   },
5194   {
5195     ARRAY_SIZE(kInstruction_sub_lt_r0_r11_r14_ASR_r5),
5196     kInstruction_sub_lt_r0_r11_r14_ASR_r5,
5197   },
5198   {
5199     ARRAY_SIZE(kInstruction_sub_ge_r11_r11_r2_ASR_r3),
5200     kInstruction_sub_ge_r11_r11_r2_ASR_r3,
5201   },
5202   {
5203     ARRAY_SIZE(kInstruction_sub_lt_r0_r0_r14_LSL_r2),
5204     kInstruction_sub_lt_r0_r0_r14_LSL_r2,
5205   },
5206   {
5207     ARRAY_SIZE(kInstruction_sub_cs_r8_r9_r11_ROR_r8),
5208     kInstruction_sub_cs_r8_r9_r11_ROR_r8,
5209   },
5210   {
5211     ARRAY_SIZE(kInstruction_sub_pl_r9_r5_r12_ASR_r14),
5212     kInstruction_sub_pl_r9_r5_r12_ASR_r14,
5213   },
5214   {
5215     ARRAY_SIZE(kInstruction_sub_eq_r13_r11_r1_LSR_r1),
5216     kInstruction_sub_eq_r13_r11_r1_LSR_r1,
5217   },
5218   {
5219     ARRAY_SIZE(kInstruction_sub_ne_r1_r0_r13_ROR_r0),
5220     kInstruction_sub_ne_r1_r0_r13_ROR_r0,
5221   },
5222   {
5223     ARRAY_SIZE(kInstruction_sub_hi_r6_r5_r9_LSR_r10),
5224     kInstruction_sub_hi_r6_r5_r9_LSR_r10,
5225   },
5226   {
5227     ARRAY_SIZE(kInstruction_sub_lt_r4_r7_r7_ASR_r9),
5228     kInstruction_sub_lt_r4_r7_r7_ASR_r9,
5229   },
5230   {
5231     ARRAY_SIZE(kInstruction_sub_ls_r13_r13_r5_LSR_r1),
5232     kInstruction_sub_ls_r13_r13_r5_LSR_r1,
5233   },
5234   {
5235     ARRAY_SIZE(kInstruction_sub_cs_r12_r1_r6_LSR_r14),
5236     kInstruction_sub_cs_r12_r1_r6_LSR_r14,
5237   },
5238   {
5239     ARRAY_SIZE(kInstruction_sub_hi_r11_r0_r5_LSR_r3),
5240     kInstruction_sub_hi_r11_r0_r5_LSR_r3,
5241   },
5242   {
5243     ARRAY_SIZE(kInstruction_sub_ne_r5_r2_r14_LSR_r1),
5244     kInstruction_sub_ne_r5_r2_r14_LSR_r1,
5245   },
5246   {
5247     ARRAY_SIZE(kInstruction_sub_le_r6_r12_r9_LSR_r5),
5248     kInstruction_sub_le_r6_r12_r9_LSR_r5,
5249   },
5250   {
5251     ARRAY_SIZE(kInstruction_sub_cs_r1_r11_r1_LSL_r2),
5252     kInstruction_sub_cs_r1_r11_r1_LSL_r2,
5253   },
5254   {
5255     ARRAY_SIZE(kInstruction_sub_al_r14_r10_r8_ASR_r4),
5256     kInstruction_sub_al_r14_r10_r8_ASR_r4,
5257   },
5258   {
5259     ARRAY_SIZE(kInstruction_sub_al_r11_r10_r8_LSL_r6),
5260     kInstruction_sub_al_r11_r10_r8_LSL_r6,
5261   },
5262   {
5263     ARRAY_SIZE(kInstruction_sub_vs_r1_r2_r1_LSL_r11),
5264     kInstruction_sub_vs_r1_r2_r1_LSL_r11,
5265   },
5266   {
5267     ARRAY_SIZE(kInstruction_sub_cs_r10_r14_r14_LSL_r0),
5268     kInstruction_sub_cs_r10_r14_r14_LSL_r0,
5269   },
5270   {
5271     ARRAY_SIZE(kInstruction_sub_pl_r0_r1_r14_ROR_r10),
5272     kInstruction_sub_pl_r0_r1_r14_ROR_r10,
5273   },
5274   {
5275     ARRAY_SIZE(kInstruction_sub_pl_r3_r7_r5_LSR_r1),
5276     kInstruction_sub_pl_r3_r7_r5_LSR_r1,
5277   },
5278   {
5279     ARRAY_SIZE(kInstruction_sub_gt_r2_r14_r10_LSL_r6),
5280     kInstruction_sub_gt_r2_r14_r10_LSL_r6,
5281   },
5282   {
5283     ARRAY_SIZE(kInstruction_sub_le_r7_r7_r8_ROR_r0),
5284     kInstruction_sub_le_r7_r7_r8_ROR_r0,
5285   },
5286   {
5287     ARRAY_SIZE(kInstruction_sub_cs_r7_r9_r8_LSL_r14),
5288     kInstruction_sub_cs_r7_r9_r8_LSL_r14,
5289   },
5290   {
5291     ARRAY_SIZE(kInstruction_sub_cs_r11_r4_r3_LSR_r10),
5292     kInstruction_sub_cs_r11_r4_r3_LSR_r10,
5293   },
5294   {
5295     ARRAY_SIZE(kInstruction_sub_cc_r9_r1_r12_ROR_r4),
5296     kInstruction_sub_cc_r9_r1_r12_ROR_r4,
5297   },
5298   {
5299     ARRAY_SIZE(kInstruction_sub_hi_r10_r0_r10_LSL_r8),
5300     kInstruction_sub_hi_r10_r0_r10_LSL_r8,
5301   },
5302   {
5303     ARRAY_SIZE(kInstruction_sub_eq_r14_r1_r0_LSL_r11),
5304     kInstruction_sub_eq_r14_r1_r0_LSL_r11,
5305   },
5306   {
5307     ARRAY_SIZE(kInstruction_sub_mi_r9_r11_r5_ROR_r5),
5308     kInstruction_sub_mi_r9_r11_r5_ROR_r5,
5309   },
5310   {
5311     ARRAY_SIZE(kInstruction_sub_le_r5_r9_r2_LSL_r1),
5312     kInstruction_sub_le_r5_r9_r2_LSL_r1,
5313   },
5314   {
5315     ARRAY_SIZE(kInstruction_sub_pl_r7_r7_r8_ASR_r13),
5316     kInstruction_sub_pl_r7_r7_r8_ASR_r13,
5317   },
5318   {
5319     ARRAY_SIZE(kInstruction_sub_gt_r14_r13_r10_ASR_r11),
5320     kInstruction_sub_gt_r14_r13_r10_ASR_r11,
5321   },
5322   {
5323     ARRAY_SIZE(kInstruction_sub_cs_r4_r6_r5_LSR_r7),
5324     kInstruction_sub_cs_r4_r6_r5_LSR_r7,
5325   },
5326   {
5327     ARRAY_SIZE(kInstruction_sub_lt_r2_r7_r7_LSL_r6),
5328     kInstruction_sub_lt_r2_r7_r7_LSL_r6,
5329   },
5330   {
5331     ARRAY_SIZE(kInstruction_sub_al_r4_r5_r2_ROR_r5),
5332     kInstruction_sub_al_r4_r5_r2_ROR_r5,
5333   },
5334   {
5335     ARRAY_SIZE(kInstruction_sub_cc_r6_r2_r9_ROR_r7),
5336     kInstruction_sub_cc_r6_r2_r9_ROR_r7,
5337   },
5338   {
5339     ARRAY_SIZE(kInstruction_sub_pl_r4_r0_r0_LSR_r11),
5340     kInstruction_sub_pl_r4_r0_r0_LSR_r11,
5341   },
5342   {
5343     ARRAY_SIZE(kInstruction_sub_pl_r6_r10_r12_LSL_r11),
5344     kInstruction_sub_pl_r6_r10_r12_LSL_r11,
5345   },
5346   {
5347     ARRAY_SIZE(kInstruction_sub_al_r0_r14_r1_LSR_r6),
5348     kInstruction_sub_al_r0_r14_r1_LSR_r6,
5349   },
5350   {
5351     ARRAY_SIZE(kInstruction_sub_cs_r7_r9_r13_LSR_r1),
5352     kInstruction_sub_cs_r7_r9_r13_LSR_r1,
5353   },
5354   {
5355     ARRAY_SIZE(kInstruction_sub_al_r4_r2_r10_ROR_r3),
5356     kInstruction_sub_al_r4_r2_r10_ROR_r3,
5357   },
5358   {
5359     ARRAY_SIZE(kInstruction_sub_gt_r12_r4_r14_ROR_r7),
5360     kInstruction_sub_gt_r12_r4_r14_ROR_r7,
5361   },
5362   {
5363     ARRAY_SIZE(kInstruction_sub_cs_r11_r0_r14_ASR_r7),
5364     kInstruction_sub_cs_r11_r0_r14_ASR_r7,
5365   },
5366   {
5367     ARRAY_SIZE(kInstruction_sub_pl_r0_r2_r4_ASR_r14),
5368     kInstruction_sub_pl_r0_r2_r4_ASR_r14,
5369   },
5370   {
5371     ARRAY_SIZE(kInstruction_sub_mi_r14_r4_r9_LSR_r5),
5372     kInstruction_sub_mi_r14_r4_r9_LSR_r5,
5373   },
5374   {
5375     ARRAY_SIZE(kInstruction_sub_ge_r13_r0_r1_ROR_r5),
5376     kInstruction_sub_ge_r13_r0_r1_ROR_r5,
5377   },
5378   {
5379     ARRAY_SIZE(kInstruction_sub_eq_r12_r14_r0_LSL_r11),
5380     kInstruction_sub_eq_r12_r14_r0_LSL_r11,
5381   },
5382   {
5383     ARRAY_SIZE(kInstruction_sub_ge_r6_r4_r10_ROR_r13),
5384     kInstruction_sub_ge_r6_r4_r10_ROR_r13,
5385   },
5386   {
5387     ARRAY_SIZE(kInstruction_sub_lt_r3_r7_r2_ASR_r5),
5388     kInstruction_sub_lt_r3_r7_r2_ASR_r5,
5389   },
5390   {
5391     ARRAY_SIZE(kInstruction_sub_al_r9_r0_r12_ROR_r0),
5392     kInstruction_sub_al_r9_r0_r12_ROR_r0,
5393   },
5394   {
5395     ARRAY_SIZE(kInstruction_sub_le_r1_r9_r7_LSL_r12),
5396     kInstruction_sub_le_r1_r9_r7_LSL_r12,
5397   },
5398   {
5399     ARRAY_SIZE(kInstruction_sub_lt_r14_r7_r4_ASR_r7),
5400     kInstruction_sub_lt_r14_r7_r4_ASR_r7,
5401   },
5402   {
5403     ARRAY_SIZE(kInstruction_sub_ne_r4_r6_r9_LSR_r8),
5404     kInstruction_sub_ne_r4_r6_r9_LSR_r8,
5405   },
5406   {
5407     ARRAY_SIZE(kInstruction_sub_cc_r0_r5_r1_ASR_r6),
5408     kInstruction_sub_cc_r0_r5_r1_ASR_r6,
5409   },
5410   {
5411     ARRAY_SIZE(kInstruction_sub_cc_r2_r13_r2_ROR_r6),
5412     kInstruction_sub_cc_r2_r13_r2_ROR_r6,
5413   },
5414   {
5415     ARRAY_SIZE(kInstruction_sub_ge_r10_r0_r9_ROR_r6),
5416     kInstruction_sub_ge_r10_r0_r9_ROR_r6,
5417   },
5418   {
5419     ARRAY_SIZE(kInstruction_sub_gt_r8_r1_r11_LSR_r0),
5420     kInstruction_sub_gt_r8_r1_r11_LSR_r0,
5421   },
5422   {
5423     ARRAY_SIZE(kInstruction_sub_al_r14_r0_r9_LSL_r0),
5424     kInstruction_sub_al_r14_r0_r9_LSL_r0,
5425   },
5426   {
5427     ARRAY_SIZE(kInstruction_sub_hi_r12_r3_r12_ROR_r9),
5428     kInstruction_sub_hi_r12_r3_r12_ROR_r9,
5429   },
5430   {
5431     ARRAY_SIZE(kInstruction_sub_eq_r4_r12_r3_LSL_r2),
5432     kInstruction_sub_eq_r4_r12_r3_LSL_r2,
5433   },
5434   {
5435     ARRAY_SIZE(kInstruction_sub_ne_r5_r3_r4_LSL_r4),
5436     kInstruction_sub_ne_r5_r3_r4_LSL_r4,
5437   },
5438   {
5439     ARRAY_SIZE(kInstruction_sub_vc_r8_r6_r10_LSL_r11),
5440     kInstruction_sub_vc_r8_r6_r10_LSL_r11,
5441   },
5442   {
5443     ARRAY_SIZE(kInstruction_sub_lt_r0_r1_r4_ASR_r3),
5444     kInstruction_sub_lt_r0_r1_r4_ASR_r3,
5445   },
5446   {
5447     ARRAY_SIZE(kInstruction_sub_le_r14_r4_r1_ROR_r7),
5448     kInstruction_sub_le_r14_r4_r1_ROR_r7,
5449   },
5450   {
5451     ARRAY_SIZE(kInstruction_sub_al_r12_r12_r5_LSL_r2),
5452     kInstruction_sub_al_r12_r12_r5_LSL_r2,
5453   },
5454   {
5455     ARRAY_SIZE(kInstruction_sub_eq_r10_r3_r10_ROR_r13),
5456     kInstruction_sub_eq_r10_r3_r10_ROR_r13,
5457   },
5458   {
5459     ARRAY_SIZE(kInstruction_sub_ne_r7_r10_r1_LSR_r14),
5460     kInstruction_sub_ne_r7_r10_r1_LSR_r14,
5461   },
5462   {
5463     ARRAY_SIZE(kInstruction_sub_lt_r10_r4_r10_LSR_r5),
5464     kInstruction_sub_lt_r10_r4_r10_LSR_r5,
5465   },
5466   {
5467     ARRAY_SIZE(kInstruction_sub_pl_r0_r14_r0_LSL_r2),
5468     kInstruction_sub_pl_r0_r14_r0_LSL_r2,
5469   },
5470   {
5471     ARRAY_SIZE(kInstruction_sub_gt_r7_r4_r11_LSL_r3),
5472     kInstruction_sub_gt_r7_r4_r11_LSL_r3,
5473   },
5474   {
5475     ARRAY_SIZE(kInstruction_sub_cs_r8_r2_r1_LSR_r8),
5476     kInstruction_sub_cs_r8_r2_r1_LSR_r8,
5477   },
5478   {
5479     ARRAY_SIZE(kInstruction_sub_pl_r9_r11_r4_ASR_r7),
5480     kInstruction_sub_pl_r9_r11_r4_ASR_r7,
5481   },
5482   {
5483     ARRAY_SIZE(kInstruction_sub_cc_r9_r5_r12_ROR_r4),
5484     kInstruction_sub_cc_r9_r5_r12_ROR_r4,
5485   },
5486   {
5487     ARRAY_SIZE(kInstruction_sub_vc_r0_r11_r3_LSR_r12),
5488     kInstruction_sub_vc_r0_r11_r3_LSR_r12,
5489   },
5490   {
5491     ARRAY_SIZE(kInstruction_sub_gt_r6_r2_r4_LSR_r4),
5492     kInstruction_sub_gt_r6_r2_r4_LSR_r4,
5493   },
5494   {
5495     ARRAY_SIZE(kInstruction_sub_lt_r4_r2_r0_LSL_r12),
5496     kInstruction_sub_lt_r4_r2_r0_LSL_r12,
5497   },
5498   {
5499     ARRAY_SIZE(kInstruction_sub_le_r9_r4_r13_ROR_r5),
5500     kInstruction_sub_le_r9_r4_r13_ROR_r5,
5501   },
5502   {
5503     ARRAY_SIZE(kInstruction_sub_vs_r9_r3_r8_LSR_r8),
5504     kInstruction_sub_vs_r9_r3_r8_LSR_r8,
5505   },
5506   {
5507     ARRAY_SIZE(kInstruction_sub_ne_r3_r8_r14_ROR_r8),
5508     kInstruction_sub_ne_r3_r8_r14_ROR_r8,
5509   },
5510   {
5511     ARRAY_SIZE(kInstruction_sub_vc_r12_r13_r4_LSR_r9),
5512     kInstruction_sub_vc_r12_r13_r4_LSR_r9,
5513   },
5514   {
5515     ARRAY_SIZE(kInstruction_sub_cc_r14_r0_r8_LSL_r1),
5516     kInstruction_sub_cc_r14_r0_r8_LSL_r1,
5517   },
5518   {
5519     ARRAY_SIZE(kInstruction_sub_hi_r6_r3_r5_ASR_r9),
5520     kInstruction_sub_hi_r6_r3_r5_ASR_r9,
5521   },
5522   {
5523     ARRAY_SIZE(kInstruction_sub_ne_r14_r4_r3_LSL_r8),
5524     kInstruction_sub_ne_r14_r4_r3_LSL_r8,
5525   },
5526   {
5527     ARRAY_SIZE(kInstruction_sub_ge_r1_r10_r13_LSR_r4),
5528     kInstruction_sub_ge_r1_r10_r13_LSR_r4,
5529   },
5530   {
5531     ARRAY_SIZE(kInstruction_sub_vc_r12_r7_r6_ROR_r3),
5532     kInstruction_sub_vc_r12_r7_r6_ROR_r3,
5533   },
5534   {
5535     ARRAY_SIZE(kInstruction_sub_gt_r0_r6_r7_ROR_r2),
5536     kInstruction_sub_gt_r0_r6_r7_ROR_r2,
5537   },
5538   {
5539     ARRAY_SIZE(kInstruction_sub_al_r4_r6_r9_LSL_r0),
5540     kInstruction_sub_al_r4_r6_r9_LSL_r0,
5541   },
5542   {
5543     ARRAY_SIZE(kInstruction_sub_ls_r1_r3_r11_LSR_r11),
5544     kInstruction_sub_ls_r1_r3_r11_LSR_r11,
5545   },
5546   {
5547     ARRAY_SIZE(kInstruction_sub_lt_r3_r11_r1_LSR_r14),
5548     kInstruction_sub_lt_r3_r11_r1_LSR_r14,
5549   },
5550   {
5551     ARRAY_SIZE(kInstruction_sub_vc_r6_r13_r7_ROR_r11),
5552     kInstruction_sub_vc_r6_r13_r7_ROR_r11,
5553   },
5554   {
5555     ARRAY_SIZE(kInstruction_sub_vc_r5_r14_r13_ROR_r13),
5556     kInstruction_sub_vc_r5_r14_r13_ROR_r13,
5557   },
5558   {
5559     ARRAY_SIZE(kInstruction_sub_vc_r1_r4_r11_LSL_r1),
5560     kInstruction_sub_vc_r1_r4_r11_LSL_r1,
5561   },
5562   {
5563     ARRAY_SIZE(kInstruction_sub_ls_r7_r3_r5_LSR_r6),
5564     kInstruction_sub_ls_r7_r3_r5_LSR_r6,
5565   },
5566   {
5567     ARRAY_SIZE(kInstruction_sub_vc_r13_r8_r3_ASR_r4),
5568     kInstruction_sub_vc_r13_r8_r3_ASR_r4,
5569   },
5570   {
5571     ARRAY_SIZE(kInstruction_sub_ls_r2_r3_r10_ROR_r11),
5572     kInstruction_sub_ls_r2_r3_r10_ROR_r11,
5573   },
5574   {
5575     ARRAY_SIZE(kInstruction_sub_ge_r6_r1_r12_ASR_r11),
5576     kInstruction_sub_ge_r6_r1_r12_ASR_r11,
5577   },
5578   {
5579     ARRAY_SIZE(kInstruction_sub_lt_r3_r1_r1_ASR_r14),
5580     kInstruction_sub_lt_r3_r1_r1_ASR_r14,
5581   },
5582   {
5583     ARRAY_SIZE(kInstruction_sub_hi_r2_r7_r14_LSL_r12),
5584     kInstruction_sub_hi_r2_r7_r14_LSL_r12,
5585   },
5586   {
5587     ARRAY_SIZE(kInstruction_sub_ge_r13_r10_r10_LSL_r14),
5588     kInstruction_sub_ge_r13_r10_r10_LSL_r14,
5589   },
5590   {
5591     ARRAY_SIZE(kInstruction_sub_le_r0_r1_r3_LSR_r3),
5592     kInstruction_sub_le_r0_r1_r3_LSR_r3,
5593   },
5594   {
5595     ARRAY_SIZE(kInstruction_sub_vs_r10_r7_r7_LSR_r6),
5596     kInstruction_sub_vs_r10_r7_r7_LSR_r6,
5597   },
5598   {
5599     ARRAY_SIZE(kInstruction_sub_al_r6_r3_r6_LSL_r7),
5600     kInstruction_sub_al_r6_r3_r6_LSL_r7,
5601   },
5602   {
5603     ARRAY_SIZE(kInstruction_sub_ne_r3_r8_r14_ASR_r1),
5604     kInstruction_sub_ne_r3_r8_r14_ASR_r1,
5605   },
5606   {
5607     ARRAY_SIZE(kInstruction_sub_cc_r4_r10_r4_LSR_r9),
5608     kInstruction_sub_cc_r4_r10_r4_LSR_r9,
5609   },
5610   {
5611     ARRAY_SIZE(kInstruction_sub_cs_r4_r1_r5_LSR_r10),
5612     kInstruction_sub_cs_r4_r1_r5_LSR_r10,
5613   },
5614   {
5615     ARRAY_SIZE(kInstruction_sub_eq_r7_r6_r1_LSL_r4),
5616     kInstruction_sub_eq_r7_r6_r1_LSL_r4,
5617   },
5618   {
5619     ARRAY_SIZE(kInstruction_sub_hi_r3_r7_r1_LSL_r5),
5620     kInstruction_sub_hi_r3_r7_r1_LSL_r5,
5621   },
5622   {
5623     ARRAY_SIZE(kInstruction_sub_al_r6_r11_r8_LSR_r12),
5624     kInstruction_sub_al_r6_r11_r8_LSR_r12,
5625   },
5626   {
5627     ARRAY_SIZE(kInstruction_sub_ls_r2_r5_r0_LSR_r5),
5628     kInstruction_sub_ls_r2_r5_r0_LSR_r5,
5629   },
5630   {
5631     ARRAY_SIZE(kInstruction_sub_pl_r4_r5_r13_LSL_r9),
5632     kInstruction_sub_pl_r4_r5_r13_LSL_r9,
5633   },
5634   {
5635     ARRAY_SIZE(kInstruction_sub_lt_r13_r12_r0_ASR_r8),
5636     kInstruction_sub_lt_r13_r12_r0_ASR_r8,
5637   },
5638   {
5639     ARRAY_SIZE(kInstruction_sub_cc_r11_r5_r0_LSL_r12),
5640     kInstruction_sub_cc_r11_r5_r0_LSL_r12,
5641   },
5642   {
5643     ARRAY_SIZE(kInstruction_sub_ne_r6_r2_r2_ROR_r0),
5644     kInstruction_sub_ne_r6_r2_r2_ROR_r0,
5645   },
5646   {
5647     ARRAY_SIZE(kInstruction_sub_ne_r9_r13_r12_ASR_r6),
5648     kInstruction_sub_ne_r9_r13_r12_ASR_r6,
5649   },
5650   {
5651     ARRAY_SIZE(kInstruction_sub_cs_r8_r6_r10_ROR_r10),
5652     kInstruction_sub_cs_r8_r6_r10_ROR_r10,
5653   },
5654   {
5655     ARRAY_SIZE(kInstruction_sub_vs_r10_r6_r1_LSL_r6),
5656     kInstruction_sub_vs_r10_r6_r1_LSL_r6,
5657   },
5658   {
5659     ARRAY_SIZE(kInstruction_sub_vc_r12_r0_r4_ASR_r10),
5660     kInstruction_sub_vc_r12_r0_r4_ASR_r10,
5661   },
5662   {
5663     ARRAY_SIZE(kInstruction_sub_cs_r10_r2_r11_ROR_r8),
5664     kInstruction_sub_cs_r10_r2_r11_ROR_r8,
5665   },
5666   {
5667     ARRAY_SIZE(kInstruction_sub_ne_r0_r9_r14_ASR_r14),
5668     kInstruction_sub_ne_r0_r9_r14_ASR_r14,
5669   },
5670   {
5671     ARRAY_SIZE(kInstruction_sub_eq_r0_r10_r1_ASR_r8),
5672     kInstruction_sub_eq_r0_r10_r1_ASR_r8,
5673   },
5674   {
5675     ARRAY_SIZE(kInstruction_sub_gt_r0_r11_r3_LSR_r0),
5676     kInstruction_sub_gt_r0_r11_r3_LSR_r0,
5677   },
5678   {
5679     ARRAY_SIZE(kInstruction_sub_al_r5_r11_r6_ROR_r14),
5680     kInstruction_sub_al_r5_r11_r6_ROR_r14,
5681   },
5682   {
5683     ARRAY_SIZE(kInstruction_sub_ls_r2_r11_r11_ROR_r2),
5684     kInstruction_sub_ls_r2_r11_r11_ROR_r2,
5685   },
5686   {
5687     ARRAY_SIZE(kInstruction_sub_cs_r2_r11_r6_ROR_r11),
5688     kInstruction_sub_cs_r2_r11_r6_ROR_r11,
5689   },
5690   {
5691     ARRAY_SIZE(kInstruction_sub_cs_r4_r9_r11_ASR_r5),
5692     kInstruction_sub_cs_r4_r9_r11_ASR_r5,
5693   },
5694   {
5695     ARRAY_SIZE(kInstruction_sub_ls_r5_r0_r2_ASR_r3),
5696     kInstruction_sub_ls_r5_r0_r2_ASR_r3,
5697   },
5698   {
5699     ARRAY_SIZE(kInstruction_sub_cc_r14_r1_r13_LSR_r2),
5700     kInstruction_sub_cc_r14_r1_r13_LSR_r2,
5701   },
5702   {
5703     ARRAY_SIZE(kInstruction_sub_lt_r4_r5_r6_ASR_r0),
5704     kInstruction_sub_lt_r4_r5_r6_ASR_r0,
5705   },
5706   {
5707     ARRAY_SIZE(kInstruction_sub_vc_r0_r12_r6_ASR_r6),
5708     kInstruction_sub_vc_r0_r12_r6_ASR_r6,
5709   },
5710   {
5711     ARRAY_SIZE(kInstruction_sub_pl_r3_r10_r4_LSR_r8),
5712     kInstruction_sub_pl_r3_r10_r4_LSR_r8,
5713   },
5714   {
5715     ARRAY_SIZE(kInstruction_sub_cc_r10_r5_r10_ASR_r10),
5716     kInstruction_sub_cc_r10_r5_r10_ASR_r10,
5717   },
5718   {
5719     ARRAY_SIZE(kInstruction_sub_pl_r2_r14_r1_ASR_r10),
5720     kInstruction_sub_pl_r2_r14_r1_ASR_r10,
5721   },
5722   {
5723     ARRAY_SIZE(kInstruction_sub_eq_r12_r13_r8_ROR_r12),
5724     kInstruction_sub_eq_r12_r13_r8_ROR_r12,
5725   },
5726   {
5727     ARRAY_SIZE(kInstruction_sub_gt_r9_r8_r2_LSL_r2),
5728     kInstruction_sub_gt_r9_r8_r2_LSL_r2,
5729   },
5730   {
5731     ARRAY_SIZE(kInstruction_sub_al_r13_r10_r10_LSL_r9),
5732     kInstruction_sub_al_r13_r10_r10_LSL_r9,
5733   },
5734   {
5735     ARRAY_SIZE(kInstruction_sub_eq_r8_r8_r6_ROR_r14),
5736     kInstruction_sub_eq_r8_r8_r6_ROR_r14,
5737   },
5738   {
5739     ARRAY_SIZE(kInstruction_sub_le_r14_r12_r4_ASR_r13),
5740     kInstruction_sub_le_r14_r12_r4_ASR_r13,
5741   },
5742   {
5743     ARRAY_SIZE(kInstruction_sub_cc_r3_r6_r12_LSR_r2),
5744     kInstruction_sub_cc_r3_r6_r12_LSR_r2,
5745   },
5746   {
5747     ARRAY_SIZE(kInstruction_sub_ls_r5_r14_r10_LSL_r6),
5748     kInstruction_sub_ls_r5_r14_r10_LSL_r6,
5749   },
5750   {
5751     ARRAY_SIZE(kInstruction_sub_hi_r12_r2_r1_ROR_r3),
5752     kInstruction_sub_hi_r12_r2_r1_ROR_r3,
5753   },
5754   {
5755     ARRAY_SIZE(kInstruction_sub_vc_r7_r13_r1_LSL_r12),
5756     kInstruction_sub_vc_r7_r13_r1_LSL_r12,
5757   },
5758   {
5759     ARRAY_SIZE(kInstruction_sub_cc_r0_r3_r13_LSL_r9),
5760     kInstruction_sub_cc_r0_r3_r13_LSL_r9,
5761   },
5762   {
5763     ARRAY_SIZE(kInstruction_sub_hi_r0_r11_r5_LSL_r11),
5764     kInstruction_sub_hi_r0_r11_r5_LSL_r11,
5765   },
5766   {
5767     ARRAY_SIZE(kInstruction_sub_ge_r9_r6_r14_LSR_r14),
5768     kInstruction_sub_ge_r9_r6_r14_LSR_r14,
5769   },
5770   {
5771     ARRAY_SIZE(kInstruction_sub_vc_r2_r5_r2_ROR_r12),
5772     kInstruction_sub_vc_r2_r5_r2_ROR_r12,
5773   },
5774   {
5775     ARRAY_SIZE(kInstruction_sub_mi_r9_r6_r9_ASR_r13),
5776     kInstruction_sub_mi_r9_r6_r9_ASR_r13,
5777   },
5778   {
5779     ARRAY_SIZE(kInstruction_sub_pl_r1_r3_r10_ASR_r2),
5780     kInstruction_sub_pl_r1_r3_r10_ASR_r2,
5781   },
5782   {
5783     ARRAY_SIZE(kInstruction_sub_le_r10_r9_r7_LSL_r4),
5784     kInstruction_sub_le_r10_r9_r7_LSL_r4,
5785   },
5786   {
5787     ARRAY_SIZE(kInstruction_sub_hi_r7_r4_r10_LSR_r6),
5788     kInstruction_sub_hi_r7_r4_r10_LSR_r6,
5789   },
5790   {
5791     ARRAY_SIZE(kInstruction_sub_cc_r6_r8_r13_LSR_r3),
5792     kInstruction_sub_cc_r6_r8_r13_LSR_r3,
5793   },
5794   {
5795     ARRAY_SIZE(kInstruction_sub_cs_r4_r9_r6_ASR_r0),
5796     kInstruction_sub_cs_r4_r9_r6_ASR_r0,
5797   },
5798   {
5799     ARRAY_SIZE(kInstruction_sub_ls_r0_r2_r4_ASR_r8),
5800     kInstruction_sub_ls_r0_r2_r4_ASR_r8,
5801   },
5802   {
5803     ARRAY_SIZE(kInstruction_sub_hi_r11_r5_r11_LSR_r1),
5804     kInstruction_sub_hi_r11_r5_r11_LSR_r1,
5805   },
5806   {
5807     ARRAY_SIZE(kInstruction_sub_vc_r0_r3_r6_LSR_r7),
5808     kInstruction_sub_vc_r0_r3_r6_LSR_r7,
5809   },
5810   {
5811     ARRAY_SIZE(kInstruction_sub_cs_r13_r10_r8_LSL_r6),
5812     kInstruction_sub_cs_r13_r10_r8_LSL_r6,
5813   },
5814   {
5815     ARRAY_SIZE(kInstruction_sub_al_r12_r12_r10_ASR_r13),
5816     kInstruction_sub_al_r12_r12_r10_ASR_r13,
5817   },
5818   {
5819     ARRAY_SIZE(kInstruction_sub_ge_r7_r7_r2_ASR_r8),
5820     kInstruction_sub_ge_r7_r7_r2_ASR_r8,
5821   },
5822   {
5823     ARRAY_SIZE(kInstruction_sub_ne_r10_r7_r6_LSL_r14),
5824     kInstruction_sub_ne_r10_r7_r6_LSL_r14,
5825   },
5826   {
5827     ARRAY_SIZE(kInstruction_sub_cs_r9_r9_r14_ROR_r0),
5828     kInstruction_sub_cs_r9_r9_r14_ROR_r0,
5829   },
5830   {
5831     ARRAY_SIZE(kInstruction_sub_lt_r3_r12_r0_ASR_r12),
5832     kInstruction_sub_lt_r3_r12_r0_ASR_r12,
5833   },
5834   {
5835     ARRAY_SIZE(kInstruction_sub_ne_r6_r9_r3_ASR_r11),
5836     kInstruction_sub_ne_r6_r9_r3_ASR_r11,
5837   },
5838   {
5839     ARRAY_SIZE(kInstruction_sub_vc_r4_r7_r7_ASR_r7),
5840     kInstruction_sub_vc_r4_r7_r7_ASR_r7,
5841   },
5842   {
5843     ARRAY_SIZE(kInstruction_sub_ne_r0_r9_r5_LSR_r14),
5844     kInstruction_sub_ne_r0_r9_r5_LSR_r14,
5845   },
5846   {
5847     ARRAY_SIZE(kInstruction_sub_hi_r8_r13_r1_ROR_r0),
5848     kInstruction_sub_hi_r8_r13_r1_ROR_r0,
5849   },
5850   {
5851     ARRAY_SIZE(kInstruction_sub_cc_r6_r1_r7_ROR_r5),
5852     kInstruction_sub_cc_r6_r1_r7_ROR_r5,
5853   },
5854   {
5855     ARRAY_SIZE(kInstruction_sub_vc_r7_r13_r2_LSL_r4),
5856     kInstruction_sub_vc_r7_r13_r2_LSL_r4,
5857   },
5858   {
5859     ARRAY_SIZE(kInstruction_sub_al_r4_r2_r3_ROR_r10),
5860     kInstruction_sub_al_r4_r2_r3_ROR_r10,
5861   },
5862   {
5863     ARRAY_SIZE(kInstruction_sub_ls_r0_r7_r3_LSR_r12),
5864     kInstruction_sub_ls_r0_r7_r3_LSR_r12,
5865   },
5866   {
5867     ARRAY_SIZE(kInstruction_sub_ls_r5_r8_r8_ASR_r13),
5868     kInstruction_sub_ls_r5_r8_r8_ASR_r13,
5869   },
5870   {
5871     ARRAY_SIZE(kInstruction_sub_gt_r0_r6_r12_ASR_r14),
5872     kInstruction_sub_gt_r0_r6_r12_ASR_r14,
5873   },
5874   {
5875     ARRAY_SIZE(kInstruction_sub_vs_r7_r13_r14_LSR_r11),
5876     kInstruction_sub_vs_r7_r13_r14_LSR_r11,
5877   },
5878   {
5879     ARRAY_SIZE(kInstruction_sub_mi_r12_r9_r11_LSL_r13),
5880     kInstruction_sub_mi_r12_r9_r11_LSL_r13,
5881   },
5882   {
5883     ARRAY_SIZE(kInstruction_sub_ge_r0_r0_r7_ROR_r13),
5884     kInstruction_sub_ge_r0_r0_r7_ROR_r13,
5885   },
5886   {
5887     ARRAY_SIZE(kInstruction_sub_hi_r14_r12_r6_LSR_r8),
5888     kInstruction_sub_hi_r14_r12_r6_LSR_r8,
5889   },
5890   {
5891     ARRAY_SIZE(kInstruction_sub_cs_r0_r3_r6_LSL_r6),
5892     kInstruction_sub_cs_r0_r3_r6_LSL_r6,
5893   },
5894   {
5895     ARRAY_SIZE(kInstruction_sub_al_r6_r9_r4_ASR_r3),
5896     kInstruction_sub_al_r6_r9_r4_ASR_r3,
5897   },
5898   {
5899     ARRAY_SIZE(kInstruction_sub_ls_r5_r6_r1_LSR_r3),
5900     kInstruction_sub_ls_r5_r6_r1_LSR_r3,
5901   },
5902   {
5903     ARRAY_SIZE(kInstruction_sub_ls_r3_r6_r14_ROR_r7),
5904     kInstruction_sub_ls_r3_r6_r14_ROR_r7,
5905   },
5906   {
5907     ARRAY_SIZE(kInstruction_sub_le_r10_r5_r1_ASR_r12),
5908     kInstruction_sub_le_r10_r5_r1_ASR_r12,
5909   },
5910   {
5911     ARRAY_SIZE(kInstruction_sub_hi_r3_r6_r10_ASR_r5),
5912     kInstruction_sub_hi_r3_r6_r10_ASR_r5,
5913   },
5914   {
5915     ARRAY_SIZE(kInstruction_sub_mi_r9_r3_r5_ROR_r8),
5916     kInstruction_sub_mi_r9_r3_r5_ROR_r8,
5917   },
5918   {
5919     ARRAY_SIZE(kInstruction_sub_hi_r10_r13_r8_ROR_r11),
5920     kInstruction_sub_hi_r10_r13_r8_ROR_r11,
5921   },
5922   {
5923     ARRAY_SIZE(kInstruction_sub_al_r11_r14_r2_ROR_r1),
5924     kInstruction_sub_al_r11_r14_r2_ROR_r1,
5925   },
5926   {
5927     ARRAY_SIZE(kInstruction_sub_gt_r12_r8_r0_ROR_r11),
5928     kInstruction_sub_gt_r12_r8_r0_ROR_r11,
5929   },
5930   {
5931     ARRAY_SIZE(kInstruction_sub_vc_r1_r0_r1_ROR_r9),
5932     kInstruction_sub_vc_r1_r0_r1_ROR_r9,
5933   },
5934   {
5935     ARRAY_SIZE(kInstruction_sub_mi_r6_r6_r3_ASR_r5),
5936     kInstruction_sub_mi_r6_r6_r3_ASR_r5,
5937   },
5938   {
5939     ARRAY_SIZE(kInstruction_sub_ge_r12_r12_r4_ROR_r9),
5940     kInstruction_sub_ge_r12_r12_r4_ROR_r9,
5941   },
5942   {
5943     ARRAY_SIZE(kInstruction_sub_ls_r4_r6_r9_ASR_r6),
5944     kInstruction_sub_ls_r4_r6_r9_ASR_r6,
5945   },
5946   {
5947     ARRAY_SIZE(kInstruction_sub_pl_r11_r3_r4_LSR_r9),
5948     kInstruction_sub_pl_r11_r3_r4_LSR_r9,
5949   },
5950   {
5951     ARRAY_SIZE(kInstruction_sub_hi_r0_r2_r2_ROR_r7),
5952     kInstruction_sub_hi_r0_r2_r2_ROR_r7,
5953   },
5954   {
5955     ARRAY_SIZE(kInstruction_sub_pl_r3_r12_r0_ASR_r2),
5956     kInstruction_sub_pl_r3_r12_r0_ASR_r2,
5957   },
5958   {
5959     ARRAY_SIZE(kInstruction_sub_ne_r6_r0_r9_LSL_r4),
5960     kInstruction_sub_ne_r6_r0_r9_LSL_r4,
5961   },
5962   {
5963     ARRAY_SIZE(kInstruction_sub_vc_r1_r2_r6_ROR_r13),
5964     kInstruction_sub_vc_r1_r2_r6_ROR_r13,
5965   },
5966   {
5967     ARRAY_SIZE(kInstruction_sub_ge_r9_r1_r12_LSL_r14),
5968     kInstruction_sub_ge_r9_r1_r12_LSL_r14,
5969   },
5970   {
5971     ARRAY_SIZE(kInstruction_sub_pl_r13_r9_r6_ROR_r14),
5972     kInstruction_sub_pl_r13_r9_r6_ROR_r14,
5973   },
5974   {
5975     ARRAY_SIZE(kInstruction_sub_gt_r0_r13_r13_LSL_r9),
5976     kInstruction_sub_gt_r0_r13_r13_LSL_r9,
5977   },
5978   {
5979     ARRAY_SIZE(kInstruction_sub_mi_r13_r5_r5_ASR_r8),
5980     kInstruction_sub_mi_r13_r5_r5_ASR_r8,
5981   },
5982   {
5983     ARRAY_SIZE(kInstruction_sub_gt_r1_r4_r0_LSL_r6),
5984     kInstruction_sub_gt_r1_r4_r0_LSL_r6,
5985   },
5986   {
5987     ARRAY_SIZE(kInstruction_sub_ls_r5_r4_r7_ROR_r4),
5988     kInstruction_sub_ls_r5_r4_r7_ROR_r4,
5989   },
5990   {
5991     ARRAY_SIZE(kInstruction_sub_vc_r8_r8_r0_ROR_r9),
5992     kInstruction_sub_vc_r8_r8_r0_ROR_r9,
5993   },
5994   {
5995     ARRAY_SIZE(kInstruction_sub_mi_r12_r12_r10_ROR_r8),
5996     kInstruction_sub_mi_r12_r12_r10_ROR_r8,
5997   },
5998   {
5999     ARRAY_SIZE(kInstruction_sub_hi_r6_r6_r6_LSL_r2),
6000     kInstruction_sub_hi_r6_r6_r6_LSL_r2,
6001   },
6002   {
6003     ARRAY_SIZE(kInstruction_sub_le_r7_r10_r14_LSL_r1),
6004     kInstruction_sub_le_r7_r10_r14_LSL_r1,
6005   },
6006   {
6007     ARRAY_SIZE(kInstruction_sub_ne_r13_r10_r6_ASR_r9),
6008     kInstruction_sub_ne_r13_r10_r6_ASR_r9,
6009   },
6010   {
6011     ARRAY_SIZE(kInstruction_sub_ne_r8_r8_r2_LSR_r13),
6012     kInstruction_sub_ne_r8_r8_r2_LSR_r13,
6013   },
6014   {
6015     ARRAY_SIZE(kInstruction_sub_mi_r0_r10_r14_ROR_r12),
6016     kInstruction_sub_mi_r0_r10_r14_ROR_r12,
6017   },
6018   {
6019     ARRAY_SIZE(kInstruction_sub_cc_r11_r14_r4_LSL_r5),
6020     kInstruction_sub_cc_r11_r14_r4_LSL_r5,
6021   },
6022   {
6023     ARRAY_SIZE(kInstruction_sub_cc_r3_r6_r3_ROR_r4),
6024     kInstruction_sub_cc_r3_r6_r3_ROR_r4,
6025   },
6026   {
6027     ARRAY_SIZE(kInstruction_sub_mi_r11_r1_r7_LSR_r7),
6028     kInstruction_sub_mi_r11_r1_r7_LSR_r7,
6029   },
6030   {
6031     ARRAY_SIZE(kInstruction_sub_vs_r12_r2_r2_LSL_r12),
6032     kInstruction_sub_vs_r12_r2_r2_LSL_r12,
6033   },
6034   {
6035     ARRAY_SIZE(kInstruction_sub_pl_r2_r2_r6_LSR_r0),
6036     kInstruction_sub_pl_r2_r2_r6_LSR_r0,
6037   },
6038   {
6039     ARRAY_SIZE(kInstruction_sub_gt_r11_r12_r7_LSR_r12),
6040     kInstruction_sub_gt_r11_r12_r7_LSR_r12,
6041   },
6042   {
6043     ARRAY_SIZE(kInstruction_sub_al_r13_r4_r4_ASR_r12),
6044     kInstruction_sub_al_r13_r4_r4_ASR_r12,
6045   },
6046   {
6047     ARRAY_SIZE(kInstruction_sub_le_r9_r1_r9_ROR_r1),
6048     kInstruction_sub_le_r9_r1_r9_ROR_r1,
6049   },
6050   {
6051     ARRAY_SIZE(kInstruction_sub_le_r1_r12_r8_ASR_r14),
6052     kInstruction_sub_le_r1_r12_r8_ASR_r14,
6053   },
6054   {
6055     ARRAY_SIZE(kInstruction_sub_cs_r1_r0_r7_ROR_r13),
6056     kInstruction_sub_cs_r1_r0_r7_ROR_r13,
6057   },
6058   {
6059     ARRAY_SIZE(kInstruction_sub_le_r0_r7_r7_ROR_r5),
6060     kInstruction_sub_le_r0_r7_r7_ROR_r5,
6061   },
6062   {
6063     ARRAY_SIZE(kInstruction_sub_hi_r6_r5_r7_ROR_r4),
6064     kInstruction_sub_hi_r6_r5_r7_ROR_r4,
6065   },
6066   {
6067     ARRAY_SIZE(kInstruction_sub_eq_r6_r14_r13_ASR_r1),
6068     kInstruction_sub_eq_r6_r14_r13_ASR_r1,
6069   },
6070   {
6071     ARRAY_SIZE(kInstruction_sub_lt_r1_r14_r13_LSR_r13),
6072     kInstruction_sub_lt_r1_r14_r13_LSR_r13,
6073   },
6074   {
6075     ARRAY_SIZE(kInstruction_sub_vs_r13_r1_r2_ROR_r6),
6076     kInstruction_sub_vs_r13_r1_r2_ROR_r6,
6077   },
6078   {
6079     ARRAY_SIZE(kInstruction_sub_gt_r11_r7_r8_ASR_r3),
6080     kInstruction_sub_gt_r11_r7_r8_ASR_r3,
6081   },
6082   {
6083     ARRAY_SIZE(kInstruction_sub_hi_r9_r5_r8_ASR_r8),
6084     kInstruction_sub_hi_r9_r5_r8_ASR_r8,
6085   },
6086   {
6087     ARRAY_SIZE(kInstruction_sub_lt_r10_r9_r5_LSL_r8),
6088     kInstruction_sub_lt_r10_r9_r5_LSL_r8,
6089   },
6090   {
6091     ARRAY_SIZE(kInstruction_sub_vs_r6_r1_r2_LSL_r4),
6092     kInstruction_sub_vs_r6_r1_r2_LSL_r4,
6093   },
6094   {
6095     ARRAY_SIZE(kInstruction_sub_pl_r13_r4_r10_LSR_r12),
6096     kInstruction_sub_pl_r13_r4_r10_LSR_r12,
6097   },
6098   {
6099     ARRAY_SIZE(kInstruction_sub_cs_r9_r8_r8_LSL_r6),
6100     kInstruction_sub_cs_r9_r8_r8_LSL_r6,
6101   },
6102   {
6103     ARRAY_SIZE(kInstruction_sub_ne_r1_r7_r0_ASR_r2),
6104     kInstruction_sub_ne_r1_r7_r0_ASR_r2,
6105   },
6106   {
6107     ARRAY_SIZE(kInstruction_sub_cc_r6_r3_r9_ASR_r3),
6108     kInstruction_sub_cc_r6_r3_r9_ASR_r3,
6109   },
6110   {
6111     ARRAY_SIZE(kInstruction_sub_hi_r13_r14_r7_ROR_r13),
6112     kInstruction_sub_hi_r13_r14_r7_ROR_r13,
6113   },
6114   {
6115     ARRAY_SIZE(kInstruction_sub_vc_r7_r11_r0_LSR_r8),
6116     kInstruction_sub_vc_r7_r11_r0_LSR_r8,
6117   },
6118   {
6119     ARRAY_SIZE(kInstruction_sub_al_r3_r2_r7_LSL_r12),
6120     kInstruction_sub_al_r3_r2_r7_LSL_r12,
6121   },
6122   {
6123     ARRAY_SIZE(kInstruction_sub_lt_r0_r5_r5_LSR_r1),
6124     kInstruction_sub_lt_r0_r5_r5_LSR_r1,
6125   },
6126   {
6127     ARRAY_SIZE(kInstruction_sub_ge_r10_r10_r4_ROR_r11),
6128     kInstruction_sub_ge_r10_r10_r4_ROR_r11,
6129   },
6130   {
6131     ARRAY_SIZE(kInstruction_sub_ne_r13_r9_r1_ROR_r12),
6132     kInstruction_sub_ne_r13_r9_r1_ROR_r12,
6133   },
6134   {
6135     ARRAY_SIZE(kInstruction_sub_eq_r6_r6_r2_ROR_r3),
6136     kInstruction_sub_eq_r6_r6_r2_ROR_r3,
6137   },
6138   {
6139     ARRAY_SIZE(kInstruction_sub_gt_r0_r4_r1_ROR_r5),
6140     kInstruction_sub_gt_r0_r4_r1_ROR_r5,
6141   },
6142   {
6143     ARRAY_SIZE(kInstruction_sub_lt_r5_r8_r0_ROR_r0),
6144     kInstruction_sub_lt_r5_r8_r0_ROR_r0,
6145   },
6146   {
6147     ARRAY_SIZE(kInstruction_sub_cs_r5_r13_r2_LSR_r8),
6148     kInstruction_sub_cs_r5_r13_r2_LSR_r8,
6149   },
6150   {
6151     ARRAY_SIZE(kInstruction_sub_le_r7_r13_r2_LSL_r7),
6152     kInstruction_sub_le_r7_r13_r2_LSL_r7,
6153   },
6154   {
6155     ARRAY_SIZE(kInstruction_sub_gt_r7_r1_r3_LSL_r1),
6156     kInstruction_sub_gt_r7_r1_r3_LSL_r1,
6157   },
6158   {
6159     ARRAY_SIZE(kInstruction_sub_vc_r4_r13_r10_ROR_r8),
6160     kInstruction_sub_vc_r4_r13_r10_ROR_r8,
6161   },
6162   {
6163     ARRAY_SIZE(kInstruction_sub_eq_r2_r8_r11_ROR_r4),
6164     kInstruction_sub_eq_r2_r8_r11_ROR_r4,
6165   },
6166   {
6167     ARRAY_SIZE(kInstruction_sub_le_r10_r1_r6_LSR_r9),
6168     kInstruction_sub_le_r10_r1_r6_LSR_r9,
6169   },
6170   {
6171     ARRAY_SIZE(kInstruction_sub_ge_r5_r1_r9_ASR_r10),
6172     kInstruction_sub_ge_r5_r1_r9_ASR_r10,
6173   },
6174   {
6175     ARRAY_SIZE(kInstruction_sub_al_r1_r5_r5_LSR_r7),
6176     kInstruction_sub_al_r1_r5_r5_LSR_r7,
6177   },
6178   {
6179     ARRAY_SIZE(kInstruction_sub_cs_r2_r13_r5_LSR_r8),
6180     kInstruction_sub_cs_r2_r13_r5_LSR_r8,
6181   },
6182   {
6183     ARRAY_SIZE(kInstruction_sub_le_r6_r6_r3_ROR_r3),
6184     kInstruction_sub_le_r6_r6_r3_ROR_r3,
6185   },
6186   {
6187     ARRAY_SIZE(kInstruction_sub_le_r5_r1_r7_ROR_r12),
6188     kInstruction_sub_le_r5_r1_r7_ROR_r12,
6189   },
6190   {
6191     ARRAY_SIZE(kInstruction_sub_cc_r9_r3_r9_ASR_r4),
6192     kInstruction_sub_cc_r9_r3_r9_ASR_r4,
6193   },
6194   {
6195     ARRAY_SIZE(kInstruction_sub_mi_r6_r2_r9_LSL_r5),
6196     kInstruction_sub_mi_r6_r2_r9_LSL_r5,
6197   },
6198   {
6199     ARRAY_SIZE(kInstruction_sub_cc_r5_r0_r4_ASR_r12),
6200     kInstruction_sub_cc_r5_r0_r4_ASR_r12,
6201   },
6202   {
6203     ARRAY_SIZE(kInstruction_sub_vc_r8_r13_r12_LSL_r11),
6204     kInstruction_sub_vc_r8_r13_r12_LSL_r11,
6205   },
6206   {
6207     ARRAY_SIZE(kInstruction_sub_lt_r7_r14_r9_LSR_r11),
6208     kInstruction_sub_lt_r7_r14_r9_LSR_r11,
6209   },
6210   {
6211     ARRAY_SIZE(kInstruction_sub_cs_r1_r5_r3_ASR_r1),
6212     kInstruction_sub_cs_r1_r5_r3_ASR_r1,
6213   },
6214   {
6215     ARRAY_SIZE(kInstruction_sub_lt_r14_r11_r6_ASR_r9),
6216     kInstruction_sub_lt_r14_r11_r6_ASR_r9,
6217   },
6218   {
6219     ARRAY_SIZE(kInstruction_sub_gt_r10_r5_r13_LSR_r3),
6220     kInstruction_sub_gt_r10_r5_r13_LSR_r3,
6221   },
6222   {
6223     ARRAY_SIZE(kInstruction_sub_cc_r6_r4_r12_LSL_r4),
6224     kInstruction_sub_cc_r6_r4_r12_LSL_r4,
6225   },
6226   {
6227     ARRAY_SIZE(kInstruction_sub_ne_r2_r12_r10_ROR_r11),
6228     kInstruction_sub_ne_r2_r12_r10_ROR_r11,
6229   },
6230   {
6231     ARRAY_SIZE(kInstruction_sub_eq_r8_r0_r6_ASR_r10),
6232     kInstruction_sub_eq_r8_r0_r6_ASR_r10,
6233   },
6234   {
6235     ARRAY_SIZE(kInstruction_sub_cc_r14_r3_r14_LSR_r7),
6236     kInstruction_sub_cc_r14_r3_r14_LSR_r7,
6237   },
6238   {
6239     ARRAY_SIZE(kInstruction_sub_lt_r1_r10_r1_ASR_r13),
6240     kInstruction_sub_lt_r1_r10_r1_ASR_r13,
6241   },
6242   {
6243     ARRAY_SIZE(kInstruction_sub_cc_r14_r3_r0_LSL_r12),
6244     kInstruction_sub_cc_r14_r3_r0_LSL_r12,
6245   },
6246   {
6247     ARRAY_SIZE(kInstruction_sub_vs_r8_r10_r7_LSL_r2),
6248     kInstruction_sub_vs_r8_r10_r7_LSL_r2,
6249   },
6250   {
6251     ARRAY_SIZE(kInstruction_sub_ls_r5_r6_r3_ASR_r2),
6252     kInstruction_sub_ls_r5_r6_r3_ASR_r2,
6253   },
6254   {
6255     ARRAY_SIZE(kInstruction_sub_vc_r11_r5_r13_LSL_r10),
6256     kInstruction_sub_vc_r11_r5_r13_LSL_r10,
6257   },
6258   {
6259     ARRAY_SIZE(kInstruction_sub_hi_r2_r10_r7_LSR_r0),
6260     kInstruction_sub_hi_r2_r10_r7_LSR_r0,
6261   },
6262   {
6263     ARRAY_SIZE(kInstruction_sub_ne_r5_r6_r8_ASR_r4),
6264     kInstruction_sub_ne_r5_r6_r8_ASR_r4,
6265   },
6266   {
6267     ARRAY_SIZE(kInstruction_sub_cs_r3_r12_r8_ASR_r5),
6268     kInstruction_sub_cs_r3_r12_r8_ASR_r5,
6269   },
6270   {
6271     ARRAY_SIZE(kInstruction_sub_ge_r3_r4_r4_LSR_r0),
6272     kInstruction_sub_ge_r3_r4_r4_LSR_r0,
6273   },
6274   {
6275     ARRAY_SIZE(kInstruction_sub_ge_r13_r13_r6_ROR_r13),
6276     kInstruction_sub_ge_r13_r13_r6_ROR_r13,
6277   },
6278   {
6279     ARRAY_SIZE(kInstruction_sub_eq_r4_r9_r0_LSL_r9),
6280     kInstruction_sub_eq_r4_r9_r0_LSL_r9,
6281   },
6282   {
6283     ARRAY_SIZE(kInstruction_sub_le_r7_r3_r1_ROR_r8),
6284     kInstruction_sub_le_r7_r3_r1_ROR_r8,
6285   },
6286   {
6287     ARRAY_SIZE(kInstruction_sub_gt_r9_r2_r5_LSL_r4),
6288     kInstruction_sub_gt_r9_r2_r5_LSL_r4,
6289   },
6290   {
6291     ARRAY_SIZE(kInstruction_sub_gt_r10_r12_r9_ROR_r12),
6292     kInstruction_sub_gt_r10_r12_r9_ROR_r12,
6293   },
6294   {
6295     ARRAY_SIZE(kInstruction_sub_hi_r4_r9_r6_LSR_r14),
6296     kInstruction_sub_hi_r4_r9_r6_LSR_r14,
6297   },
6298   {
6299     ARRAY_SIZE(kInstruction_sub_pl_r1_r10_r9_LSR_r8),
6300     kInstruction_sub_pl_r1_r10_r9_LSR_r8,
6301   },
6302   {
6303     ARRAY_SIZE(kInstruction_sub_mi_r0_r11_r2_ROR_r13),
6304     kInstruction_sub_mi_r0_r11_r2_ROR_r13,
6305   },
6306   {
6307     ARRAY_SIZE(kInstruction_sub_ge_r14_r5_r4_ASR_r2),
6308     kInstruction_sub_ge_r14_r5_r4_ASR_r2,
6309   },
6310   {
6311     ARRAY_SIZE(kInstruction_sub_vc_r7_r8_r9_ROR_r10),
6312     kInstruction_sub_vc_r7_r8_r9_ROR_r10,
6313   },
6314   {
6315     ARRAY_SIZE(kInstruction_sub_cs_r3_r1_r0_ROR_r7),
6316     kInstruction_sub_cs_r3_r1_r0_ROR_r7,
6317   },
6318   {
6319     ARRAY_SIZE(kInstruction_sub_hi_r9_r11_r4_ASR_r14),
6320     kInstruction_sub_hi_r9_r11_r4_ASR_r14,
6321   },
6322   {
6323     ARRAY_SIZE(kInstruction_sub_mi_r3_r8_r6_LSR_r12),
6324     kInstruction_sub_mi_r3_r8_r6_LSR_r12,
6325   },
6326   {
6327     ARRAY_SIZE(kInstruction_sub_vc_r5_r5_r6_LSL_r1),
6328     kInstruction_sub_vc_r5_r5_r6_LSL_r1,
6329   },
6330   {
6331     ARRAY_SIZE(kInstruction_sub_mi_r4_r8_r1_ASR_r3),
6332     kInstruction_sub_mi_r4_r8_r1_ASR_r3,
6333   },
6334   {
6335     ARRAY_SIZE(kInstruction_sub_le_r6_r0_r0_LSL_r0),
6336     kInstruction_sub_le_r6_r0_r0_LSL_r0,
6337   },
6338   {
6339     ARRAY_SIZE(kInstruction_sub_hi_r8_r11_r8_LSL_r14),
6340     kInstruction_sub_hi_r8_r11_r8_LSL_r14,
6341   },
6342   {
6343     ARRAY_SIZE(kInstruction_sub_gt_r14_r8_r12_ASR_r13),
6344     kInstruction_sub_gt_r14_r8_r12_ASR_r13,
6345   },
6346   {
6347     ARRAY_SIZE(kInstruction_sub_ge_r7_r7_r4_ROR_r7),
6348     kInstruction_sub_ge_r7_r7_r4_ROR_r7,
6349   },
6350   {
6351     ARRAY_SIZE(kInstruction_sub_eq_r11_r4_r13_LSL_r3),
6352     kInstruction_sub_eq_r11_r4_r13_LSL_r3,
6353   },
6354   {
6355     ARRAY_SIZE(kInstruction_sub_eq_r3_r6_r6_LSL_r10),
6356     kInstruction_sub_eq_r3_r6_r6_LSL_r10,
6357   },
6358   {
6359     ARRAY_SIZE(kInstruction_sub_al_r3_r10_r11_ROR_r12),
6360     kInstruction_sub_al_r3_r10_r11_ROR_r12,
6361   },
6362   {
6363     ARRAY_SIZE(kInstruction_sub_pl_r13_r7_r8_LSL_r13),
6364     kInstruction_sub_pl_r13_r7_r8_LSL_r13,
6365   },
6366   {
6367     ARRAY_SIZE(kInstruction_sub_pl_r9_r2_r11_LSR_r2),
6368     kInstruction_sub_pl_r9_r2_r11_LSR_r2,
6369   },
6370   {
6371     ARRAY_SIZE(kInstruction_sub_al_r3_r12_r8_LSR_r2),
6372     kInstruction_sub_al_r3_r12_r8_LSR_r2,
6373   },
6374   {
6375     ARRAY_SIZE(kInstruction_sub_ne_r4_r14_r6_ROR_r0),
6376     kInstruction_sub_ne_r4_r14_r6_ROR_r0,
6377   },
6378   {
6379     ARRAY_SIZE(kInstruction_sub_cs_r6_r14_r13_ASR_r3),
6380     kInstruction_sub_cs_r6_r14_r13_ASR_r3,
6381   },
6382   {
6383     ARRAY_SIZE(kInstruction_sub_pl_r10_r6_r8_LSR_r7),
6384     kInstruction_sub_pl_r10_r6_r8_LSR_r7,
6385   },
6386   {
6387     ARRAY_SIZE(kInstruction_sub_ls_r10_r1_r12_ROR_r6),
6388     kInstruction_sub_ls_r10_r1_r12_ROR_r6,
6389   },
6390   {
6391     ARRAY_SIZE(kInstruction_sub_eq_r12_r0_r1_LSL_r9),
6392     kInstruction_sub_eq_r12_r0_r1_LSL_r9,
6393   },
6394   {
6395     ARRAY_SIZE(kInstruction_sub_hi_r11_r14_r8_ROR_r6),
6396     kInstruction_sub_hi_r11_r14_r8_ROR_r6,
6397   },
6398   {
6399     ARRAY_SIZE(kInstruction_sub_vc_r9_r2_r5_LSL_r6),
6400     kInstruction_sub_vc_r9_r2_r5_LSL_r6,
6401   },
6402   {
6403     ARRAY_SIZE(kInstruction_sub_ne_r11_r8_r5_LSR_r11),
6404     kInstruction_sub_ne_r11_r8_r5_LSR_r11,
6405   },
6406   {
6407     ARRAY_SIZE(kInstruction_sub_mi_r1_r12_r3_ASR_r5),
6408     kInstruction_sub_mi_r1_r12_r3_ASR_r5,
6409   },
6410   {
6411     ARRAY_SIZE(kInstruction_sub_pl_r14_r7_r1_ASR_r12),
6412     kInstruction_sub_pl_r14_r7_r1_ASR_r12,
6413   },
6414   {
6415     ARRAY_SIZE(kInstruction_sub_pl_r9_r4_r1_ASR_r1),
6416     kInstruction_sub_pl_r9_r4_r1_ASR_r1,
6417   },
6418   {
6419     ARRAY_SIZE(kInstruction_sub_ls_r11_r0_r5_ROR_r14),
6420     kInstruction_sub_ls_r11_r0_r5_ROR_r14,
6421   },
6422   {
6423     ARRAY_SIZE(kInstruction_sub_lt_r13_r10_r14_ROR_r13),
6424     kInstruction_sub_lt_r13_r10_r14_ROR_r13,
6425   },
6426   {
6427     ARRAY_SIZE(kInstruction_sub_gt_r3_r14_r10_LSR_r4),
6428     kInstruction_sub_gt_r3_r14_r10_LSR_r4,
6429   },
6430   {
6431     ARRAY_SIZE(kInstruction_sub_cc_r1_r0_r5_ROR_r7),
6432     kInstruction_sub_cc_r1_r0_r5_ROR_r7,
6433   },
6434   {
6435     ARRAY_SIZE(kInstruction_sub_hi_r2_r14_r0_LSR_r14),
6436     kInstruction_sub_hi_r2_r14_r0_LSR_r14,
6437   },
6438   {
6439     ARRAY_SIZE(kInstruction_sub_pl_r3_r7_r2_ASR_r9),
6440     kInstruction_sub_pl_r3_r7_r2_ASR_r9,
6441   },
6442   {
6443     ARRAY_SIZE(kInstruction_sub_eq_r7_r5_r0_ROR_r6),
6444     kInstruction_sub_eq_r7_r5_r0_ROR_r6,
6445   },
6446   {
6447     ARRAY_SIZE(kInstruction_sub_mi_r14_r9_r14_LSR_r5),
6448     kInstruction_sub_mi_r14_r9_r14_LSR_r5,
6449   },
6450   {
6451     ARRAY_SIZE(kInstruction_sub_mi_r6_r1_r1_LSL_r12),
6452     kInstruction_sub_mi_r6_r1_r1_LSL_r12,
6453   },
6454   {
6455     ARRAY_SIZE(kInstruction_sub_ge_r12_r0_r8_LSR_r0),
6456     kInstruction_sub_ge_r12_r0_r8_LSR_r0,
6457   },
6458   {
6459     ARRAY_SIZE(kInstruction_sub_cc_r13_r8_r3_ROR_r7),
6460     kInstruction_sub_cc_r13_r8_r3_ROR_r7,
6461   },
6462   {
6463     ARRAY_SIZE(kInstruction_sub_vs_r7_r9_r4_LSL_r11),
6464     kInstruction_sub_vs_r7_r9_r4_LSL_r11,
6465   },
6466   {
6467     ARRAY_SIZE(kInstruction_sub_ge_r9_r10_r9_LSR_r5),
6468     kInstruction_sub_ge_r9_r10_r9_LSR_r5,
6469   },
6470   {
6471     ARRAY_SIZE(kInstruction_sub_ls_r5_r3_r0_LSR_r7),
6472     kInstruction_sub_ls_r5_r3_r0_LSR_r7,
6473   },
6474   {
6475     ARRAY_SIZE(kInstruction_sub_eq_r0_r6_r1_LSL_r11),
6476     kInstruction_sub_eq_r0_r6_r1_LSL_r11,
6477   },
6478   {
6479     ARRAY_SIZE(kInstruction_sub_ge_r9_r7_r0_ROR_r11),
6480     kInstruction_sub_ge_r9_r7_r0_ROR_r11,
6481   },
6482   {
6483     ARRAY_SIZE(kInstruction_sub_mi_r4_r2_r3_LSL_r12),
6484     kInstruction_sub_mi_r4_r2_r3_LSL_r12,
6485   },
6486   {
6487     ARRAY_SIZE(kInstruction_sub_hi_r7_r5_r0_ASR_r5),
6488     kInstruction_sub_hi_r7_r5_r0_ASR_r5,
6489   },
6490   {
6491     ARRAY_SIZE(kInstruction_sub_cc_r7_r13_r7_LSL_r14),
6492     kInstruction_sub_cc_r7_r13_r7_LSL_r14,
6493   },
6494   {
6495     ARRAY_SIZE(kInstruction_sub_ne_r2_r11_r2_LSL_r14),
6496     kInstruction_sub_ne_r2_r11_r2_LSL_r14,
6497   },
6498   {
6499     ARRAY_SIZE(kInstruction_sub_cc_r7_r5_r3_LSR_r11),
6500     kInstruction_sub_cc_r7_r5_r3_LSR_r11,
6501   },
6502   {
6503     ARRAY_SIZE(kInstruction_sub_ge_r12_r0_r12_ASR_r10),
6504     kInstruction_sub_ge_r12_r0_r12_ASR_r10,
6505   },
6506   {
6507     ARRAY_SIZE(kInstruction_sub_al_r11_r0_r2_LSR_r11),
6508     kInstruction_sub_al_r11_r0_r2_LSR_r11,
6509   },
6510   {
6511     ARRAY_SIZE(kInstruction_sub_cc_r1_r12_r1_ROR_r1),
6512     kInstruction_sub_cc_r1_r12_r1_ROR_r1,
6513   },
6514   {
6515     ARRAY_SIZE(kInstruction_sub_ls_r5_r9_r6_ASR_r4),
6516     kInstruction_sub_ls_r5_r9_r6_ASR_r4,
6517   },
6518   {
6519     ARRAY_SIZE(kInstruction_sub_ne_r5_r13_r2_ROR_r12),
6520     kInstruction_sub_ne_r5_r13_r2_ROR_r12,
6521   },
6522   {
6523     ARRAY_SIZE(kInstruction_sub_ge_r9_r10_r12_ROR_r10),
6524     kInstruction_sub_ge_r9_r10_r12_ROR_r10,
6525   },
6526   {
6527     ARRAY_SIZE(kInstruction_sub_cc_r10_r1_r8_LSR_r12),
6528     kInstruction_sub_cc_r10_r1_r8_LSR_r12,
6529   },
6530   {
6531     ARRAY_SIZE(kInstruction_sub_le_r9_r6_r11_ROR_r3),
6532     kInstruction_sub_le_r9_r6_r11_ROR_r3,
6533   },
6534   {
6535     ARRAY_SIZE(kInstruction_sub_le_r9_r9_r13_ASR_r5),
6536     kInstruction_sub_le_r9_r9_r13_ASR_r5,
6537   },
6538   {
6539     ARRAY_SIZE(kInstruction_sub_ge_r1_r12_r11_LSL_r12),
6540     kInstruction_sub_ge_r1_r12_r11_LSL_r12,
6541   },
6542   {
6543     ARRAY_SIZE(kInstruction_sub_vs_r11_r4_r6_LSL_r10),
6544     kInstruction_sub_vs_r11_r4_r6_LSL_r10,
6545   },
6546   {
6547     ARRAY_SIZE(kInstruction_sub_vs_r3_r3_r1_ROR_r2),
6548     kInstruction_sub_vs_r3_r3_r1_ROR_r2,
6549   },
6550   {
6551     ARRAY_SIZE(kInstruction_sub_ne_r12_r8_r12_ASR_r11),
6552     kInstruction_sub_ne_r12_r8_r12_ASR_r11,
6553   },
6554   {
6555     ARRAY_SIZE(kInstruction_sub_pl_r4_r8_r1_ROR_r8),
6556     kInstruction_sub_pl_r4_r8_r1_ROR_r8,
6557   },
6558   {
6559     ARRAY_SIZE(kInstruction_sub_gt_r3_r11_r13_ROR_r9),
6560     kInstruction_sub_gt_r3_r11_r13_ROR_r9,
6561   },
6562   {
6563     ARRAY_SIZE(kInstruction_sub_pl_r6_r0_r3_LSR_r9),
6564     kInstruction_sub_pl_r6_r0_r3_LSR_r9,
6565   },
6566   {
6567     ARRAY_SIZE(kInstruction_sub_ne_r5_r7_r9_LSL_r10),
6568     kInstruction_sub_ne_r5_r7_r9_LSL_r10,
6569   },
6570   {
6571     ARRAY_SIZE(kInstruction_sub_lt_r1_r12_r12_LSR_r8),
6572     kInstruction_sub_lt_r1_r12_r12_LSR_r8,
6573   },
6574   {
6575     ARRAY_SIZE(kInstruction_sub_cc_r2_r0_r0_ROR_r5),
6576     kInstruction_sub_cc_r2_r0_r0_ROR_r5,
6577   },
6578   {
6579     ARRAY_SIZE(kInstruction_sub_vc_r7_r11_r8_LSR_r14),
6580     kInstruction_sub_vc_r7_r11_r8_LSR_r14,
6581   },
6582   {
6583     ARRAY_SIZE(kInstruction_sub_ge_r0_r11_r6_ROR_r10),
6584     kInstruction_sub_ge_r0_r11_r6_ROR_r10,
6585   },
6586   {
6587     ARRAY_SIZE(kInstruction_sub_vs_r0_r9_r1_LSR_r0),
6588     kInstruction_sub_vs_r0_r9_r1_LSR_r0,
6589   },
6590   {
6591     ARRAY_SIZE(kInstruction_sub_gt_r13_r7_r11_LSR_r1),
6592     kInstruction_sub_gt_r13_r7_r11_LSR_r1,
6593   },
6594   {
6595     ARRAY_SIZE(kInstruction_sub_eq_r9_r10_r2_ROR_r12),
6596     kInstruction_sub_eq_r9_r10_r2_ROR_r12,
6597   },
6598   {
6599     ARRAY_SIZE(kInstruction_sub_eq_r0_r4_r0_LSR_r3),
6600     kInstruction_sub_eq_r0_r4_r0_LSR_r3,
6601   },
6602   {
6603     ARRAY_SIZE(kInstruction_sub_cs_r14_r2_r9_ASR_r12),
6604     kInstruction_sub_cs_r14_r2_r9_ASR_r12,
6605   },
6606   {
6607     ARRAY_SIZE(kInstruction_sub_lt_r9_r4_r9_ASR_r8),
6608     kInstruction_sub_lt_r9_r4_r9_ASR_r8,
6609   },
6610   {
6611     ARRAY_SIZE(kInstruction_sub_vs_r6_r12_r3_LSL_r11),
6612     kInstruction_sub_vs_r6_r12_r3_LSL_r11,
6613   },
6614   {
6615     ARRAY_SIZE(kInstruction_sub_ge_r9_r14_r10_ROR_r0),
6616     kInstruction_sub_ge_r9_r14_r10_ROR_r0,
6617   },
6618   {
6619     ARRAY_SIZE(kInstruction_sub_pl_r10_r2_r5_LSL_r12),
6620     kInstruction_sub_pl_r10_r2_r5_LSL_r12,
6621   },
6622   {
6623     ARRAY_SIZE(kInstruction_sub_al_r8_r0_r6_ROR_r6),
6624     kInstruction_sub_al_r8_r0_r6_ROR_r6,
6625   },
6626   {
6627     ARRAY_SIZE(kInstruction_sub_le_r9_r7_r7_LSR_r11),
6628     kInstruction_sub_le_r9_r7_r7_LSR_r11,
6629   },
6630   {
6631     ARRAY_SIZE(kInstruction_sub_vc_r3_r4_r5_LSR_r1),
6632     kInstruction_sub_vc_r3_r4_r5_LSR_r1,
6633   },
6634   {
6635     ARRAY_SIZE(kInstruction_sub_cc_r13_r1_r4_LSR_r11),
6636     kInstruction_sub_cc_r13_r1_r4_LSR_r11,
6637   },
6638   {
6639     ARRAY_SIZE(kInstruction_sub_vc_r13_r4_r0_LSL_r10),
6640     kInstruction_sub_vc_r13_r4_r0_LSL_r10,
6641   },
6642   {
6643     ARRAY_SIZE(kInstruction_sub_vc_r5_r0_r1_LSR_r1),
6644     kInstruction_sub_vc_r5_r0_r1_LSR_r1,
6645   },
6646   {
6647     ARRAY_SIZE(kInstruction_sub_ls_r5_r11_r1_ASR_r9),
6648     kInstruction_sub_ls_r5_r11_r1_ASR_r9,
6649   },
6650   {
6651     ARRAY_SIZE(kInstruction_sub_vs_r3_r2_r8_ASR_r1),
6652     kInstruction_sub_vs_r3_r2_r8_ASR_r1,
6653   },
6654   {
6655     ARRAY_SIZE(kInstruction_sub_hi_r8_r4_r6_ASR_r4),
6656     kInstruction_sub_hi_r8_r4_r6_ASR_r4,
6657   },
6658   {
6659     ARRAY_SIZE(kInstruction_sub_mi_r11_r12_r14_ASR_r13),
6660     kInstruction_sub_mi_r11_r12_r14_ASR_r13,
6661   },
6662   {
6663     ARRAY_SIZE(kInstruction_sub_gt_r7_r12_r12_LSL_r14),
6664     kInstruction_sub_gt_r7_r12_r12_LSL_r14,
6665   },
6666   {
6667     ARRAY_SIZE(kInstruction_sub_ge_r11_r4_r9_LSR_r7),
6668     kInstruction_sub_ge_r11_r4_r9_LSR_r7,
6669   },
6670   {
6671     ARRAY_SIZE(kInstruction_sub_vs_r0_r4_r10_LSL_r2),
6672     kInstruction_sub_vs_r0_r4_r10_LSL_r2,
6673   },
6674   {
6675     ARRAY_SIZE(kInstruction_sub_pl_r6_r4_r13_ASR_r0),
6676     kInstruction_sub_pl_r6_r4_r13_ASR_r0,
6677   },
6678   {
6679     ARRAY_SIZE(kInstruction_sub_eq_r2_r3_r11_ROR_r1),
6680     kInstruction_sub_eq_r2_r3_r11_ROR_r1,
6681   },
6682   {
6683     ARRAY_SIZE(kInstruction_sub_vs_r10_r9_r0_LSL_r4),
6684     kInstruction_sub_vs_r10_r9_r0_LSL_r4,
6685   },
6686   {
6687     ARRAY_SIZE(kInstruction_sub_cs_r0_r7_r10_LSL_r0),
6688     kInstruction_sub_cs_r0_r7_r10_LSL_r0,
6689   },
6690   {
6691     ARRAY_SIZE(kInstruction_sub_eq_r11_r2_r3_ASR_r13),
6692     kInstruction_sub_eq_r11_r2_r3_ASR_r13,
6693   },
6694   {
6695     ARRAY_SIZE(kInstruction_sub_eq_r14_r3_r7_ASR_r14),
6696     kInstruction_sub_eq_r14_r3_r7_ASR_r14,
6697   },
6698   {
6699     ARRAY_SIZE(kInstruction_sub_gt_r0_r2_r0_LSL_r12),
6700     kInstruction_sub_gt_r0_r2_r0_LSL_r12,
6701   },
6702   {
6703     ARRAY_SIZE(kInstruction_sub_mi_r0_r12_r6_LSR_r13),
6704     kInstruction_sub_mi_r0_r12_r6_LSR_r13,
6705   },
6706   {
6707     ARRAY_SIZE(kInstruction_sub_gt_r4_r4_r9_LSR_r12),
6708     kInstruction_sub_gt_r4_r4_r9_LSR_r12,
6709   },
6710   {
6711     ARRAY_SIZE(kInstruction_sub_vc_r6_r7_r10_ROR_r2),
6712     kInstruction_sub_vc_r6_r7_r10_ROR_r2,
6713   },
6714   {
6715     ARRAY_SIZE(kInstruction_sub_lt_r10_r8_r13_ROR_r13),
6716     kInstruction_sub_lt_r10_r8_r13_ROR_r13,
6717   },
6718   {
6719     ARRAY_SIZE(kInstruction_sub_lt_r13_r10_r4_ROR_r0),
6720     kInstruction_sub_lt_r13_r10_r4_ROR_r0,
6721   },
6722   {
6723     ARRAY_SIZE(kInstruction_sub_pl_r1_r6_r0_LSR_r12),
6724     kInstruction_sub_pl_r1_r6_r0_LSR_r12,
6725   },
6726   {
6727     ARRAY_SIZE(kInstruction_sub_ge_r14_r7_r1_LSR_r8),
6728     kInstruction_sub_ge_r14_r7_r1_LSR_r8,
6729   },
6730   {
6731     ARRAY_SIZE(kInstruction_sub_cc_r8_r13_r6_LSL_r13),
6732     kInstruction_sub_cc_r8_r13_r6_LSL_r13,
6733   },
6734   {
6735     ARRAY_SIZE(kInstruction_sub_gt_r13_r4_r7_LSR_r2),
6736     kInstruction_sub_gt_r13_r4_r7_LSR_r2,
6737   },
6738   {
6739     ARRAY_SIZE(kInstruction_sub_eq_r11_r3_r5_LSR_r3),
6740     kInstruction_sub_eq_r11_r3_r5_LSR_r3,
6741   },
6742   {
6743     ARRAY_SIZE(kInstruction_sub_vc_r8_r11_r2_ROR_r7),
6744     kInstruction_sub_vc_r8_r11_r2_ROR_r7,
6745   },
6746   {
6747     ARRAY_SIZE(kInstruction_sub_vc_r11_r2_r0_LSL_r2),
6748     kInstruction_sub_vc_r11_r2_r0_LSL_r2,
6749   },
6750   {
6751     ARRAY_SIZE(kInstruction_sub_cs_r9_r11_r11_LSL_r11),
6752     kInstruction_sub_cs_r9_r11_r11_LSL_r11,
6753   },
6754   {
6755     ARRAY_SIZE(kInstruction_sub_ge_r14_r4_r12_LSL_r11),
6756     kInstruction_sub_ge_r14_r4_r12_LSL_r11,
6757   },
6758   {
6759     ARRAY_SIZE(kInstruction_sub_vs_r4_r10_r3_LSL_r1),
6760     kInstruction_sub_vs_r4_r10_r3_LSL_r1,
6761   },
6762   {
6763     ARRAY_SIZE(kInstruction_sub_mi_r13_r1_r8_LSR_r2),
6764     kInstruction_sub_mi_r13_r1_r8_LSR_r2,
6765   },
6766   {
6767     ARRAY_SIZE(kInstruction_sub_le_r3_r13_r13_LSL_r8),
6768     kInstruction_sub_le_r3_r13_r13_LSL_r8,
6769   },
6770   {
6771     ARRAY_SIZE(kInstruction_sub_mi_r9_r12_r8_LSR_r14),
6772     kInstruction_sub_mi_r9_r12_r8_LSR_r14,
6773   },
6774   {
6775     ARRAY_SIZE(kInstruction_sub_pl_r7_r11_r10_ASR_r2),
6776     kInstruction_sub_pl_r7_r11_r10_ASR_r2,
6777   },
6778   {
6779     ARRAY_SIZE(kInstruction_sub_lt_r12_r2_r9_ASR_r5),
6780     kInstruction_sub_lt_r12_r2_r9_ASR_r5,
6781   },
6782   {
6783     ARRAY_SIZE(kInstruction_sub_gt_r13_r0_r5_LSL_r2),
6784     kInstruction_sub_gt_r13_r0_r5_LSL_r2,
6785   },
6786   {
6787     ARRAY_SIZE(kInstruction_sub_le_r5_r10_r9_ROR_r0),
6788     kInstruction_sub_le_r5_r10_r9_ROR_r0,
6789   },
6790   {
6791     ARRAY_SIZE(kInstruction_sub_lt_r6_r1_r4_ASR_r11),
6792     kInstruction_sub_lt_r6_r1_r4_ASR_r11,
6793   },
6794   {
6795     ARRAY_SIZE(kInstruction_sub_pl_r11_r5_r14_LSR_r4),
6796     kInstruction_sub_pl_r11_r5_r14_LSR_r4,
6797   },
6798   {
6799     ARRAY_SIZE(kInstruction_sub_eq_r9_r0_r6_ROR_r9),
6800     kInstruction_sub_eq_r9_r0_r6_ROR_r9,
6801   },
6802   {
6803     ARRAY_SIZE(kInstruction_sub_mi_r3_r11_r2_ASR_r4),
6804     kInstruction_sub_mi_r3_r11_r2_ASR_r4,
6805   },
6806   {
6807     ARRAY_SIZE(kInstruction_sub_pl_r13_r8_r0_ROR_r6),
6808     kInstruction_sub_pl_r13_r8_r0_ROR_r6,
6809   },
6810   {
6811     ARRAY_SIZE(kInstruction_sub_vc_r8_r2_r6_ASR_r4),
6812     kInstruction_sub_vc_r8_r2_r6_ASR_r4,
6813   },
6814   {
6815     ARRAY_SIZE(kInstruction_sub_ge_r1_r0_r4_ASR_r1),
6816     kInstruction_sub_ge_r1_r0_r4_ASR_r1,
6817   },
6818   {
6819     ARRAY_SIZE(kInstruction_sub_vc_r2_r4_r13_LSL_r13),
6820     kInstruction_sub_vc_r2_r4_r13_LSL_r13,
6821   },
6822   {
6823     ARRAY_SIZE(kInstruction_sub_lt_r4_r3_r5_ASR_r11),
6824     kInstruction_sub_lt_r4_r3_r5_ASR_r11,
6825   },
6826   {
6827     ARRAY_SIZE(kInstruction_sub_pl_r5_r12_r3_LSL_r4),
6828     kInstruction_sub_pl_r5_r12_r3_LSL_r4,
6829   },
6830   {
6831     ARRAY_SIZE(kInstruction_sub_pl_r14_r6_r6_LSR_r10),
6832     kInstruction_sub_pl_r14_r6_r6_LSR_r10,
6833   },
6834   {
6835     ARRAY_SIZE(kInstruction_sub_gt_r14_r13_r3_LSL_r9),
6836     kInstruction_sub_gt_r14_r13_r3_LSL_r9,
6837   },
6838   {
6839     ARRAY_SIZE(kInstruction_sub_pl_r10_r9_r4_LSL_r3),
6840     kInstruction_sub_pl_r10_r9_r4_LSL_r3,
6841   },
6842   {
6843     ARRAY_SIZE(kInstruction_sub_al_r10_r8_r4_ROR_r1),
6844     kInstruction_sub_al_r10_r8_r4_ROR_r1,
6845   },
6846   {
6847     ARRAY_SIZE(kInstruction_sub_pl_r14_r9_r11_ASR_r13),
6848     kInstruction_sub_pl_r14_r9_r11_ASR_r13,
6849   },
6850   {
6851     ARRAY_SIZE(kInstruction_sub_cc_r8_r1_r4_ROR_r12),
6852     kInstruction_sub_cc_r8_r1_r4_ROR_r12,
6853   },
6854   {
6855     ARRAY_SIZE(kInstruction_sub_vs_r5_r14_r7_LSR_r0),
6856     kInstruction_sub_vs_r5_r14_r7_LSR_r0,
6857   },
6858   {
6859     ARRAY_SIZE(kInstruction_sub_gt_r1_r10_r13_ROR_r9),
6860     kInstruction_sub_gt_r1_r10_r13_ROR_r9,
6861   },
6862   {
6863     ARRAY_SIZE(kInstruction_sub_mi_r8_r14_r9_LSR_r5),
6864     kInstruction_sub_mi_r8_r14_r9_LSR_r5,
6865   },
6866   {
6867     ARRAY_SIZE(kInstruction_sub_ge_r12_r10_r7_ROR_r2),
6868     kInstruction_sub_ge_r12_r10_r7_ROR_r2,
6869   },
6870   {
6871     ARRAY_SIZE(kInstruction_sub_al_r11_r8_r1_LSR_r10),
6872     kInstruction_sub_al_r11_r8_r1_LSR_r10,
6873   },
6874   {
6875     ARRAY_SIZE(kInstruction_sub_al_r7_r13_r11_LSL_r14),
6876     kInstruction_sub_al_r7_r13_r11_LSL_r14,
6877   },
6878   {
6879     ARRAY_SIZE(kInstruction_sub_vc_r13_r11_r11_ASR_r9),
6880     kInstruction_sub_vc_r13_r11_r11_ASR_r9,
6881   },
6882   {
6883     ARRAY_SIZE(kInstruction_sub_gt_r10_r5_r11_LSR_r14),
6884     kInstruction_sub_gt_r10_r5_r11_LSR_r14,
6885   },
6886   {
6887     ARRAY_SIZE(kInstruction_sub_vc_r10_r11_r7_ROR_r3),
6888     kInstruction_sub_vc_r10_r11_r7_ROR_r3,
6889   },
6890   {
6891     ARRAY_SIZE(kInstruction_sub_le_r10_r2_r7_LSL_r6),
6892     kInstruction_sub_le_r10_r2_r7_LSL_r6,
6893   },
6894   {
6895     ARRAY_SIZE(kInstruction_sub_al_r1_r3_r6_ASR_r5),
6896     kInstruction_sub_al_r1_r3_r6_ASR_r5,
6897   },
6898   {
6899     ARRAY_SIZE(kInstruction_sub_cs_r14_r9_r7_LSL_r12),
6900     kInstruction_sub_cs_r14_r9_r7_LSL_r12,
6901   },
6902   {
6903     ARRAY_SIZE(kInstruction_sub_ls_r10_r1_r4_LSL_r4),
6904     kInstruction_sub_ls_r10_r1_r4_LSL_r4,
6905   },
6906   {
6907     ARRAY_SIZE(kInstruction_sub_vs_r2_r5_r4_ROR_r3),
6908     kInstruction_sub_vs_r2_r5_r4_ROR_r3,
6909   },
6910   {
6911     ARRAY_SIZE(kInstruction_sub_vs_r1_r7_r10_ASR_r0),
6912     kInstruction_sub_vs_r1_r7_r10_ASR_r0,
6913   },
6914   {
6915     ARRAY_SIZE(kInstruction_sub_cs_r10_r12_r0_LSR_r4),
6916     kInstruction_sub_cs_r10_r12_r0_LSR_r4,
6917   },
6918   {
6919     ARRAY_SIZE(kInstruction_sub_vs_r8_r8_r1_LSR_r13),
6920     kInstruction_sub_vs_r8_r8_r1_LSR_r13,
6921   },
6922   {
6923     ARRAY_SIZE(kInstruction_sub_mi_r14_r5_r9_LSR_r7),
6924     kInstruction_sub_mi_r14_r5_r9_LSR_r7,
6925   },
6926   {
6927     ARRAY_SIZE(kInstruction_sub_vs_r6_r6_r14_ASR_r8),
6928     kInstruction_sub_vs_r6_r6_r14_ASR_r8,
6929   },
6930   {
6931     ARRAY_SIZE(kInstruction_sub_vc_r0_r1_r14_ROR_r0),
6932     kInstruction_sub_vc_r0_r1_r14_ROR_r0,
6933   },
6934   {
6935     ARRAY_SIZE(kInstruction_sub_ls_r9_r3_r11_ASR_r3),
6936     kInstruction_sub_ls_r9_r3_r11_ASR_r3,
6937   },
6938   {
6939     ARRAY_SIZE(kInstruction_sub_ls_r1_r12_r1_ASR_r6),
6940     kInstruction_sub_ls_r1_r12_r1_ASR_r6,
6941   },
6942   {
6943     ARRAY_SIZE(kInstruction_sub_hi_r6_r10_r0_ASR_r2),
6944     kInstruction_sub_hi_r6_r10_r0_ASR_r2,
6945   },
6946   {
6947     ARRAY_SIZE(kInstruction_sub_vc_r6_r14_r7_ASR_r1),
6948     kInstruction_sub_vc_r6_r14_r7_ASR_r1,
6949   },
6950   {
6951     ARRAY_SIZE(kInstruction_sub_eq_r14_r11_r10_LSL_r13),
6952     kInstruction_sub_eq_r14_r11_r10_LSL_r13,
6953   },
6954   {
6955     ARRAY_SIZE(kInstruction_sub_ge_r6_r12_r5_LSR_r9),
6956     kInstruction_sub_ge_r6_r12_r5_LSR_r9,
6957   },
6958   {
6959     ARRAY_SIZE(kInstruction_sub_mi_r1_r5_r0_ROR_r9),
6960     kInstruction_sub_mi_r1_r5_r0_ROR_r9,
6961   },
6962   {
6963     ARRAY_SIZE(kInstruction_sub_al_r7_r8_r2_ROR_r4),
6964     kInstruction_sub_al_r7_r8_r2_ROR_r4,
6965   },
6966   {
6967     ARRAY_SIZE(kInstruction_sub_hi_r8_r1_r5_ASR_r10),
6968     kInstruction_sub_hi_r8_r1_r5_ASR_r10,
6969   },
6970   {
6971     ARRAY_SIZE(kInstruction_sub_ne_r14_r5_r0_LSR_r7),
6972     kInstruction_sub_ne_r14_r5_r0_LSR_r7,
6973   },
6974   {
6975     ARRAY_SIZE(kInstruction_sub_vc_r3_r13_r9_LSL_r9),
6976     kInstruction_sub_vc_r3_r13_r9_LSL_r9,
6977   },
6978   {
6979     ARRAY_SIZE(kInstruction_sub_vs_r2_r2_r7_LSL_r5),
6980     kInstruction_sub_vs_r2_r2_r7_LSL_r5,
6981   },
6982   {
6983     ARRAY_SIZE(kInstruction_sub_vc_r7_r3_r6_ASR_r6),
6984     kInstruction_sub_vc_r7_r3_r6_ASR_r6,
6985   },
6986   {
6987     ARRAY_SIZE(kInstruction_sub_eq_r2_r5_r8_ROR_r1),
6988     kInstruction_sub_eq_r2_r5_r8_ROR_r1,
6989   },
6990   {
6991     ARRAY_SIZE(kInstruction_sub_eq_r0_r0_r10_ROR_r3),
6992     kInstruction_sub_eq_r0_r0_r10_ROR_r3,
6993   },
6994   {
6995     ARRAY_SIZE(kInstruction_sub_lt_r6_r1_r0_ROR_r9),
6996     kInstruction_sub_lt_r6_r1_r0_ROR_r9,
6997   },
6998   {
6999     ARRAY_SIZE(kInstruction_sub_ls_r7_r7_r12_LSR_r5),
7000     kInstruction_sub_ls_r7_r7_r12_LSR_r5,
7001   },
7002   {
7003     ARRAY_SIZE(kInstruction_sub_vs_r0_r9_r7_ROR_r14),
7004     kInstruction_sub_vs_r0_r9_r7_ROR_r14,
7005   },
7006   {
7007     ARRAY_SIZE(kInstruction_sub_al_r0_r8_r2_ROR_r2),
7008     kInstruction_sub_al_r0_r8_r2_ROR_r2,
7009   },
7010   {
7011     ARRAY_SIZE(kInstruction_sub_vc_r1_r14_r14_LSL_r11),
7012     kInstruction_sub_vc_r1_r14_r14_LSL_r11,
7013   },
7014   {
7015     ARRAY_SIZE(kInstruction_sub_ge_r9_r14_r10_ASR_r11),
7016     kInstruction_sub_ge_r9_r14_r10_ASR_r11,
7017   },
7018   {
7019     ARRAY_SIZE(kInstruction_sub_vs_r0_r3_r9_LSL_r4),
7020     kInstruction_sub_vs_r0_r3_r9_LSL_r4,
7021   },
7022   {
7023     ARRAY_SIZE(kInstruction_sub_pl_r14_r13_r7_LSR_r14),
7024     kInstruction_sub_pl_r14_r13_r7_LSR_r14,
7025   },
7026   {
7027     ARRAY_SIZE(kInstruction_sub_le_r2_r4_r6_LSR_r3),
7028     kInstruction_sub_le_r2_r4_r6_LSR_r3,
7029   },
7030   {
7031     ARRAY_SIZE(kInstruction_sub_vc_r7_r14_r6_LSR_r10),
7032     kInstruction_sub_vc_r7_r14_r6_LSR_r10,
7033   },
7034   {
7035     ARRAY_SIZE(kInstruction_sub_mi_r13_r11_r14_ASR_r7),
7036     kInstruction_sub_mi_r13_r11_r14_ASR_r7,
7037   },
7038 };
7039 
7040 #endif  // VIXL_ASSEMBLER_COND_RD_RN_OPERAND_RM_SHIFT_RS_SUB_A32_H_
7041