basic-arm-instructions.s revision 10c7d70a4e843b3006db9f5f583d6f6f56cc245e
13f00e317064560ad11168d22030416d853829f6eJim Grosbach@ RUN: llvm-mc -triple=armv7-apple-darwin -show-encoding < %s | FileCheck %s
23f00e317064560ad11168d22030416d853829f6eJim Grosbach  .syntax unified
33f00e317064560ad11168d22030416d853829f6eJim Grosbach  .globl _func
4e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach
5e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ Check that the assembler can handle the documented syntax from the ARM ARM.
6e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ For complex constructs like shifter operands, check more thoroughly for them
7e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ once then spot check that following instructions accept the form generally.
8e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ This gives us good coverage while keeping the overall size of the test
9e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ more reasonable.
10e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach
113f00e317064560ad11168d22030416d853829f6eJim Grosbach_func:
123f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: _func
133f00e317064560ad11168d22030416d853829f6eJim Grosbach
14da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@------------------------------------------------------------------------------
153f00e317064560ad11168d22030416d853829f6eJim Grosbach@ ADC (immediate)
16da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@------------------------------------------------------------------------------
173f00e317064560ad11168d22030416d853829f6eJim Grosbach  adc r1, r2, #0xf
183f00e317064560ad11168d22030416d853829f6eJim Grosbach  adc r1, r2, #0xf0
193f00e317064560ad11168d22030416d853829f6eJim Grosbach  adc r1, r2, #0xf00
203f00e317064560ad11168d22030416d853829f6eJim Grosbach  adc r1, r2, #0xf000
213f00e317064560ad11168d22030416d853829f6eJim Grosbach  adc r1, r2, #0xf0000
223f00e317064560ad11168d22030416d853829f6eJim Grosbach  adc r1, r2, #0xf00000
233f00e317064560ad11168d22030416d853829f6eJim Grosbach  adc r1, r2, #0xf000000
243f00e317064560ad11168d22030416d853829f6eJim Grosbach  adc r1, r2, #0xf0000000
253f00e317064560ad11168d22030416d853829f6eJim Grosbach  adc r1, r2, #0xf000000f
263f00e317064560ad11168d22030416d853829f6eJim Grosbach  adcs r1, r2, #0xf00
273f00e317064560ad11168d22030416d853829f6eJim Grosbach  adcseq r1, r2, #0xf00
28dc89561fecf100d6c32d73c7b009fd73e51be688Jim Grosbach  adceq r1, r2, #0xf00
293f00e317064560ad11168d22030416d853829f6eJim Grosbach
303f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adc	r1, r2, #15             @ encoding: [0x0f,0x10,0xa2,0xe2]
313f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adc	r1, r2, #240            @ encoding: [0xf0,0x10,0xa2,0xe2]
323f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adc	r1, r2, #3840           @ encoding: [0x0f,0x1c,0xa2,0xe2]
333f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adc	r1, r2, #61440          @ encoding: [0x0f,0x1a,0xa2,0xe2]
343f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adc	r1, r2, #983040         @ encoding: [0x0f,0x18,0xa2,0xe2]
353f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adc	r1, r2, #15728640       @ encoding: [0x0f,0x16,0xa2,0xe2]
363f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adc	r1, r2, #251658240      @ encoding: [0x0f,0x14,0xa2,0xe2]
373f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adc	r1, r2, #4026531840     @ encoding: [0x0f,0x12,0xa2,0xe2]
383f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adc	r1, r2, #4026531855     @ encoding: [0xff,0x12,0xa2,0xe2]
393f00e317064560ad11168d22030416d853829f6eJim Grosbach
403f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adcs	r1, r2, #3840           @ encoding: [0x0f,0x1c,0xb2,0xe2]
413f00e317064560ad11168d22030416d853829f6eJim Grosbach@ CHECK: adcseq	r1, r2, #3840           @ encoding: [0x0f,0x1c,0xb2,0x02]
42dc89561fecf100d6c32d73c7b009fd73e51be688Jim Grosbach@ CHECK: adceq	r1, r2, #3840           @ encoding: [0x0f,0x1c,0xa2,0x02]
43e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach
44da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@------------------------------------------------------------------------------
45e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ ADC (register)
46da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ ADC (shifted register)
47da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@------------------------------------------------------------------------------
48e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6
49e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  @ Constant shifts
50e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, lsl #1
51e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, lsl #31
52e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, lsr #1
53e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, lsr #31
54e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, lsr #32
55e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, asr #1
56e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, asr #31
57e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, asr #32
58e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, ror #1
59e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, ror #31
60e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach
61e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  @ Register shifts
62e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r6, r7, r8, lsl r9
63e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r6, r7, r8, lsr r9
64e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r6, r7, r8, asr r9
65e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r6, r7, r8, ror r9
66e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach  adc r4, r5, r6, rrx
67e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach
6837ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  @ Destination register is optional
6937ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r5, r6
7037ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, lsl #1
7137ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, lsl #31
7237ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, lsr #1
7337ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, lsr #31
7437ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, lsr #32
7537ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, asr #1
7637ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, asr #31
7737ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, asr #32
7837ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, ror #1
7937ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, ror #31
8037ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, rrx
8137ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r6, r7, lsl r9
8237ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r6, r7, lsr r9
8337ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r6, r7, asr r9
8437ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r6, r7, ror r9
8537ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach  adc r4, r5, rrx
8637ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach
87e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6              @ encoding: [0x06,0x40,0xa5,0xe0]
88e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach
89e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, lsl #1      @ encoding: [0x86,0x40,0xa5,0xe0]
90e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, lsl #31     @ encoding: [0x86,0x4f,0xa5,0xe0]
91e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, lsr #1      @ encoding: [0xa6,0x40,0xa5,0xe0]
92e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, lsr #31     @ encoding: [0xa6,0x4f,0xa5,0xe0]
93e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, lsr #32     @ encoding: [0x26,0x40,0xa5,0xe0]
94e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, asr #1      @ encoding: [0xc6,0x40,0xa5,0xe0]
95e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, asr #31     @ encoding: [0xc6,0x4f,0xa5,0xe0]
96e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, asr #32     @ encoding: [0x46,0x40,0xa5,0xe0]
97e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, ror #1      @ encoding: [0xe6,0x40,0xa5,0xe0]
98e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, ror #31     @ encoding: [0xe6,0x4f,0xa5,0xe0]
99e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach
100e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r6, r7, r8, lsl r9      @ encoding: [0x18,0x69,0xa7,0xe0]
101e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r6, r7, r8, lsr r9      @ encoding: [0x38,0x69,0xa7,0xe0]
102e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r6, r7, r8, asr r9      @ encoding: [0x58,0x69,0xa7,0xe0]
103e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r6, r7, r8, ror r9      @ encoding: [0x78,0x69,0xa7,0xe0]
104e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach@ CHECK: adc	r4, r5, r6, rrx         @ encoding: [0x66,0x40,0xa5,0xe0]
105e8606dc7c878d4562da5e3e5609b9d7d734d498cJim Grosbach
10637ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r5, r5, r6              @ encoding: [0x06,0x50,0xa5,0xe0]
10737ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, lsl #1      @ encoding: [0x85,0x40,0xa4,0xe0]
10837ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, lsl #31     @ encoding: [0x85,0x4f,0xa4,0xe0]
10937ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, lsr #1      @ encoding: [0xa5,0x40,0xa4,0xe0]
11037ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, lsr #31     @ encoding: [0xa5,0x4f,0xa4,0xe0]
11137ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, lsr #32     @ encoding: [0x25,0x40,0xa4,0xe0]
11237ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, asr #1      @ encoding: [0xc5,0x40,0xa4,0xe0]
11337ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, asr #31     @ encoding: [0xc5,0x4f,0xa4,0xe0]
11437ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, asr #32     @ encoding: [0x45,0x40,0xa4,0xe0]
11537ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, ror #1      @ encoding: [0xe5,0x40,0xa4,0xe0]
11637ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, ror #31     @ encoding: [0xe5,0x4f,0xa4,0xe0]
11737ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, rrx         @ encoding: [0x65,0x40,0xa4,0xe0]
11837ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r6, r6, r7, lsl r9      @ encoding: [0x17,0x69,0xa6,0xe0]
11937ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r6, r6, r7, lsr r9      @ encoding: [0x37,0x69,0xa6,0xe0]
12037ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r6, r6, r7, asr r9      @ encoding: [0x57,0x69,0xa6,0xe0]
12137ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r6, r6, r7, ror r9      @ encoding: [0x77,0x69,0xa6,0xe0]
12237ee464ea98544d3ed84cec6dde5f769ce003d5fJim Grosbach@ CHECK: adc	r4, r4, r5, rrx         @ encoding: [0x65,0x40,0xa4,0xe0]
123da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach
124da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach
125da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@------------------------------------------------------------------------------
1267ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@ FIXME: ADR
1277ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
1287ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach
1297ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
130da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ ADD
131da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@------------------------------------------------------------------------------
132da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, #0xf000
133da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, r6
134da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, r6, lsl #5
135da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, r6, lsr #5
136da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, r6, lsr #5
137da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, r6, asr #5
138da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, r6, ror #5
139da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r6, r7, r8, lsl r9
140da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r6, r7, r8, lsr r9
141da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r6, r7, r8, asr r9
142da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r6, r7, r8, ror r9
143da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, r6, rrx
144da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach
145da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  @ destination register is optional
146da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r5, #0xf000
147da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5
148da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, lsl #5
149da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, lsr #5
150da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, lsr #5
151da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, asr #5
152da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, ror #5
153da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r6, r7, lsl r9
154da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r6, r7, lsr r9
155da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r6, r7, asr r9
156da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r6, r7, ror r9
157da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach  add r4, r5, rrx
158da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach
159da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r5, #61440          @ encoding: [0x0f,0x4a,0x85,0xe2]
160da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r5, r6              @ encoding: [0x06,0x40,0x85,0xe0]
161da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r5, r6, lsl #5      @ encoding: [0x86,0x42,0x85,0xe0]
162da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r5, r6, lsr #5      @ encoding: [0xa6,0x42,0x85,0xe0]
163da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r5, r6, lsr #5      @ encoding: [0xa6,0x42,0x85,0xe0]
164da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r5, r6, asr #5      @ encoding: [0xc6,0x42,0x85,0xe0]
165da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r5, r6, ror #5      @ encoding: [0xe6,0x42,0x85,0xe0]
166da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r6, r7, r8, lsl r9      @ encoding: [0x18,0x69,0x87,0xe0]
167da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r6, r7, r8, lsr r9      @ encoding: [0x38,0x69,0x87,0xe0]
168da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r6, r7, r8, asr r9      @ encoding: [0x58,0x69,0x87,0xe0]
169da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r6, r7, r8, ror r9      @ encoding: [0x78,0x69,0x87,0xe0]
170da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r5, r6, rrx         @ encoding: [0x66,0x40,0x85,0xe0]
171da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach
172da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach
173da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r5, r5, #61440          @ encoding: [0x0f,0x5a,0x85,0xe2]
174da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r4, r5              @ encoding: [0x05,0x40,0x84,0xe0]
175da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r4, r5, lsl #5      @ encoding: [0x85,0x42,0x84,0xe0]
176da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r4, r5, lsr #5      @ encoding: [0xa5,0x42,0x84,0xe0]
177da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r4, r5, lsr #5      @ encoding: [0xa5,0x42,0x84,0xe0]
178da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r4, r5, asr #5      @ encoding: [0xc5,0x42,0x84,0xe0]
179da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r4, r5, ror #5      @ encoding: [0xe5,0x42,0x84,0xe0]
180da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r6, r6, r7, lsl r9      @ encoding: [0x17,0x69,0x86,0xe0]
181da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r6, r6, r7, lsr r9      @ encoding: [0x37,0x69,0x86,0xe0]
182da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r6, r6, r7, asr r9      @ encoding: [0x57,0x69,0x86,0xe0]
183da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r6, r6, r7, ror r9      @ encoding: [0x77,0x69,0x86,0xe0]
184da9f278c741e8ced7c1652720270918eb04ed348Jim Grosbach@ CHECK: add	r4, r4, r5, rrx         @ encoding: [0x65,0x40,0x84,0xe0]
18559642c260064a0c9140e048d702a21830020487fJim Grosbach
18659642c260064a0c9140e048d702a21830020487fJim Grosbach
18759642c260064a0c9140e048d702a21830020487fJim Grosbach@------------------------------------------------------------------------------
18859642c260064a0c9140e048d702a21830020487fJim Grosbach@ AND
18959642c260064a0c9140e048d702a21830020487fJim Grosbach@------------------------------------------------------------------------------
19059642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, #0xf
19159642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, r6
19259642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, r6, lsl #10
19359642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, r6, lsr #10
19459642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, r6, lsr #10
19559642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, r6, asr #10
19659642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, r6, ror #10
19759642c260064a0c9140e048d702a21830020487fJim Grosbach  and r6, r7, r8, lsl r2
19859642c260064a0c9140e048d702a21830020487fJim Grosbach  and r6, r7, r8, lsr r2
19959642c260064a0c9140e048d702a21830020487fJim Grosbach  and r6, r7, r8, asr r2
20059642c260064a0c9140e048d702a21830020487fJim Grosbach  and r6, r7, r8, ror r2
20159642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, r6, rrx
20259642c260064a0c9140e048d702a21830020487fJim Grosbach
20359642c260064a0c9140e048d702a21830020487fJim Grosbach  @ destination register is optional
20459642c260064a0c9140e048d702a21830020487fJim Grosbach  and r1, #0xf
20559642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1
20659642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, lsl #10
20759642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, lsr #10
20859642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, lsr #10
20959642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, asr #10
21059642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, ror #10
21159642c260064a0c9140e048d702a21830020487fJim Grosbach  and r6, r7, lsl r2
21259642c260064a0c9140e048d702a21830020487fJim Grosbach  and r6, r7, lsr r2
21359642c260064a0c9140e048d702a21830020487fJim Grosbach  and r6, r7, asr r2
21459642c260064a0c9140e048d702a21830020487fJim Grosbach  and r6, r7, ror r2
21559642c260064a0c9140e048d702a21830020487fJim Grosbach  and r10, r1, rrx
21659642c260064a0c9140e048d702a21830020487fJim Grosbach
21759642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r1, #15            @ encoding: [0x0f,0xa0,0x01,0xe2]
21859642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r1, r6             @ encoding: [0x06,0xa0,0x01,0xe0]
21959642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r1, r6, lsl #10    @ encoding: [0x06,0xa5,0x01,0xe0]
22059642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r1, r6, lsr #10    @ encoding: [0x26,0xa5,0x01,0xe0]
22159642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r1, r6, lsr #10    @ encoding: [0x26,0xa5,0x01,0xe0]
22259642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r1, r6, asr #10    @ encoding: [0x46,0xa5,0x01,0xe0]
22359642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r1, r6, ror #10    @ encoding: [0x66,0xa5,0x01,0xe0]
22459642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r6, r7, r8, lsl r2      @ encoding: [0x18,0x62,0x07,0xe0]
22559642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r6, r7, r8, lsr r2      @ encoding: [0x38,0x62,0x07,0xe0]
22659642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r6, r7, r8, asr r2      @ encoding: [0x58,0x62,0x07,0xe0]
22759642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r6, r7, r8, ror r2      @ encoding: [0x78,0x62,0x07,0xe0]
22859642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r1, r6, rrx        @ encoding: [0x66,0xa0,0x01,0xe0]
22959642c260064a0c9140e048d702a21830020487fJim Grosbach
23059642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r1, r1, #15             @ encoding: [0x0f,0x10,0x01,0xe2]
23159642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r10, r1            @ encoding: [0x01,0xa0,0x0a,0xe0]
23259642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r10, r1, lsl #10   @ encoding: [0x01,0xa5,0x0a,0xe0]
23359642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r10, r1, lsr #10   @ encoding: [0x21,0xa5,0x0a,0xe0]
23459642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r10, r1, lsr #10   @ encoding: [0x21,0xa5,0x0a,0xe0]
23559642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r10, r1, asr #10   @ encoding: [0x41,0xa5,0x0a,0xe0]
23659642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r10, r1, ror #10   @ encoding: [0x61,0xa5,0x0a,0xe0]
23759642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r6, r6, r7, lsl r2      @ encoding: [0x17,0x62,0x06,0xe0]
23859642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r6, r6, r7, lsr r2      @ encoding: [0x37,0x62,0x06,0xe0]
23959642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r6, r6, r7, asr r2      @ encoding: [0x57,0x62,0x06,0xe0]
24059642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r6, r6, r7, ror r2      @ encoding: [0x77,0x62,0x06,0xe0]
24159642c260064a0c9140e048d702a21830020487fJim Grosbach@ CHECK: and	r10, r10, r1, rrx       @ encoding: [0x61,0xa0,0x0a,0xe0]
24259642c260064a0c9140e048d702a21830020487fJim Grosbach
2437ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
2447ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@ FIXME: ASR
2457ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
2467ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
2477ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@ FIXME: B
2487ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
2497ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
2507ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@ FIXME: BFC
2517ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
2527ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
2537ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@ FIXME: BFI
2547ed6d22e9637c52b3511ac6907830251d1124e60Jim Grosbach@------------------------------------------------------------------------------
255e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach
256e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@------------------------------------------------------------------------------
25776cbe02cdd57a297d9c6f1e5106e4718abd7ff9fJim Grosbach@ BIC
258e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@------------------------------------------------------------------------------
259e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, #0xf
260e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, r6
261e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, r6, lsl #10
262e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, r6, lsr #10
263e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, r6, lsr #10
264e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, r6, asr #10
265e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, r6, ror #10
266e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r6, r7, r8, lsl r2
267e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r6, r7, r8, lsr r2
268e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r6, r7, r8, asr r2
269e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r6, r7, r8, ror r2
270e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, r6, rrx
271e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach
272e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  @ destination register is optional
273e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r1, #0xf
274e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1
275e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, lsl #10
276e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, lsr #10
277e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, lsr #10
278e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, asr #10
279e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, ror #10
280e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r6, r7, lsl r2
281e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r6, r7, lsr r2
282e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r6, r7, asr r2
283e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r6, r7, ror r2
284e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach  bic r10, r1, rrx
285e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach
286e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r1, #15            @ encoding: [0x0f,0xa0,0xc1,0xe3]
287e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r1, r6             @ encoding: [0x06,0xa0,0xc1,0xe1]
288e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r1, r6, lsl #10    @ encoding: [0x06,0xa5,0xc1,0xe1]
289e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r1, r6, lsr #10    @ encoding: [0x26,0xa5,0xc1,0xe1]
290e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r1, r6, lsr #10    @ encoding: [0x26,0xa5,0xc1,0xe1]
291e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r1, r6, asr #10    @ encoding: [0x46,0xa5,0xc1,0xe1]
292e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r1, r6, ror #10    @ encoding: [0x66,0xa5,0xc1,0xe1]
293e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r6, r7, r8, lsl r2      @ encoding: [0x18,0x62,0xc7,0xe1]
294e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r6, r7, r8, lsr r2      @ encoding: [0x38,0x62,0xc7,0xe1]
295e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r6, r7, r8, asr r2      @ encoding: [0x58,0x62,0xc7,0xe1]
296e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r6, r7, r8, ror r2      @ encoding: [0x78,0x62,0xc7,0xe1]
297e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r1, r6, rrx        @ encoding: [0x66,0xa0,0xc1,0xe1]
298e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach
299e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach
300e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r1, r1, #15             @ encoding: [0x0f,0x10,0xc1,0xe3]
301e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r10, r1            @ encoding: [0x01,0xa0,0xca,0xe1]
302e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r10, r1, lsl #10   @ encoding: [0x01,0xa5,0xca,0xe1]
303e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r10, r1, lsr #10   @ encoding: [0x21,0xa5,0xca,0xe1]
304e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r10, r1, lsr #10   @ encoding: [0x21,0xa5,0xca,0xe1]
305e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r10, r1, asr #10   @ encoding: [0x41,0xa5,0xca,0xe1]
306e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r10, r1, ror #10   @ encoding: [0x61,0xa5,0xca,0xe1]
307e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r6, r6, r7, lsl r2      @ encoding: [0x17,0x62,0xc6,0xe1]
308e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r6, r6, r7, lsr r2      @ encoding: [0x37,0x62,0xc6,0xe1]
309e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r6, r6, r7, asr r2      @ encoding: [0x57,0x62,0xc6,0xe1]
310e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r6, r6, r7, ror r2      @ encoding: [0x77,0x62,0xc6,0xe1]
311e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach@ CHECK: bic	r10, r10, r1, rrx       @ encoding: [0x61,0xa0,0xca,0xe1]
312e52240c3705f3133eb8c4ebb4220054c68de2651Jim Grosbach
31321101d60ce94f51651f71eeb61ceb8264eccac83Jim Grosbach@------------------------------------------------------------------------------
31421101d60ce94f51651f71eeb61ceb8264eccac83Jim Grosbach@ BKPT
31521101d60ce94f51651f71eeb61ceb8264eccac83Jim Grosbach@------------------------------------------------------------------------------
31621101d60ce94f51651f71eeb61ceb8264eccac83Jim Grosbach  bkpt #10
31721101d60ce94f51651f71eeb61ceb8264eccac83Jim Grosbach  bkpt #65535
31821101d60ce94f51651f71eeb61ceb8264eccac83Jim Grosbach
319fff76ee7ef007b2bb74804f165fee475e30ead0dJim Grosbach@ CHECK: bkpt  #10                      @ encoding: [0x7a,0x00,0x20,0xe1]
320fff76ee7ef007b2bb74804f165fee475e30ead0dJim Grosbach@ CHECK: bkpt  #65535                   @ encoding: [0x7f,0xff,0x2f,0xe1]
32137023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach
32237023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach@------------------------------------------------------------------------------
32337023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach@ BL/BLX (immediate)
32437023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach@------------------------------------------------------------------------------
32537023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach
32637023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach  bl _bar
32737023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach  @ FIXME: blx _bar
32837023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach
329f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@ CHECK: bl  _bar @ encoding: [A,A,A,0xeb]
330f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@ CHECK:   @   fixup A - offset: 0, value: _bar, kind: fixup_arm_uncondbranch
331f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach
332f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@------------------------------------------------------------------------------
333f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@ BLX (register)
334f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@------------------------------------------------------------------------------
33537023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach  blx r2
33637023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach  blxne r2
33737023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach
33837023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach@ CHECK: blx r2                         @ encoding: [0x32,0xff,0x2f,0xe1]
33937023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach@ CHECK: blxne r2                       @ encoding: [0x32,0xff,0x2f,0x11]
34037023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach
341f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@------------------------------------------------------------------------------
342f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@ BX
343f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@------------------------------------------------------------------------------
344f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach
345f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach  bx r2
346f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach  bxne r2
347f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach
348f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@ CHECK: bx	r2                      @ encoding: [0x12,0xff,0x2f,0xe1]
349f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@ CHECK: bxne	r2                      @ encoding: [0x12,0xff,0x2f,0x11]
350f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach
351f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@------------------------------------------------------------------------------
352f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@ BXJ
353f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@------------------------------------------------------------------------------
354f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach
355f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach  bxj r2
356f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach  bxjne r2
35737023b05c84000373fcfc0871edad3c2b995be33Jim Grosbach
358f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@ CHECK: bxj	r2                      @ encoding: [0x22,0xff,0x2f,0xe1]
359f333d471d2cdd47d830dfe3a3e40efbb106c100dJim Grosbach@ CHECK: bxjne	r2                      @ encoding: [0x22,0xff,0x2f,0x11]
36083ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach
36183ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach@------------------------------------------------------------------------------
36283ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach@ FIXME: CBNZ/CBZ
36383ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach@------------------------------------------------------------------------------
36483ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach
36583ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach
36683ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach@------------------------------------------------------------------------------
36783ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach@ CDP/CDP2
36883ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach@------------------------------------------------------------------------------
369d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach  cdp  p7, #1, c1, c1, c1, #4
370d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach  cdp2  p7, #1, c1, c1, c1, #4
37183ab070fc1fbb02ca77b0a37e6ae0eacf58001e1Jim Grosbach
372d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@ CHECK: cdp  p7, #1, c1, c1, c1, #4     @ encoding: [0x81,0x17,0x11,0xee]
373d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@ CHECK: cdp2  p7, #1, c1, c1, c1, #4    @ encoding: [0x81,0x17,0x11,0xfe]
374d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach
375d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach
376d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@------------------------------------------------------------------------------
377d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@ CLREX
378d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@------------------------------------------------------------------------------
379d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach  clrex
380d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach
381d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@ CHECK: clrex                           @ encoding: [0x1f,0xf0,0x7f,0xf5]
382d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach
383d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach
384d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@------------------------------------------------------------------------------
385d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@ CLZ
386d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@------------------------------------------------------------------------------
387d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach  clz r1, r2
388d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach  clzeq r1, r2
389d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach
390d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@ CHECK: clz r1, r2                      @ encoding: [0x12,0x1f,0x6f,0xe1]
391d986bc66bc56251c2b7d5b9a89df14c4760568fcJim Grosbach@ CHECK: clzeq r1, r2                    @ encoding: [0x12,0x1f,0x6f,0x01]
39214ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach
39314ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@------------------------------------------------------------------------------
39414ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CMN
39514ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@------------------------------------------------------------------------------
39614ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r1, #0xf
39714ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r1, r6
39814ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r1, r6, lsl #10
39914ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r1, r6, lsr #10
40014ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn sp, r6, lsr #10
40114ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r1, r6, asr #10
40214ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r1, r6, ror #10
40314ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r7, r8, lsl r2
40414ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn sp, r8, lsr r2
40514ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r7, r8, asr r2
40614ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r7, r8, ror r2
40714ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmn r1, r6, rrx
40814ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach
40914ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r1, #15                 @ encoding: [0x0f,0x00,0x71,0xe3]
41014ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r1, r6                  @ encoding: [0x06,0x00,0x71,0xe1]
41114ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r1, r6, lsl #10         @ encoding: [0x06,0x05,0x71,0xe1]
41214ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r1, r6, lsr #10         @ encoding: [0x26,0x05,0x71,0xe1]
41314ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	sp, r6, lsr #10         @ encoding: [0x26,0x05,0x7d,0xe1]
41414ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r1, r6, asr #10         @ encoding: [0x46,0x05,0x71,0xe1]
41514ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r1, r6, ror #10         @ encoding: [0x66,0x05,0x71,0xe1]
41614ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r7, r8, lsl r2          @ encoding: [0x18,0x02,0x77,0xe1]
41714ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	sp, r8, lsr r2          @ encoding: [0x38,0x02,0x7d,0xe1]
41814ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r7, r8, asr r2          @ encoding: [0x58,0x02,0x77,0xe1]
41914ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r7, r8, ror r2          @ encoding: [0x78,0x02,0x77,0xe1]
42014ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmn	r1, r6, rrx             @ encoding: [0x66,0x00,0x71,0xe1]
42114ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach
42214ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@------------------------------------------------------------------------------
42314ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CMP
42414ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@------------------------------------------------------------------------------
42514ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r1, #0xf
42614ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r1, r6
42714ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r1, r6, lsl #10
42814ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r1, r6, lsr #10
42914ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp sp, r6, lsr #10
43014ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r1, r6, asr #10
43114ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r1, r6, ror #10
43214ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r7, r8, lsl r2
43314ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp sp, r8, lsr r2
43414ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r7, r8, asr r2
43514ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r7, r8, ror r2
43614ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach  cmp r1, r6, rrx
43714ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach
43814ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r1, #15                 @ encoding: [0x0f,0x00,0x51,0xe3]
43914ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r1, r6                  @ encoding: [0x06,0x00,0x51,0xe1]
44014ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r1, r6, lsl #10         @ encoding: [0x06,0x05,0x51,0xe1]
44114ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r1, r6, lsr #10         @ encoding: [0x26,0x05,0x51,0xe1]
44214ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	sp, r6, lsr #10         @ encoding: [0x26,0x05,0x5d,0xe1]
44314ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r1, r6, asr #10         @ encoding: [0x46,0x05,0x51,0xe1]
44414ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r1, r6, ror #10         @ encoding: [0x66,0x05,0x51,0xe1]
44514ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r7, r8, lsl r2          @ encoding: [0x18,0x02,0x57,0xe1]
44614ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	sp, r8, lsr r2          @ encoding: [0x38,0x02,0x5d,0xe1]
44714ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r7, r8, asr r2          @ encoding: [0x58,0x02,0x57,0xe1]
44814ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r7, r8, ror r2          @ encoding: [0x78,0x02,0x57,0xe1]
44914ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach@ CHECK: cmp	r1, r6, rrx             @ encoding: [0x66,0x00,0x51,0xe1]
45014ab1c3387a240a914cf8b1907bb3609bae72269Jim Grosbach
4516f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach@------------------------------------------------------------------------------
4526f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach@ DBG
4536f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach@------------------------------------------------------------------------------
4546f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach  dbg #0
4556f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach  dbg #5
4566f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach  dbg #15
4576f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach
4586f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach@ CHECK: dbg #0                         @ encoding: [0xf0,0xf0,0x20,0xe3]
4596f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach@ CHECK: dbg #5                         @ encoding: [0xf5,0xf0,0x20,0xe3]
4606f9f8845028d4d3b96c33417398034a71137d867Jim Grosbach@ CHECK: dbg #15                        @ encoding: [0xff,0xf0,0x20,0xe3]
461032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach
462032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach
463032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@------------------------------------------------------------------------------
464032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ DMB
465032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@------------------------------------------------------------------------------
466032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb sy
467032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb st
468032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb sh
469032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb ish
470032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb shst
471032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb ishst
472032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb un
473032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb nsh
474032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb unst
475032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb nshst
476032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb osh
477032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb oshst
478032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach  dmb
479032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach
480032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	sy                      @ encoding: [0x5f,0xf0,0x7f,0xf5]
481032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	st                      @ encoding: [0x5e,0xf0,0x7f,0xf5]
482032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	ish                     @ encoding: [0x5b,0xf0,0x7f,0xf5]
483032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	ish                     @ encoding: [0x5b,0xf0,0x7f,0xf5]
484032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	ishst                   @ encoding: [0x5a,0xf0,0x7f,0xf5]
485032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	ishst                   @ encoding: [0x5a,0xf0,0x7f,0xf5]
486032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	nsh                     @ encoding: [0x57,0xf0,0x7f,0xf5]
487032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	nsh                     @ encoding: [0x57,0xf0,0x7f,0xf5]
488032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	nshst                   @ encoding: [0x56,0xf0,0x7f,0xf5]
489032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	nshst                   @ encoding: [0x56,0xf0,0x7f,0xf5]
490032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	osh                     @ encoding: [0x53,0xf0,0x7f,0xf5]
491032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	oshst                   @ encoding: [0x52,0xf0,0x7f,0xf5]
492032434d622b6cd030a60bb9045a520c93b0d7d68Jim Grosbach@ CHECK: dmb	sy                      @ encoding: [0x5f,0xf0,0x7f,0xf5]
493e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach
494e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@------------------------------------------------------------------------------
495e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ DSB
496e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@------------------------------------------------------------------------------
497e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb sy
498e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb st
499e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb sh
500e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb ish
501e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb shst
502e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb ishst
503e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb un
504e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb nsh
505e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb unst
506e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb nshst
507e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb osh
508e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb oshst
509e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach  dsb
510e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach
511e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	sy                      @ encoding: [0x4f,0xf0,0x7f,0xf5]
512e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	st                      @ encoding: [0x4e,0xf0,0x7f,0xf5]
513e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	ish                     @ encoding: [0x4b,0xf0,0x7f,0xf5]
514e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	ish                     @ encoding: [0x4b,0xf0,0x7f,0xf5]
515e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	ishst                   @ encoding: [0x4a,0xf0,0x7f,0xf5]
516e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	ishst                   @ encoding: [0x4a,0xf0,0x7f,0xf5]
517e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	nsh                     @ encoding: [0x47,0xf0,0x7f,0xf5]
518e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	nsh                     @ encoding: [0x47,0xf0,0x7f,0xf5]
519e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	nshst                   @ encoding: [0x46,0xf0,0x7f,0xf5]
520e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	nshst                   @ encoding: [0x46,0xf0,0x7f,0xf5]
521e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	osh                     @ encoding: [0x43,0xf0,0x7f,0xf5]
522e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	oshst                   @ encoding: [0x42,0xf0,0x7f,0xf5]
523e77494e3e3da59afaa51d1bbcf732fa2851d865dJim Grosbach@ CHECK: dsb	sy                      @ encoding: [0x4f,0xf0,0x7f,0xf5]
52400a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach
52500a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@------------------------------------------------------------------------------
52600a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ EOR
52700a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@------------------------------------------------------------------------------
52800a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, #0xf000
52900a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, r6
53000a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, r6, lsl #5
53100a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, r6, lsr #5
53200a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, r6, lsr #5
53300a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, r6, asr #5
53400a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, r6, ror #5
53500a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r6, r7, r8, lsl r9
53600a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r6, r7, r8, lsr r9
53700a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r6, r7, r8, asr r9
53800a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r6, r7, r8, ror r9
53900a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, r6, rrx
54000a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach
54100a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  @ destination register is optional
54200a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r5, #0xf000
54300a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5
54400a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, lsl #5
54500a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, lsr #5
54600a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, lsr #5
54700a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, asr #5
54800a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, ror #5
54900a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r6, r7, lsl r9
55000a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r6, r7, lsr r9
55100a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r6, r7, asr r9
55200a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r6, r7, ror r9
55300a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach  eor r4, r5, rrx
55400a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach
55500a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r5, #61440          @ encoding: [0x0f,0x4a,0x25,0xe2]
55600a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r5, r6              @ encoding: [0x06,0x40,0x25,0xe0]
55700a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r5, r6, lsl #5      @ encoding: [0x86,0x42,0x25,0xe0]
55800a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r5, r6, lsr #5      @ encoding: [0xa6,0x42,0x25,0xe0]
55900a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r5, r6, lsr #5      @ encoding: [0xa6,0x42,0x25,0xe0]
56000a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r5, r6, asr #5      @ encoding: [0xc6,0x42,0x25,0xe0]
56100a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r5, r6, ror #5      @ encoding: [0xe6,0x42,0x25,0xe0]
56200a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r6, r7, r8, lsl r9      @ encoding: [0x18,0x69,0x27,0xe0]
56300a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r6, r7, r8, lsr r9      @ encoding: [0x38,0x69,0x27,0xe0]
56400a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r6, r7, r8, asr r9      @ encoding: [0x58,0x69,0x27,0xe0]
56500a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r6, r7, r8, ror r9      @ encoding: [0x78,0x69,0x27,0xe0]
56600a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r5, r6, rrx         @ encoding: [0x66,0x40,0x25,0xe0]
56700a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach
56800a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach
56900a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r5, r5, #61440          @ encoding: [0x0f,0x5a,0x25,0xe2]
57000a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r4, r5              @ encoding: [0x05,0x40,0x24,0xe0]
57100a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r4, r5, lsl #5      @ encoding: [0x85,0x42,0x24,0xe0]
57200a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r4, r5, lsr #5      @ encoding: [0xa5,0x42,0x24,0xe0]
57300a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r4, r5, lsr #5      @ encoding: [0xa5,0x42,0x24,0xe0]
57400a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r4, r5, asr #5      @ encoding: [0xc5,0x42,0x24,0xe0]
57500a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r4, r5, ror #5      @ encoding: [0xe5,0x42,0x24,0xe0]
57600a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r6, r6, r7, lsl r9      @ encoding: [0x17,0x69,0x26,0xe0]
57700a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r6, r6, r7, lsr r9      @ encoding: [0x37,0x69,0x26,0xe0]
57800a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r6, r6, r7, asr r9      @ encoding: [0x57,0x69,0x26,0xe0]
57900a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r6, r6, r7, ror r9      @ encoding: [0x77,0x69,0x26,0xe0]
58000a66653cbe56dfbdb831172b54097bf8256a191Jim Grosbach@ CHECK: eor	r4, r4, r5, rrx         @ encoding: [0x65,0x40,0x24,0xe0]
581791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach
582791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach
583791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach@------------------------------------------------------------------------------
584791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach@ ISB
585791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach@------------------------------------------------------------------------------
586791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach        isb sy
587791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach        isb
588791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach
589791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach@ CHECK: isb sy                         @ encoding: [0x6f,0xf0,0x7f,0xf5]
590791feea10071223886e2fe2bfa0e1f4cb2c0ce74Jim Grosbach@ CHECK: isb sy                         @ encoding: [0x6f,0xf0,0x7f,0xf5]
5913b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
5923b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
5933b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
5943b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@------------------------------------------------------------------------------
5953b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ LDM*
5963b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@------------------------------------------------------------------------------
5973b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldm       r2, {r1,r3-r6,sp}
5983b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldmia     r2, {r1,r3-r6,sp}
5993b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldmib     r2, {r1,r3-r6,sp}
6003b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldmda     r2, {r1,r3-r6,sp}
6013b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldmdb     r2, {r1,r3-r6,sp}
6023b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldmfd     r2, {r1,r3-r6,sp}
6033b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
6043b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        @ with update
6053b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldm       r2!, {r1,r3-r6,sp}
6063b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldmib     r2!, {r1,r3-r6,sp}
6073b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldmda     r2!, {r1,r3-r6,sp}
6083b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        ldmdb     r2!, {r1,r3-r6,sp}
6093b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
6103b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldm   r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x92,0xe8]
6113b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldm   r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x92,0xe8]
6123b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldmib r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x92,0xe9]
6133b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldmda r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x12,0xe8]
6143b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldmdb r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x12,0xe9]
6153b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldm   r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x92,0xe8]
6163b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
6173b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldm   r2!, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0xb2,0xe8]
6183b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldmib r2!, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0xb2,0xe9]
6193b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldmda r2!, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x32,0xe8]
6203b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: ldmdb r2!, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x32,0xe9]
6213b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
622e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@------------------------------------------------------------------------------
623e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@ FIXME: LDR*
624e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@------------------------------------------------------------------------------
625e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@------------------------------------------------------------------------------
626e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@ FIXME: LSL
627e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@------------------------------------------------------------------------------
628e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@------------------------------------------------------------------------------
629e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@ FIXME: LSR
630e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@------------------------------------------------------------------------------
631e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach
632e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@------------------------------------------------------------------------------
633e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@ MCR/MCR2
634e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@------------------------------------------------------------------------------
635e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach        mcr  p7, #1, r5, c1, c1, #4
636e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach        mcr2  p7, #1, r5, c1, c1, #4
637e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach
638e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@ CHECK: mcr  p7, #1, r5, c1, c1, #4 @ encoding: [0x91,0x57,0x21,0xee]
639e540c7422ca13c950f0e8f6f93af7225bb7742a9Jim Grosbach@ CHECK: mcr2  p7, #1, r5, c1, c1, #4 @ encoding: [0x91,0x57,0x21,0xfe]
6403b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
6413b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@------------------------------------------------------------------------------
642c8ae39e746a20dc326def0ccfc052df3e21f16d3Jim Grosbach@ MCRR/MCRR2
643c8ae39e746a20dc326def0ccfc052df3e21f16d3Jim Grosbach@------------------------------------------------------------------------------
644c8ae39e746a20dc326def0ccfc052df3e21f16d3Jim Grosbach        mcrr  p7, #15, r5, r4, c1
645c8ae39e746a20dc326def0ccfc052df3e21f16d3Jim Grosbach        mcrr2  p7, #15, r5, r4, c1
646c8ae39e746a20dc326def0ccfc052df3e21f16d3Jim Grosbach
647c8ae39e746a20dc326def0ccfc052df3e21f16d3Jim Grosbach@ CHECK: mcrr  p7, #15, r5, r4, c1 @ encoding: [0xf1,0x57,0x44,0xec]
648c8ae39e746a20dc326def0ccfc052df3e21f16d3Jim Grosbach@ CHECK: mcrr2  p7, #15, r5, r4, c1 @ encoding: [0xf1,0x57,0x44,0xfc]
649c8ae39e746a20dc326def0ccfc052df3e21f16d3Jim Grosbach
65070d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach
65170d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@------------------------------------------------------------------------------
65270d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@ MLA
65370d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@------------------------------------------------------------------------------
65470d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach        mla  r1,r2,r3,r4
65570d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach        mlas r1,r2,r3,r4
65670d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach        mlane  r1,r2,r3,r4
65770d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach        mlasne r1,r2,r3,r4
65870d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach
65970d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@ CHECK: mla 	r1, r2, r3, r4 @ encoding: [0x92,0x43,0x21,0xe0]
66070d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@ CHECK: mlas	r1, r2, r3, r4 @ encoding: [0x92,0x43,0x31,0xe0]
66170d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@ CHECK: mlane 	r1, r2, r3, r4 @ encoding: [0x92,0x43,0x21,0x10]
66270d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@ CHECK: mlasne	r1, r2, r3, r4 @ encoding: [0x92,0x43,0x31,0x10]
66370d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach
66470d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@------------------------------------------------------------------------------
66570d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@ MLS
66670d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@------------------------------------------------------------------------------
66770d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach        mls  r2,r5,r6,r3
66870d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach        mlsne  r2,r5,r6,r3
66970d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach
67070d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@ CHECK: mls	r2, r5, r6, r3          @ encoding: [0x95,0x36,0x62,0xe0]
67170d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach@ CHECK: mlsne	r2, r5, r6, r3          @ encoding: [0x95,0x36,0x62,0x10]
67270d8fcfaa04eb20541b006a8fb97cbc1d3033cc4Jim Grosbach
673c8ae39e746a20dc326def0ccfc052df3e21f16d3Jim Grosbach@------------------------------------------------------------------------------
674ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach@ MOV (immediate)
675ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach@------------------------------------------------------------------------------
676ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach    mov r3, #7
677ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach    mov r4, #0xff0
678ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach    mov r5, #0xff0000
679ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach    mov r6, #0xffff
680ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach    movw r9, #0xffff
6815f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach    movs r3, #7
6825f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach    moveq r4, #0xff0
6835f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach    movseq r5, #0xff0000
684ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach
685ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach@ CHECK: mov	r3, #7                  @ encoding: [0x07,0x30,0xa0,0xe3]
686ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach@ CHECK: mov	r4, #4080               @ encoding: [0xff,0x4e,0xa0,0xe3]
687ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach@ CHECK: mov	r5, #16711680           @ encoding: [0xff,0x58,0xa0,0xe3]
688ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach@ CHECK: movw	r6, #65535              @ encoding: [0xff,0x6f,0x0f,0xe3]
689ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach@ CHECK: movw	r9, #65535              @ encoding: [0xff,0x9f,0x0f,0xe3]
6905f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@ CHECK: movs	r3, #7                  @ encoding: [0x07,0x30,0xb0,0xe3]
6915f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@ CHECK: moveq	r4, #4080               @ encoding: [0xff,0x4e,0xa0,0x03]
6925f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@ CHECK: movseq	r5, #16711680           @ encoding: [0xff,0x58,0xb0,0x03]
6935f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach
6945f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@------------------------------------------------------------------------------
6955f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@ MOV (register)
6965f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@------------------------------------------------------------------------------
6975f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach        mov r2, r3
6985f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach        movs r2, r3
6995f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach        moveq r2, r3
7005f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach        movseq r2, r3
7015f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach
7025f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@ CHECK: mov	r2, r3                  @ encoding: [0x03,0x20,0xa0,0xe1]
7035f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@ CHECK: movs	r2, r3                  @ encoding: [0x03,0x20,0xb0,0xe1]
7045f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@ CHECK: moveq	r2, r3                  @ encoding: [0x03,0x20,0xa0,0x01]
7055f16057d1e4b711d492091bc555693a03d4a1b6eJim Grosbach@ CHECK: movseq	r2, r3                  @ encoding: [0x03,0x20,0xb0,0x01]
706ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach
707ffa3225e26cc1977d20f0d9649fcd6f38a3c4815Jim Grosbach@------------------------------------------------------------------------------
7081a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach@ MOVT
7091a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach@------------------------------------------------------------------------------
7101a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach    movt r3, #7
7111a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach    movt r6, #0xffff
7121a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach    movteq r4, #0xff0
7131a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach
7141a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach@ CHECK: movt	r3, #7                  @ encoding: [0x07,0x30,0x40,0xe3]
7151a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach@ CHECK: movt	r6, #65535              @ encoding: [0xff,0x6f,0x4f,0xe3]
7161a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach@ CHECK: movteq	r4, #4080               @ encoding: [0xf0,0x4f,0x40,0x03]
7171a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach
7182317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach
7192317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@------------------------------------------------------------------------------
7202317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@ MRC/MRC2
7212317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@------------------------------------------------------------------------------
7222317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach        mrc  p14, #0, r1, c1, c2, #4
7232317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach        mrc2  p14, #0, r1, c1, c2, #4
7242317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach
7252317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@ CHECK: mrc  p14, #0, r1, c1, c2, #4   @ encoding: [0x92,0x1e,0x11,0xee]
7262317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@ CHECK: mrc2  p14, #0, r1, c1, c2, #4  @ encoding: [0x92,0x1e,0x11,0xfe]
7272317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach
7282317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@------------------------------------------------------------------------------
7292317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@ MRRC/MRRC2
7302317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@------------------------------------------------------------------------------
7312317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach        mrrc  p7, #1, r5, r4, c1
7322317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach        mrrc2  p7, #1, r5, r4, c1
7332317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach
7342317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@ CHECK: mrrc  p7, #1, r5, r4, c1       @ encoding: [0x11,0x57,0x54,0xec]
7352317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach@ CHECK: mrrc2  p7, #1, r5, r4, c1      @ encoding: [0x11,0x57,0x54,0xfc]
7362317fe1584e02582c616c1c4d15954999ff5525aJim Grosbach
73780d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach
73880d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach@------------------------------------------------------------------------------
73980d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach@ MRS
74080d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach@------------------------------------------------------------------------------
74180d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach        mrs  r8, apsr
74280d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach        mrs  r8, cpsr
74380d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach        mrs  r8, spsr
74480d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach@ CHECK: mrs  r8, apsr @ encoding: [0x00,0x80,0x0f,0xe1]
74580d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach@ CHECK: mrs  r8, apsr @ encoding: [0x00,0x80,0x0f,0xe1]
74680d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach@ CHECK: mrs  r8, spsr @ encoding: [0x00,0x80,0x4f,0xe1]
74780d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach
74880d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach
74980d01dd3d19a84621324ac444c6749602df7a513Jim Grosbach
7501a2be4db5b12cb7bfa351bcebd5e94b0decb021fJim Grosbach@------------------------------------------------------------------------------
751b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ MSR
752b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@------------------------------------------------------------------------------
753b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach
754b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  apsr, #5
755b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  apsr_g, #5
756b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  apsr_nzcvq, #5
757b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  APSR_nzcvq, #5
758b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  apsr_nzcvqg, #5
759b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_fc, #5
760b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_c, #5
761b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_x, #5
762b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_fc, #5
763b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_all, #5
764b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_fsx, #5
765b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  spsr_fc, #5
766b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  SPSR_fsxc, #5
767b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_fsxc, #5
768b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach
769b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	CPSR_fc, #5             @ encoding: [0x05,0xf0,0x29,0xe3]
770b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	APSR_g, #5              @ encoding: [0x05,0xf0,0x24,0xe3]
771b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	APSR_nzcvq, #5          @ encoding: [0x05,0xf0,0x28,0xe3]
772b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	APSR_nzcvq, #5          @ encoding: [0x05,0xf0,0x28,0xe3]
773b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	APSR_nzcvqg, #5         @ encoding: [0x05,0xf0,0x2c,0xe3]
774b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	CPSR_fc, #5             @ encoding: [0x05,0xf0,0x29,0xe3]
775b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	CPSR_c, #5              @ encoding: [0x05,0xf0,0x21,0xe3]
776b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	CPSR_x, #5              @ encoding: [0x05,0xf0,0x22,0xe3]
777b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	CPSR_fc, #5             @ encoding: [0x05,0xf0,0x29,0xe3]
778b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	CPSR_fc, #5             @ encoding: [0x05,0xf0,0x29,0xe3]
779b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	CPSR_fsx, #5            @ encoding: [0x05,0xf0,0x2e,0xe3]
780b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	SPSR_fc, #5             @ encoding: [0x05,0xf0,0x69,0xe3]
781b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	SPSR_fsxc, #5           @ encoding: [0x05,0xf0,0x6f,0xe3]
782b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr	CPSR_fsxc, #5           @ encoding: [0x05,0xf0,0x2f,0xe3]
783b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach
784b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  apsr, r0
785b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  apsr_g, r0
786b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  apsr_nzcvq, r0
787b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  APSR_nzcvq, r0
788b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  apsr_nzcvqg, r0
789b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_fc, r0
790b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_c, r0
791b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_x, r0
792b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_fc, r0
793b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_all, r0
794b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_fsx, r0
795b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  spsr_fc, r0
796b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  SPSR_fsxc, r0
797b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach        msr  cpsr_fsxc, r0
798b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach
799b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  CPSR_fc, r0 @ encoding: [0x00,0xf0,0x29,0xe1]
800b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  APSR_g, r0 @ encoding: [0x00,0xf0,0x24,0xe1]
801b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  APSR_nzcvq, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
802b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  APSR_nzcvq, r0 @ encoding: [0x00,0xf0,0x28,0xe1]
803b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  APSR_nzcvqg, r0 @ encoding: [0x00,0xf0,0x2c,0xe1]
804b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  CPSR_fc, r0 @ encoding: [0x00,0xf0,0x29,0xe1]
805b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  CPSR_c, r0 @ encoding: [0x00,0xf0,0x21,0xe1]
806b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  CPSR_x, r0 @ encoding: [0x00,0xf0,0x22,0xe1]
807b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  CPSR_fc, r0 @ encoding: [0x00,0xf0,0x29,0xe1]
808b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  CPSR_fc, r0 @ encoding: [0x00,0xf0,0x29,0xe1]
809b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  CPSR_fsx, r0 @ encoding: [0x00,0xf0,0x2e,0xe1]
810b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  SPSR_fc, r0 @ encoding: [0x00,0xf0,0x69,0xe1]
811b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  SPSR_fsxc, r0 @ encoding: [0x00,0xf0,0x6f,0xe1]
812b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@ CHECK: msr  CPSR_fsxc, r0 @ encoding: [0x00,0xf0,0x2f,0xe1]
813b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach
814b29b4dd988c50d5c4a15cd196e7910bf46f30b83Jim Grosbach@------------------------------------------------------------------------------
815ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach@ MUL
816ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach@------------------------------------------------------------------------------
817ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach
818ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach  mul r5, r6, r7
819ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach  muls r5, r6, r7
820ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach  mulgt r5, r6, r7
821ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach  mulsle r5, r6, r7
822ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach
823ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach@ CHECK: mul	r5, r6, r7              @ encoding: [0x96,0x07,0x05,0xe0]
824ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach@ CHECK: muls	r5, r6, r7              @ encoding: [0x96,0x07,0x15,0xe0]
825ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach@ CHECK: mulgt	r5, r6, r7              @ encoding: [0x96,0x07,0x05,0xc0]
826ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach@ CHECK: mulsle	r5, r6, r7              @ encoding: [0x96,0x07,0x15,0xd0]
827ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach
828c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
829c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@------------------------------------------------------------------------------
830c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ MVN (immediate)
831c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@------------------------------------------------------------------------------
832c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach    mvn r3, #7
833c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach    mvn r4, #0xff0
834c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach    mvn r5, #0xff0000
835c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach    mvns r3, #7
836c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach    mvneq r4, #0xff0
837c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach    mvnseq r5, #0xff0000
838c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
839c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r3, #7                  @ encoding: [0x07,0x30,0xe0,0xe3]
840c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r4, #4080               @ encoding: [0xff,0x4e,0xe0,0xe3]
841c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r5, #16711680           @ encoding: [0xff,0x58,0xe0,0xe3]
842c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvns	r3, #7                  @ encoding: [0x07,0x30,0xf0,0xe3]
843c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvneq	r4, #4080               @ encoding: [0xff,0x4e,0xe0,0x03]
844c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvnseq	r5, #16711680           @ encoding: [0xff,0x58,0xf0,0x03]
845c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
846c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
847c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@------------------------------------------------------------------------------
848c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ MVN (register)
849c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@------------------------------------------------------------------------------
850c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvn r2, r3
851c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvns r2, r3
852c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvn r5, r6, lsl #19
853c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvn r5, r6, lsr #9
854c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvn r5, r6, asr #4
855c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvn r5, r6, ror #6
856c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvn r5, r6, rrx
857c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvneq r2, r3
858c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvnseq r2, r3, lsl #10
859c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
860c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r2, r3                  @ encoding: [0x03,0x20,0xe0,0xe1]
861c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvns	r2, r3                  @ encoding: [0x03,0x20,0xf0,0xe1]
862c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r5, r6, lsl #19         @ encoding: [0x86,0x59,0xe0,0xe1]
863c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r5, r6, lsr #9          @ encoding: [0xa6,0x54,0xe0,0xe1]
864c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r5, r6, asr #4          @ encoding: [0x46,0x52,0xe0,0xe1]
865c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r5, r6, ror #6          @ encoding: [0x66,0x53,0xe0,0xe1]
866c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r5, r6, rrx             @ encoding: [0x66,0x50,0xe0,0xe1]
867c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvneq	r2, r3                  @ encoding: [0x03,0x20,0xe0,0x01]
868c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvnseq	r2, r3, lsl #10         @ encoding: [0x03,0x25,0xf0,0x01]
869c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
870c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
871c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@------------------------------------------------------------------------------
872c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ MVN (shifted register)
873c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@------------------------------------------------------------------------------
874c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvn r5, r6, lsl r7
875c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvns r5, r6, lsr r7
876c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvngt r5, r6, asr r7
877c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach        mvnslt r5, r6, ror r7
878c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
879c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvn	r5, r6, lsl r7          @ encoding: [0x16,0x57,0xe0,0xe1]
880c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvns	r5, r6, lsr r7          @ encoding: [0x36,0x57,0xf0,0xe1]
881c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvngt	r5, r6, asr r7          @ encoding: [0x56,0x57,0xe0,0xc1]
882c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach@ CHECK: mvnslt	r5, r6, ror r7          @ encoding: [0x76,0x57,0xf0,0xb1]
883c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
884a67851445902d1fc01fa2a37a3dfc347af949f84Jim Grosbach@------------------------------------------------------------------------------
885a67851445902d1fc01fa2a37a3dfc347af949f84Jim Grosbach@ NOP
886a67851445902d1fc01fa2a37a3dfc347af949f84Jim Grosbach@------------------------------------------------------------------------------
887a67851445902d1fc01fa2a37a3dfc347af949f84Jim Grosbach        nop
888a67851445902d1fc01fa2a37a3dfc347af949f84Jim Grosbach        nopgt
889a67851445902d1fc01fa2a37a3dfc347af949f84Jim Grosbach
890a67851445902d1fc01fa2a37a3dfc347af949f84Jim Grosbach@ CHECK: nop @ encoding: [0x00,0xf0,0x20,0xe3]
891a67851445902d1fc01fa2a37a3dfc347af949f84Jim Grosbach@ CHECK: nopgt @ encoding: [0x00,0xf0,0x20,0xc3]
892a67851445902d1fc01fa2a37a3dfc347af949f84Jim Grosbach
893c3635c2e928a7ecde11398ff272411f6dea2dcd2Jim Grosbach
894ab40f4b737b0a87c4048a9ad2f0c02be735e3770Jim Grosbach@------------------------------------------------------------------------------
89588d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ ORR
89688d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@------------------------------------------------------------------------------
89788d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, #0xf000
89888d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, r6
89988d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, r6, lsl #5
90088d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, r6, lsr #5
90188d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, r6, lsr #5
90288d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, r6, asr #5
90388d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, r6, ror #5
90488d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r6, r7, r8, lsl r9
90588d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r6, r7, r8, lsr r9
90688d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r6, r7, r8, asr r9
90788d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r6, r7, r8, ror r9
90888d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, r6, rrx
90988d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach
91088d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        @ destination register is optional
91188d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r5, #0xf000
91288d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5
91388d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, lsl #5
91488d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, lsr #5
91588d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, lsr #5
91688d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, asr #5
91788d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, ror #5
91888d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r6, r7, lsl r9
91988d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r6, r7, lsr r9
92088d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r6, r7, asr r9
92188d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r6, r7, ror r9
92288d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orr r4, r5, rrx
92388d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach
92488d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r5, #61440          @ encoding: [0x0f,0x4a,0x85,0xe3]
92588d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r5, r6              @ encoding: [0x06,0x40,0x85,0xe1]
92688d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r5, r6, lsl #5      @ encoding: [0x86,0x42,0x85,0xe1]
92788d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r5, r6, lsr #5      @ encoding: [0xa6,0x42,0x85,0xe1]
92888d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r5, r6, lsr #5      @ encoding: [0xa6,0x42,0x85,0xe1]
92988d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r5, r6, asr #5      @ encoding: [0xc6,0x42,0x85,0xe1]
93088d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r5, r6, ror #5      @ encoding: [0xe6,0x42,0x85,0xe1]
93188d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r6, r7, r8, lsl r9      @ encoding: [0x18,0x69,0x87,0xe1]
93288d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r6, r7, r8, lsr r9      @ encoding: [0x38,0x69,0x87,0xe1]
93388d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r6, r7, r8, asr r9      @ encoding: [0x58,0x69,0x87,0xe1]
93488d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r6, r7, r8, ror r9      @ encoding: [0x78,0x69,0x87,0xe1]
93588d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r5, r6, rrx         @ encoding: [0x66,0x40,0x85,0xe1]
93688d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach
93788d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r5, r5, #61440          @ encoding: [0x0f,0x5a,0x85,0xe3]
93888d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r4, r5              @ encoding: [0x05,0x40,0x84,0xe1]
93988d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r4, r5, lsl #5      @ encoding: [0x85,0x42,0x84,0xe1]
94088d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r4, r5, lsr #5      @ encoding: [0xa5,0x42,0x84,0xe1]
94188d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r4, r5, lsr #5      @ encoding: [0xa5,0x42,0x84,0xe1]
94288d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r4, r5, asr #5      @ encoding: [0xc5,0x42,0x84,0xe1]
94388d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r4, r5, ror #5      @ encoding: [0xe5,0x42,0x84,0xe1]
94488d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r6, r6, r7, lsl r9      @ encoding: [0x17,0x69,0x86,0xe1]
94588d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r6, r6, r7, lsr r9      @ encoding: [0x37,0x69,0x86,0xe1]
94688d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r6, r6, r7, asr r9      @ encoding: [0x57,0x69,0x86,0xe1]
94788d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r6, r6, r7, ror r9      @ encoding: [0x77,0x69,0x86,0xe1]
94888d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orr	r4, r4, r5, rrx         @ encoding: [0x65,0x40,0x84,0xe1]
94988d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach
95088d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrseq r4, r5, #0xf000
95188d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrne r4, r5, r6
95288d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrseq r4, r5, r6, lsl #5
95388d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrlo r6, r7, r8, ror r9
95488d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrshi r4, r5, r6, rrx
95588d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrcs r5, #0xf000
95688d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrseq r4, r5
95788d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrne r6, r7, asr r9
95888d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrslt r6, r7, ror r9
95988d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach        orrsgt r4, r5, rrx
96088d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach
96188d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrseq	r4, r5, #61440          @ encoding: [0x0f,0x4a,0x95,0x03]
96288d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrne	r4, r5, r6              @ encoding: [0x06,0x40,0x85,0x11]
96388d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrseq	r4, r5, r6, lsl #5      @ encoding: [0x86,0x42,0x95,0x01]
96488d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrlo	r6, r7, r8, ror r9      @ encoding: [0x78,0x69,0x87,0x31]
96588d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrshi	r4, r5, r6, rrx         @ encoding: [0x66,0x40,0x95,0x81]
96688d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrhs	r5, r5, #61440          @ encoding: [0x0f,0x5a,0x85,0x23]
96788d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrseq	r4, r4, r5              @ encoding: [0x05,0x40,0x94,0x01]
96888d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrne	r6, r6, r7, asr r9      @ encoding: [0x57,0x69,0x86,0x11]
96988d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrslt	r6, r6, r7, ror r9      @ encoding: [0x77,0x69,0x96,0xb1]
97088d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@ CHECK: orrsgt	r4, r4, r5, rrx         @ encoding: [0x65,0x40,0x94,0xc1]
97188d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach
97261b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@------------------------------------------------------------------------------
97361b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@ PKH
97461b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@------------------------------------------------------------------------------
97561b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach        pkhbt r2, r2, r3
97661b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach        pkhbt r2, r2, r3, lsl #31
97761b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach        pkhbt r2, r2, r3, lsl #0
97861b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach        pkhbt r2, r2, r3, lsl #15
97961b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach
98061b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach        pkhtb r2, r2, r3
98161b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach        pkhtb r2, r2, r3, asr #31
98261b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach        pkhtb r2, r2, r3, asr #15
98361b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach
98461b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@ CHECK: pkhbt	r2, r2, r3              @ encoding: [0x13,0x20,0x82,0xe6]
98561b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@ CHECK: pkhbt	r2, r2, r3, lsl #31     @ encoding: [0x93,0x2f,0x82,0xe6]
98661b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@ CHECK: pkhbt	r2, r2, r3              @ encoding: [0x13,0x20,0x82,0xe6]
98761b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@ CHECK: pkhbt	r2, r2, r3, lsl #15     @ encoding: [0x93,0x27,0x82,0xe6]
98861b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach
98961b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@ CHECK: pkhbt	r2, r2, r3              @ encoding: [0x13,0x20,0x82,0xe6]
99061b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@ CHECK: pkhtb	r2, r2, r3, asr #31     @ encoding: [0xd3,0x2f,0x82,0xe6]
99161b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach@ CHECK: pkhtb	r2, r2, r3, asr #15     @ encoding: [0xd3,0x27,0x82,0xe6]
99261b1b21e9ad2b8af163a352766eeb159979f4ff2Jim Grosbach
99310c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@------------------------------------------------------------------------------
99410c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ FIXME: PLD
99510c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@------------------------------------------------------------------------------
99610c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@------------------------------------------------------------------------------
99710c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ FIXME: PLI
99810c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@------------------------------------------------------------------------------
99910c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach
100010c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach
100110c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@------------------------------------------------------------------------------
100210c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ POP
100310c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@------------------------------------------------------------------------------
100410c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach        pop {r7}
100510c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach        pop {r7, r8, r9, r10}
100610c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach
100710c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ FIXME: pop of a single register should encode as "ldr r7, [sp], #4"
100810c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ CHECK-FIXME: pop	{r7}                    @ encoding: [0x04,0x70,0x9d,0xe4]
100910c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ CHECK: pop	{r7, r8, r9, r10}       @ encoding: [0x80,0x07,0xbd,0xe8]
101010c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach
101110c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach
101210c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@------------------------------------------------------------------------------
101310c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ PUSH
101410c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@------------------------------------------------------------------------------
101510c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach        push {r7}
101610c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach        push {r7, r8, r9, r10}
101710c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach
101810c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ FIXME: push of a single register should encode as "str r7, [sp, #-4]!"
101910c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ CHECK-FIXME: push	{r7}                    @ encoding: [0x04,0x70,0x2d,0xe5]
102010c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach@ CHECK: push	{r7, r8, r9, r10}       @ encoding: [0x80,0x07,0x2d,0xe9]
102110c7d70a4e843b3006db9f5f583d6f6f56cc245eJim Grosbach
102288d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach
102388d1bc832ca5b458c8460929227be8eae6c6bdc3Jim Grosbach@------------------------------------------------------------------------------
10243b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ STM*
10253b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@------------------------------------------------------------------------------
10263b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stm       r2, {r1,r3-r6,sp}
10273b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stmia     r2, {r1,r3-r6,sp}
10283b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stmib     r2, {r1,r3-r6,sp}
10293b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stmda     r2, {r1,r3-r6,sp}
10303b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stmdb     r2, {r1,r3-r6,sp}
10313b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stmfd     r2, {r1,r3-r6,sp}
10323b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
10333b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        @ with update
10343b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stmia     r2!, {r1,r3-r6,sp}
10353b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stmib     r2!, {r1,r3-r6,sp}
10363b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stmda     r2!, {r1,r3-r6,sp}
10373b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach        stmdb     r2!, {r1,r3-r6,sp}
10383b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stm   r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x82,0xe8]
10393b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stm   r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x82,0xe8]
10403b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stmib r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x82,0xe9]
10413b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stmda r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x02,0xe8]
10423b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stmdb r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x02,0xe9]
10433b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stmdb r2, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x02,0xe9]
10443b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach
10453b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stm   r2!, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0xa2,0xe8]
10463b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stmib r2!, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0xa2,0xe9]
10473b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stmda r2!, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x22,0xe8]
10483b14a5c5469176effb921d91d4494f0aa2919fd0Jim Grosbach@ CHECK: stmdb r2!, {r1, r3, r4, r5, r6, sp} @ encoding: [0x7a,0x20,0x22,0xe9]
1049