Heuristic: If the number of operands in the alias are more than the number of
[llvm/stm8.git] / test / MC / Disassembler / ARM / thumb-tests.txt
blob895a5bb346ddea8a9fe47ac3e9d3bb07c33dc678
1 # RUN: llvm-mc --disassemble %s -triple=thumb-apple-darwin9 | FileCheck %s
3 # CHECK:        add     r5, sp, #68
4 0x11 0xad
6 # CHECK:        adcs    r0, r0, #1
7 0x50 0xf1 0x01 0x00
9 # CHECK:        b       #30
10 0x0f 0xe0
12 # CHECK:        bgt.w   #-16
13 0x3f 0xf7 0xf8 0xaf
15 # CHECK:        bfc     r0, #10, #10
16 0x6f 0xf3 0x93 0x20
18 # CHECK:        bfi     r2, r10, #0, #1
19 0x6a 0xf3 0x00 0x02
21 # CHECK:        cbnz    r7, #20
22 0x57 0xb9
24 # CHECK:        cmp     r3, r4
25 0xa3 0x42
27 # CHECK:        cmn.w   r0, #31
28 0x10 0xf1 0x1f 0x0f
30 # CHECK:        ldmia   r0!, {r1}
31 0x02 0xc8
33 # CHECK:        ldr     r5, #432
34 0x6c 0x4d
36 # CHECK:        str     r0, [r3]
37 0x18 0x60
39 # CHECK:        str     r0, [r3, #4]
40 0x58 0x60
42 # CHECK:        str     r2, [r5, r3]
43 0xea 0x50
45 # CHECK:        ldrb.w  r8, #-24
46 0x1f 0xf8 0x18 0x80
48 # CHECK:        ldrd    r0, r1, [r7, #64]!
49 0xf7 0xe9 0x10 0x01
51 # CHECK:        lsls.w  r0, r5, #1
52 0x5f 0xea 0x45 0x00
54 # CHECK:        mov     r11, r7
55 0xbb 0x46
57 # CHECK:        pkhtb   r2, r4, r6, asr #16
58 0xc4 0xea 0x26 0x42
60 # CHECK-NOT:    pkhbt   r2, r4, r6, lsl #0
61 # CHECK:        pkhbt   r2, r4, r6
62 0xc4 0xea 0x06 0x02
64 # CHECK:        pop.w   {r2, r4, r6, r8, r10, r12}
65 0xbd 0xe8 0x54 0x15
67 # CHECK:        push.w  {r2, r4, r6, r8, r10, r12}
68 0x2d 0xe9 0x54 0x15
70 # CHECK:        rsbs    r0, r0, #0
71 0x40 0x42
73 # CHECK-NOT:    rsb     r0, r2, r0, lsl #0
74 # CHECK:        rsb     r0, r2, r0
75 0xc2 0xeb 0x00 0x00
77 # CHECK-NOT:    ssat    r0, #17, r12, lsl #0
78 # CHECK:        ssat    r0, #17, r12
79 0x0c 0xf3 0x10 0x00
81 # CHECK:        strd    r0, r1, [r7, #64]
82 0xc7 0xe9 0x10 0x01
84 # CHECK:        sub     sp, #60
85 0x8f 0xb0
87 # CHECK:        subw    r0, pc, #1
88 0xaf 0xf2 0x01 0x00
90 # CHECK:        subw    r0, sp, #835
91 0xad 0xf2 0x43 0x30
93 # CHECK:        uqadd16 r3, r4, r5
94 0x94 0xfa 0x55 0xf3
96 # CHECK:        usada8  r5, r4, r3, r2
97 0x74 0xfb 0x03 0x25
99 # CHECK:        uxtab16 r1, r2, r3, ror #8
100 0x32 0xfa 0x93 0xf1
102 # IT block begin
103 # CHECK:        ittte   eq
104 0x03 0xbf
106 # CHECK:        moveq   r3, #3
107 0x03 0x23
109 # CHECK:        asreq   r1, r0, #5
110 0x41 0x11
112 # CHECK:        lsleq   r1, r0, #28
113 0x01 0x07
115 # CHECK:        stmiane r0!, {r1, r2, r3}
116 0x0e 0xc0
118 # IT block end
119 # CHECK:        rsbs    r1, r2, #0
120 0x51 0x42
122 # CHECK: cpsid.w  f
123 0xaf 0xf3 0x20 0x86
125 # CHECK: cps  #15
126 0xaf 0xf3 0x0f 0x81
128 # CHECK: cpsie.w  if, #10
129 0xaf 0xf3 0x6a 0x85
131 # CHECK: cpsie aif
132 0x67 0xb6
134 # CHECK: msr cpsr_fc, r0
135 0x80 0xf3 0x00 0x89
137 # CHECK: blx    #-4
138 0xff 0xf7 0xfe 0xef
140 # CHECK:        vpush   {d8, d9, d10}
141 0x2d 0xed 0x06 0x8b
143 # CHECK:        vcmpe.f64       d8, #0
144 0xb5 0xee 0xc0 0x8b
146 # CHECK:        stmdb.w sp, {r0, r2, r3, r8, r11, lr}
147 0x0d 0xe9 0x0d 0x49
149 # CHECK:        stmia   r5!, {r0, r1, r2, r3, r4}
150 0x1f 0xc5
152 # CHECK:        ldmia   r5, {r0, r1, r2, r3, r4, r5}
153 0x3f 0xcd
155 # CHECK:        ldmia   r5!, {r0, r1, r2, r3, r4}
156 0x1f 0xcd
158 # CHECK:        addw    r0, pc, #1050
159 0x0f 0xf2 0x1a 0x40
161 # CHECK:        ldrd    r3, r8, [r11, #-60]
162 0x5b 0xe9 0x0f 0x38
164 # CHECK:        ldrex   r8, [r2]
165 0x52 0xe8 0x00 0x8f
167 # CHECK:        ldrexd  r8, r9, [r2]
168 0xd2 0xe8 0x7f 0x89
170 # CHECK:        strexd  r1, r7, r8, [r2]
171 0xc2 0xe8 0x71 0x78
173 # CHECK:        tbh     [r5, r4, lsl #1]
174 0xd5 0xe8 0x14 0xf0
176 # CHECK:        tbb     [r5, r4]
177 0xd5 0xe8 0x04 0xf0
179 # CHECK:        ldr.w   r4, [sp, r4, lsl #3]
180 0x5d 0xf8 0x34 0x40
182 # CHECK:        ldr.w   r5, [r6, #30]
183 0xd6 0xf8 0x1e 0x50
185 # CHECK:        ldrh.w  r5, [r6, #30]
186 0xb6 0xf8 0x1e 0x50
188 # CHECK:        ldrt    r5, [r6, #30]
189 0x56 0xf8 0x1e 0x5e
191 # CHECK:        ldr     r5, [r6, #-30]
192 0x56 0xf8 0x1e 0x5c
194 # CHECK:        sel     r7, r3, r5
195 0xa3 0xfa 0x85 0xf7
197 # CHECK:        lsl.w   r7, r3, r5
198 0x03 0xfa 0x05 0xf7
200 # CHECK:        adds.w  r7, r3, r5
201 0x13 0xeb 0x05 0x07
203 # CHECK:        smlabt  r4, r3, r2, r1
204 0x13 0xfb 0x12 0x14
206 # CHECK:        smmulr  r7, r8, r9
207 0x58 0xfb 0x19 0xf7
209 # CHECK:        umull   r1, r2, r3, r4
210 0xa3 0xfb 0x04 0x12
212 # CHECK:        pld     [r5, r0, lsl #1]
213 0x15 0xf8 0x10 0xf0
215 # CHECK:        pld     [pc, #-16]
216 0x1f 0xf8 0x10 0xf0
218 # CHECK:        pld     [r5, #30]
219 0x95 0xf8 0x1e 0xf0
221 # CHECK:        stc2    p12, cr15, [r9], {137}
222 0x89 0xfc 0x89 0xfc
224 # CHECK:        vmov    r1, r0, d11
225 0x50 0xec 0x1b 0x1b
227 # CHECK:        dsb     nsh
228 0xbf 0xf3 0x47 0x8f
230 # CHECK:        isb
231 0xbf 0xf3 0x6f 0x8f
233 # CHECK:        asrs    r1, r0, #32
234 0x1 0x10
236 # CHECK:        lsr.w   r10, r0, #32
237 0x4f 0xea 0x10 0x0a
239 # CHECK:        blx     sp
240 0xe8 0x47
242 # CHECK:        bx      lr
243 0x70 0x47
245 # CHECK:        bx      pc
246 0x78 0x47
248 # CHECK:        svc     #230
249 0xe6 0xdf
251 # CHECK:        rfedb   lr
252 0x1e 0xe8 0x00 0xc0
254 # CHECK:        mov.w   r3, #4294967295
255 0x4f 0xf0 0xff 0x33
257 # CHECK:        mov     pc, sp
258 0xef 0x46
260 # CHECK:        nop
261 0x00 0xbf
263 # CHECK:        nop.w
264 0xaf 0xf3 0x00 0x80
266 # CHECK:        bne     #24
267 0x0c 0xd1