1 # RUN: llvm-mc -triple=thumbv7-apple-darwin -mcpu=cortex-a8 -disassemble < %s | FileCheck %s
3 #------------------------------------------------------------------------------
5 #------------------------------------------------------------------------------
6 # CHECK: adc r0, r1, #4
7 # CHECK: adcs r0, r1, #0
8 # CHECK: adc r1, r2, #255
9 # CHECK: adc r3, r7, #5570645
10 # CHECK: adc r8, r12, #2852170240
11 # CHECK: adc r9, r7, #2779096485
12 # CHECK: adc r5, r3, #2264924160
13 # CHECK: adc r4, r2, #2139095040
14 # CHECK: adc r4, r2, #1664
26 #------------------------------------------------------------------------------
28 #------------------------------------------------------------------------------
29 # CHECK: adc.w r4, r5, r6
30 # CHECK: adcs.w r4, r5, r6
31 # CHECK: adc.w r9, r1, r3
32 # CHECK: adcs.w r9, r1, r3
33 # CHECK: adc.w r0, r1, r3, ror #4
34 # CHECK: adcs.w r0, r1, r3, lsl #7
35 # CHECK: adc.w r0, r1, r3, lsr #31
36 # CHECK: adcs.w r0, r1, r3, asr #32
48 #------------------------------------------------------------------------------
50 #------------------------------------------------------------------------------
52 # CHECK: addeq r1, r2, #4
53 # CHECK: addwne r5, r3, #1023
54 # CHECK: addweq r4, r5, #293
55 # CHECK: add.w r2, sp, #1024
56 # CHECK: add.w r2, r8, #65280
57 # CHECK: addw r2, r3, #257
58 # CHECK: add.w r12, r6, #256
59 # CHECK: addw r12, r6, #256
60 # CHECK: adds.w r1, r2, #496
74 #------------------------------------------------------------------------------
76 #------------------------------------------------------------------------------
77 # CHECK: add.w r1, r2, r8
78 # CHECK: add.w r5, r9, r2, asr #32
79 # CHECK: adds.w r7, r3, r1, lsl #31
80 # CHECK: adds.w r0, r3, r6, lsr #25
81 # CHECK: add.w r4, r8, r1, ror #12
90 #------------------------------------------------------------------------------
92 #------------------------------------------------------------------------------
93 # CHECK: subw r11, pc, #3270
94 # CHECK: subw r11, pc, #826
95 # CHECK: subw r1, pc, #0
101 #------------------------------------------------------------------------------
103 #------------------------------------------------------------------------------
104 # CHECK: and r2, r5, #1044480
105 # CHECK: ands r3, r12, #15
106 # CHECK: and r1, r1, #255
113 #------------------------------------------------------------------------------
115 #------------------------------------------------------------------------------
116 # CHECK: and.w r4, r9, r8
117 # CHECK: and.w r1, r4, r8, asr #3
118 # CHECK: ands.w r2, r1, r7, lsl #1
119 # CHECK: ands.w r4, r5, r2, lsr #20
120 # CHECK: and.w r9, r12, r1, ror #17
128 #------------------------------------------------------------------------------
130 #------------------------------------------------------------------------------
131 # CHECK: asr.w r2, r3, #12
132 # CHECK: asrs.w r8, r3, #32
133 # CHECK: asrs.w r2, r3, #1
134 # CHECK: asr.w r2, r3, #4
135 # CHECK: asrs.w r2, r12, #15
137 # CHECK: asr.w r3, r3, #19
138 # CHECK: asrs.w r8, r8, #2
139 # CHECK: asrs.w r7, r7, #5
140 # CHECK: asr.w r12, r12, #21
154 #------------------------------------------------------------------------------
156 #------------------------------------------------------------------------------
157 # CHECK: asr.w r3, r4, r2
158 # CHECK: asr.w r1, r1, r2
159 # CHECK: asrs.w r3, r4, r8
165 #------------------------------------------------------------------------------
167 #------------------------------------------------------------------------------
168 # CHECK: bmi.w #-183396
173 # CHECK: b.w #-16777216
175 0x33 0xf0 0x21 0xb8 # rdar://12585795
178 #------------------------------------------------------------------------------
180 #------------------------------------------------------------------------------
181 # CHECK: bfc r5, #3, #17
183 # CHECK: bfclo r5, #3, #17
190 #------------------------------------------------------------------------------
192 #------------------------------------------------------------------------------
193 # CHECK: bfi r5, r2, #3, #17
195 # CHECK: bfine r5, r2, #3, #17
196 # CHECK: bfi r6, r0, #0, #32
197 # CHECK: bfi r6, r0, #31, #1
206 #------------------------------------------------------------------------------
208 #------------------------------------------------------------------------------
209 # CHECK: bic r10, r1, #15
210 # CHECK: bic.w r12, r3, r6
211 # CHECK: bic.w r11, r2, r6, lsl #12
212 # CHECK: bic.w r8, r4, r1, lsr #11
213 # CHECK: bic.w r7, r5, r7, lsr #15
214 # CHECK: bic.w r6, r7, r9, asr #32
215 # CHECK: bic.w r5, r6, r8, ror #1
217 # CHECK: bic r1, r1, #15
218 # CHECK: bic.w r1, r1, r1
219 # CHECK: bic.w r4, r4, r2, lsl #31
220 # CHECK: bic.w r6, r6, r3, lsr #12
221 # CHECK: bic.w r7, r7, r4, lsr #7
222 # CHECK: bic.w r8, r8, r5, asr #15
223 # CHECK: bic.w r12, r12, r6, ror #29
242 #------------------------------------------------------------------------------
244 #------------------------------------------------------------------------------
254 #------------------------------------------------------------------------------
256 #------------------------------------------------------------------------------
258 # CHECK: cbnz r7, #12
266 #------------------------------------------------------------------------------
268 #------------------------------------------------------------------------------
269 # CHECK: cdp p7, #1, c1, c1, c1, #4
270 # CHECK: cdp2 p7, #1, c1, c1, c1, #4
276 #------------------------------------------------------------------------------
278 #------------------------------------------------------------------------------
288 #------------------------------------------------------------------------------
290 #------------------------------------------------------------------------------
300 #------------------------------------------------------------------------------
302 #------------------------------------------------------------------------------
303 #CHECK: cmn.w r1, #15
305 #CHECK: cmn.w r1, r6, lsl #10
306 #CHECK: cmn.w r1, r6, lsr #10
307 #CHECK: cmn.w sp, r6, lsr #10
308 #CHECK: cmn.w r1, r6, asr #10
309 #CHECK: cmn.w r1, r6, ror #10
320 #------------------------------------------------------------------------------
322 #------------------------------------------------------------------------------
323 #CHECK: cmp.w r5, #65280
324 #CHECK: cmp.w r4, r12
325 #CHECK: cmp.w r9, r6, lsl #12
326 #CHECK: cmp.w r3, r7, lsr #31
327 #CHECK: cmp.w sp, r6, lsr #1
328 #CHECK: cmp.w r2, r5, asr #24
329 #CHECK: cmp.w r1, r4, ror #15
340 #------------------------------------------------------------------------------
342 #------------------------------------------------------------------------------
352 #------------------------------------------------------------------------------
354 #------------------------------------------------------------------------------
390 #------------------------------------------------------------------------------
392 #------------------------------------------------------------------------------
428 #------------------------------------------------------------------------------
430 #------------------------------------------------------------------------------
431 #CHECK: eor r4, r5, #61440
432 #CHECK: eor.w r4, r5, r6
433 #CHECK: eor.w r4, r5, r6, lsl #5
434 #CHECK: eor.w r4, r5, r6, lsr #5
435 #CHECK: eor.w r4, r5, r6, lsr #5
436 #CHECK: eor.w r4, r5, r6, asr #5
437 #CHECK: eor.w r4, r5, r6, ror #5
448 #------------------------------------------------------------------------------
450 #------------------------------------------------------------------------------
457 #------------------------------------------------------------------------------
459 #------------------------------------------------------------------------------
460 # Test encodings of a few full IT blocks, not just the IT instruction
463 # CHECK: addeq r0, r1, r2
465 # CHECK: subne r5, r6, r7
466 # CHECK: addeq r1, r2, #4
475 # CHECK: addls r0, r1, r2
477 # CHECK: subhi r5, r6, r7
478 # CHECK: addhi r1, r2, #4
487 #------------------------------------------------------------------------------
489 #------------------------------------------------------------------------------
490 # CHECK: ldm.w r4, {r4, r5, r8, r9}
491 # CHECK: ldm.w r4, {r5, r6}
492 # CHECK: ldm.w r5!, {r3, r8}
493 # CHECK: ldm.w r4, {r4, r5, r8, r9}
494 # CHECK: ldm.w r4, {r5, r6}
495 # CHECK: ldm.w r5!, {r3, r8}
496 # CHECK: ldm.w r5!, {r1, r2}
497 # CHECK: ldm.w r2, {r1, r2}
499 # CHECK: ldm.w r4, {r4, r5, r8, r9}
500 # CHECK: ldm.w r4, {r5, r6}
501 # CHECK: ldm.w r5!, {r3, r8}
502 # CHECK: ldm.w r4, {r4, r5, r8, r9}
503 # CHECK: ldm.w r4, {r5, r6}
504 # CHECK: ldm.w r5!, {r3, r8}
505 # CHECK: ldm.w r5!, {r3, r8}
525 #------------------------------------------------------------------------------
527 #------------------------------------------------------------------------------
528 # CHECK: ldmdb r4, {r4, r5, r8, r9}
529 # CHECK: ldmdb r4, {r5, r6}
530 # CHECK: ldmdb r5!, {r3, r8}
531 # CHECK: ldmdb r5!, {r3, r8}
539 #------------------------------------------------------------------------------
541 #------------------------------------------------------------------------------
542 # CHECK: ldr r5, [r5, #-4]
543 # CHECK: ldr r5, [r6, #32]
544 # CHECK: ldr.w r5, [r6, #33]
545 # CHECK: ldr.w r5, [r6, #257]
546 # CHECK: ldr.w pc, [r7, #257]
555 #------------------------------------------------------------------------------
557 #------------------------------------------------------------------------------
558 # CHECK: ldr.w r4, [pc, #-0]
559 # CHECK: ldr.w r2, [pc, #-40]
560 # CHECK: ldr.w r1, [pc, #1024]
566 #------------------------------------------------------------------------------
568 #------------------------------------------------------------------------------
569 # CHECK: ldr.w r1, [r8, r1]
570 # CHECK: ldr.w r4, [r5, r2]
571 # CHECK: ldr.w r6, [r0, r2, lsl #3]
572 # CHECK: ldr.w r8, [r8, r2, lsl #2]
573 # CHECK: ldr.w r7, [sp, r2, lsl #1]
574 # CHECK: ldr.w r7, [sp, r2]
575 # CHECK: ldr pc, [sp], #12
576 # CHECK: ldr r2, [r4, #255]!
577 # CHECK: ldr r8, [sp, #4]!
578 # CHECK: ldr lr, [sp, #-4]!
579 # CHECK: ldr lr, [sp, #0]!
580 # CHECK: ldr r2, [r4], #255
581 # CHECK: ldr r8, [sp], #4
582 # CHECK: ldr lr, [sp], #-4
600 #------------------------------------------------------------------------------
602 #------------------------------------------------------------------------------
603 # CHECK: ldrb r5, [r5, #-4]
604 # CHECK: ldrb.w r5, [r6, #32]
605 # CHECK: ldrb.w r5, [r6, #33]
606 # CHECK: ldrb.w r5, [r6, #257]
607 # CHECK: ldrb.w lr, [r7, #257]
616 #------------------------------------------------------------------------------
618 #------------------------------------------------------------------------------
619 # CHECK: ldrb.w r1, [r8, r1]
620 # CHECK: ldrb.w r4, [r5, r2]
621 # CHECK: ldrb.w r6, [r0, r2, lsl #3]
622 # CHECK: ldrb.w r8, [r8, r2, lsl #2]
623 # CHECK: ldrb.w r7, [sp, r2, lsl #1]
624 # CHECK: ldrb.w r7, [sp, r2]
625 # CHECK: ldrb r5, [r8, #255]!
626 # CHECK: ldrb r2, [r5, #4]!
627 # CHECK: ldrb r1, [r4, #-4]!
628 # CHECK: ldrb r1, [r4, #0]!
629 # CHECK: ldrb lr, [r3], #255
630 # CHECK: ldrb r9, [r2], #4
631 # CHECK: ldrb r3, [sp], #-4
648 #------------------------------------------------------------------------------
650 #------------------------------------------------------------------------------
651 # CHECK: ldrb.w r6, [pc, #-0]
652 # CHECK: ldrb.w r10, [pc, #227]
653 # CHECK: ldrb.w r5, [pc, #0]
659 #------------------------------------------------------------------------------
661 #------------------------------------------------------------------------------
662 # CHECK: ldrbt r1, [r2]
663 # CHECK: ldrbt r1, [r8]
664 # CHECK: ldrbt r1, [r8, #3]
665 # CHECK: ldrbt r1, [r8, #255]
673 #------------------------------------------------------------------------------
675 #------------------------------------------------------------------------------
676 # CHECK: ldrd r3, r5, [r6, #24]
677 # CHECK: ldrd r3, r5, [r6, #24]!
678 # CHECK: ldrd r3, r5, [r6], #4
679 # CHECK: ldrd r3, r5, [r6], #-8
680 # CHECK: ldrd r3, r5, [r6]
681 # CHECK: ldrd r8, r1, [r3]
682 # CHECK: ldrd r0, r1, [r2], #-0
683 # CHECK: ldrd r0, r1, [r2, #-0]!
684 # CHECK: ldrd r0, r1, [r2, #0]!
685 # CHECK: ldrd r0, r1, [r2, #-0]
699 #------------------------------------------------------------------------------
700 # FIXME: LDRD(literal)
701 #------------------------------------------------------------------------------
704 #------------------------------------------------------------------------------
705 # LDREX/LDREXB/LDREXH/LDREXD
706 #------------------------------------------------------------------------------
707 # CHECK: ldrex r1, [r4]
708 # CHECK: ldrex r8, [r4]
709 # CHECK: ldrex r2, [sp, #128]
710 # CHECK: ldrexb r5, [r7]
711 # CHECK: ldrexh r9, [r12]
712 # CHECK: ldrexd r9, r3, [r4]
722 #------------------------------------------------------------------------------
724 #------------------------------------------------------------------------------
725 # CHECK: ldrh r5, [r5, #-4]
726 # CHECK: ldrh r5, [r6, #32]
727 # CHECK: ldrh.w r5, [r6, #33]
728 # CHECK: ldrh.w r5, [r6, #257]
729 # CHECK: ldrh.w lr, [r7, #257]
738 #------------------------------------------------------------------------------
740 #------------------------------------------------------------------------------
741 # CHECK: ldrh.w r1, [r8, r1]
742 # CHECK: ldrh.w r4, [r5, r2]
743 # CHECK: ldrh.w r6, [r0, r2, lsl #3]
744 # CHECK: ldrh.w r8, [r8, r2, lsl #2]
745 # CHECK: ldrh.w r7, [sp, r2, lsl #1]
746 # CHECK: ldrh.w r7, [sp, r2]
747 # CHECK: ldrh r5, [r8, #255]!
748 # CHECK: ldrh r2, [r5, #4]!
749 # CHECK: ldrh r1, [r4, #-4]!
750 # CHECK: ldrh r1, [r4, #0]!
751 # CHECK: ldrh lr, [r3], #255
752 # CHECK: ldrh r9, [r2], #4
753 # CHECK: ldrh r3, [sp], #-4
770 #------------------------------------------------------------------------------
772 #------------------------------------------------------------------------------
773 # CHECK: ldrh.w r7, [pc, #-0]
774 # CHECK: ldrh.w r5, [pc, #121]
775 # CHECK: ldrh.w r4, [pc, #0]
781 #------------------------------------------------------------------------------
783 #------------------------------------------------------------------------------
784 # CHECK: ldrsb r5, [r5, #-4]
785 # CHECK: ldrsb.w r5, [r6, #32]
786 # CHECK: ldrsb.w r5, [r6, #33]
787 # CHECK: ldrsb.w r5, [r6, #257]
788 # CHECK: ldrsb.w lr, [r7, #257]
797 #------------------------------------------------------------------------------
799 #------------------------------------------------------------------------------
800 # CHECK: ldrsb.w r1, [r8, r1]
801 # CHECK: ldrsb.w r4, [r5, r2]
802 # CHECK: ldrsb.w r6, [r0, r2, lsl #3]
803 # CHECK: ldrsb.w r8, [r8, r2, lsl #2]
804 # CHECK: ldrsb.w r7, [sp, r2, lsl #1]
805 # CHECK: ldrsb.w r7, [sp, r2]
806 # CHECK: ldrsb r5, [r8, #255]!
807 # CHECK: ldrsb r2, [r5, #4]!
808 # CHECK: ldrsb r1, [r4, #-4]!
809 # CHECK: ldrsb r1, [r4, #0]!
810 # CHECK: ldrsb lr, [r3], #255
811 # CHECK: ldrsb r9, [r2], #4
812 # CHECK: ldrsb r3, [sp], #-4
829 #------------------------------------------------------------------------------
831 #------------------------------------------------------------------------------
832 # CHECK: ldrsb.w r0, [pc, #-0]
833 # CHECK: ldrsb.w r12, [pc, #80]
834 # CHECK: ldrsb.w r3, [pc, #0]
840 #------------------------------------------------------------------------------
842 #------------------------------------------------------------------------------
843 # CHECK: ldrsbt r1, [r2]
844 # CHECK: ldrsbt r1, [r8]
845 # CHECK: ldrsbt r1, [r8, #3]
846 # CHECK: ldrsbt r1, [r8, #255]
854 #------------------------------------------------------------------------------
856 #------------------------------------------------------------------------------
857 # CHECK: ldrsh r5, [r5, #-4]
858 # CHECK: ldrsh.w r5, [r6, #32]
859 # CHECK: ldrsh.w r5, [r6, #33]
860 # CHECK: ldrsh.w r5, [r6, #257]
861 # CHECK: ldrsh.w lr, [r7, #257]
862 # CHECK: ldrsh r10, [r5, #-0]
871 #------------------------------------------------------------------------------
873 #------------------------------------------------------------------------------
874 # CHECK: ldrsh.w r1, [r8, r1]
875 # CHECK: ldrsh.w r4, [r5, r2]
876 # CHECK: ldrsh.w r6, [r0, r2, lsl #3]
877 # CHECK: ldrsh.w r8, [r8, r2, lsl #2]
878 # CHECK: ldrsh.w r7, [sp, r2, lsl #1]
879 # CHECK: ldrsh.w r7, [sp, r2]
880 # CHECK: ldrsh r5, [r8, #255]!
881 # CHECK: ldrsh r2, [r5, #4]!
882 # CHECK: ldrsh r1, [r4, #-4]!
883 # CHECK: ldrsh r1, [r4, #0]!
884 # CHECK: ldrsh lr, [r3], #255
885 # CHECK: ldrsh r9, [r2], #4
886 # CHECK: ldrsh r3, [sp], #-4
903 #------------------------------------------------------------------------------
905 #------------------------------------------------------------------------------
906 # CHECK: ldrsh.w r0, [pc, #-0]
907 # CHECK: ldrsh.w r10, [pc, #-231]
908 # CHECK: ldrsh.w r6, [pc, #0]
914 #------------------------------------------------------------------------------
916 #------------------------------------------------------------------------------
917 # CHECK: ldrsht r1, [r2]
918 # CHECK: ldrsht r1, [r8]
919 # CHECK: ldrsht r1, [r8, #3]
920 # CHECK: ldrsht r1, [r8, #255]
928 #------------------------------------------------------------------------------
930 #------------------------------------------------------------------------------
931 # CHECK: ldrt r1, [r2]
932 # CHECK: ldrt r2, [r6]
933 # CHECK: ldrt r3, [r7, #3]
934 # CHECK: ldrt r4, [r9, #255]
942 #------------------------------------------------------------------------------
944 #------------------------------------------------------------------------------
945 # CHECK: lsl.w r2, r3, #12
946 # CHECK: lsls.w r8, r3, #31
947 # CHECK: lsls.w r2, r3, #1
948 # CHECK: lsl.w r2, r3, #4
949 # CHECK: lsls.w r2, r12, #15
951 # CHECK: lsl.w r3, r3, #19
952 # CHECK: lsls.w r8, r8, #2
953 # CHECK: lsls.w r7, r7, #5
954 # CHECK: lsl.w r12, r12, #21
968 #------------------------------------------------------------------------------
970 #------------------------------------------------------------------------------
971 # CHECK: lsl.w r3, r4, r2
972 # CHECK: lsl.w r1, r1, r2
973 # CHECK: lsls.w r3, r4, r8
980 #------------------------------------------------------------------------------
982 #------------------------------------------------------------------------------
983 # CHECK: lsr.w r2, r3, #12
984 # CHECK: lsrs.w r8, r3, #32
985 # CHECK: lsrs.w r2, r3, #1
986 # CHECK: lsr.w r2, r3, #4
987 # CHECK: lsrs.w r2, r12, #15
989 # CHECK: lsr.w r3, r3, #19
990 # CHECK: lsrs.w r8, r8, #2
991 # CHECK: lsrs.w r7, r7, #5
992 # CHECK: lsr.w r12, r12, #21
1006 #------------------------------------------------------------------------------
1008 #------------------------------------------------------------------------------
1009 # CHECK: lsr.w r3, r4, r2
1010 # CHECK: lsr.w r1, r1, r2
1011 # CHECK: lsrs.w r3, r4, r8
1017 #------------------------------------------------------------------------------
1019 #------------------------------------------------------------------------------
1020 # CHECK: mcr p7, #1, r5, c1, c1, #4
1021 # CHECK: mcr2 p7, #1, r5, c1, c1, #4
1027 #------------------------------------------------------------------------------
1029 #------------------------------------------------------------------------------
1030 # CHECK: mcrr p7, #15, r5, r4, c1
1031 # CHECK: mcrr2 p7, #15, r5, r4, c1
1037 #------------------------------------------------------------------------------
1039 #------------------------------------------------------------------------------
1040 # CHECK: mla r1, r2, r3, r4
1041 # CHECK: mls r1, r2, r3, r4
1047 #------------------------------------------------------------------------------
1049 #------------------------------------------------------------------------------
1050 # CHECK: movs r1, #21
1051 # CHECK: movs.w r1, #21
1052 # CHECK: movs.w r8, #21
1053 # CHECK: movw r0, #65535
1054 # CHECK: movw r1, #43777
1055 # CHECK: movw r1, #43792
1056 # CHECK: mov.w r0, #66846720
1057 # CHECK: mov.w r0, #66846720
1058 # CHECK: movs.w r0, #66846720
1070 #------------------------------------------------------------------------------
1072 #------------------------------------------------------------------------------
1073 # CHECK: movt r3, #7
1074 # CHECK: movt r6, #65535
1076 # CHECK: movteq r4, #4080
1083 #------------------------------------------------------------------------------
1085 #------------------------------------------------------------------------------
1086 # CHECK: mrc p14, #0, r1, c1, c2, #4
1087 # CHECK: mrc2 p14, #0, r1, c1, c2, #4
1093 #------------------------------------------------------------------------------
1095 #------------------------------------------------------------------------------
1096 # CHECK: mrrc p7, #1, r5, r4, c1
1097 # CHECK: mrrc2 p7, #1, r5, r4, c1
1103 #------------------------------------------------------------------------------
1105 #------------------------------------------------------------------------------
1106 # CHECK: mrs r8, apsr
1107 # CHECK: mrs r8, spsr
1113 #------------------------------------------------------------------------------
1115 #------------------------------------------------------------------------------
1116 # CHECK: msr APSR_nzcvq, r1
1117 # CHECK: msr APSR_g, r2
1118 # CHECK: msr APSR_nzcvq, r3
1119 # CHECK: msr APSR_nzcvq, r4
1120 # CHECK: msr APSR_nzcvqg, r5
1121 # CHECK: msr CPSR_fc, r6
1122 # CHECK: msr CPSR_c, r7
1123 # CHECK: msr CPSR_x, r8
1124 # CHECK: msr CPSR_fc, r9
1125 # CHECK: msr CPSR_fc, r11
1126 # CHECK: msr CPSR_fsx, r12
1127 # CHECK: msr SPSR_fc, r0
1128 # CHECK: msr SPSR_fsxc, r5
1129 # CHECK: msr CPSR_fsxc, r8
1147 #------------------------------------------------------------------------------
1149 #------------------------------------------------------------------------------
1150 # CHECK: muls r3, r4, r3
1151 # CHECK: mul r3, r4, r3
1152 # CHECK: mul r3, r4, r6
1154 # CHECK: muleq r3, r4, r5
1163 #------------------------------------------------------------------------------
1165 #------------------------------------------------------------------------------
1166 # CHECK: mvns r8, #21
1167 # CHECK: mvn r0, #66846720
1168 # CHECK: mvns r0, #66846720
1170 # CHECK: mvnseq r1, #12
1171 # CHECK: mvneq r1, #12
1172 # CHECK: mvnne r1, #12
1183 #------------------------------------------------------------------------------
1185 #------------------------------------------------------------------------------
1186 # CHECK: mvn.w r2, r3
1187 # CHECK: mvns r2, r3
1188 # CHECK: mvn.w r5, r6, lsl #19
1189 # CHECK: mvn.w r5, r6, lsr #9
1190 # CHECK: mvn.w r5, r6, asr #4
1191 # CHECK: mvn.w r5, r6, ror #6
1192 # CHECK: mvn.w r5, r6, rrx
1194 # CHECK: mvneq r2, r3
1206 #------------------------------------------------------------------------------
1208 #------------------------------------------------------------------------------
1214 #------------------------------------------------------------------------------
1216 #------------------------------------------------------------------------------
1217 # CHECK: orn r4, r5, #61440
1218 # CHECK: orn r4, r5, r6
1219 # CHECK: orns r4, r5, r6
1220 # CHECK: orn r4, r5, r6, lsl #5
1221 # CHECK: orns r4, r5, r6, lsr #5
1222 # CHECK: orn r4, r5, r6, lsr #5
1223 # CHECK: orns r4, r5, r6, asr #5
1224 # CHECK: orn r4, r5, r6, ror #5
1236 #------------------------------------------------------------------------------
1238 #------------------------------------------------------------------------------
1239 # CHECK: orr r4, r5, #61440
1240 # CHECK: orr.w r4, r5, r6
1241 # CHECK: orr.w r4, r5, r6, lsl #5
1242 # CHECK: orrs.w r4, r5, r6, lsr #5
1243 # CHECK: orr.w r4, r5, r6, lsr #5
1244 # CHECK: orrs.w r4, r5, r6, asr #5
1245 # CHECK: orr.w r4, r5, r6, ror #5
1256 #------------------------------------------------------------------------------
1258 #------------------------------------------------------------------------------
1259 # CHECK: pkhbt r2, r2, r3
1260 # CHECK: pkhbt r2, r2, r3, lsl #31
1261 # CHECK: pkhbt r2, r2, r3, lsl #15
1263 # CHECK: pkhtb r2, r2, r3, asr #31
1264 # CHECK: pkhtb r2, r2, r3, asr #15
1274 #------------------------------------------------------------------------------
1276 #------------------------------------------------------------------------------
1277 # CHECK: pld [r5, #-4]
1278 # CHECK: pld [r6, #32]
1279 # CHECK: pld [r6, #33]
1280 # CHECK: pld [r6, #257]
1281 # CHECK: pld [r7, #257]
1289 #------------------------------------------------------------------------------
1291 #------------------------------------------------------------------------------
1292 # CHECK: pld [r8, r1]
1293 # CHECK: pld [r5, r2]
1294 # CHECK: pld [r0, r2, lsl #3]
1295 # CHECK: pld [r8, r2, lsl #2]
1296 # CHECK: pld [sp, r2, lsl #1]
1297 # CHECK: pld [sp, r2]
1306 #------------------------------------------------------------------------------
1308 #------------------------------------------------------------------------------
1309 # CHECK: pld [pc, #-0]
1310 # CHECK: pld [pc, #455]
1311 # CHECK: pld [pc, #0]
1317 #------------------------------------------------------------------------------
1319 #------------------------------------------------------------------------------
1320 # CHECK: pli [r5, #-4]
1321 # CHECK: pli [r6, #32]
1322 # CHECK: pli [r6, #33]
1323 # CHECK: pli [r6, #257]
1324 # CHECK: pli [r7, #257]
1332 #------------------------------------------------------------------------------
1334 #------------------------------------------------------------------------------
1335 # CHECK: pli [r8, r1]
1336 # CHECK: pli [r5, r2]
1337 # CHECK: pli [r0, r2, lsl #3]
1338 # CHECK: pli [r8, r2, lsl #2]
1339 # CHECK: pli [sp, r2, lsl #1]
1340 # CHECK: pli [sp, r2]
1349 #------------------------------------------------------------------------------
1351 #------------------------------------------------------------------------------
1352 # CHECK: pli [pc, #-0]
1353 # CHECK: pli [pc, #-328]
1354 # CHECK: pli [pc, #0]
1361 #------------------------------------------------------------------------------
1363 #------------------------------------------------------------------------------
1364 # CHECK: qadd r1, r2, r3
1365 # CHECK: qadd16 r1, r2, r3
1366 # CHECK: qadd8 r1, r2, r3
1368 # CHECK: qaddgt r1, r2, r3
1369 # CHECK: qadd16gt r1, r2, r3
1370 # CHECK: qadd8le r1, r2, r3
1381 #------------------------------------------------------------------------------
1383 #------------------------------------------------------------------------------
1384 # CHECK: qdadd r6, r7, r8
1385 # CHECK: qdsub r6, r7, r8
1387 # CHECK: qdaddhi r6, r7, r8
1388 # CHECK: qdsubhi r6, r7, r8
1397 #------------------------------------------------------------------------------
1399 #------------------------------------------------------------------------------
1400 # CHECK: qsax r9, r12, r0
1402 # CHECK: qsaxeq r9, r12, r0
1409 #------------------------------------------------------------------------------
1411 #------------------------------------------------------------------------------
1412 # CHECK: qsub r1, r2, r3
1413 # CHECK: qsub16 r1, r2, r3
1414 # CHECK: qsub8 r1, r2, r3
1416 # CHECK: qsuble r1, r2, r3
1417 # CHECK: qsub16gt r1, r2, r3
1418 # CHECK: qsub8le r1, r2, r3
1429 #------------------------------------------------------------------------------
1431 #------------------------------------------------------------------------------
1432 # CHECK: rbit r1, r2
1434 # CHECK: rbitne r1, r2
1441 #------------------------------------------------------------------------------
1443 #------------------------------------------------------------------------------
1444 # CHECK: rev.w r1, r2
1445 # CHECK: rev.w r2, r8
1447 # CHECK: revne r1, r2
1448 # CHECK: revne.w r1, r8
1457 #------------------------------------------------------------------------------
1459 #------------------------------------------------------------------------------
1460 # CHECK: rev16.w r1, r2
1461 # CHECK: rev16.w r2, r8
1463 # CHECK: rev16ne r1, r2
1464 # CHECK: rev16ne.w r1, r8
1473 #------------------------------------------------------------------------------
1475 #------------------------------------------------------------------------------
1476 # CHECK: revsh.w r1, r2
1477 # CHECK: revsh.w r2, r8
1479 # CHECK: revshne r1, r2
1480 # CHECK: revshne.w r1, r8
1489 #------------------------------------------------------------------------------
1491 #------------------------------------------------------------------------------
1492 # CHECK: ror.w r2, r3, #12
1493 # CHECK: rors.w r8, r3, #31
1494 # CHECK: rors.w r2, r3, #1
1495 # CHECK: ror.w r2, r3, #4
1496 # CHECK: rors.w r2, r12, #15
1498 # CHECK: ror.w r3, r3, #19
1499 # CHECK: rors.w r8, r8, #2
1500 # CHECK: rors.w r7, r7, #5
1501 # CHECK: ror.w r12, r12, #21
1515 #------------------------------------------------------------------------------
1517 #------------------------------------------------------------------------------
1518 # CHECK: ror.w r3, r4, r2
1519 # CHECK: ror.w r1, r1, r2
1520 # CHECK: rors.w r3, r4, r8
1527 #------------------------------------------------------------------------------
1529 #------------------------------------------------------------------------------
1531 # CHECK: rrxs r1, r2
1533 # CHECK: rrxlt r9, r12
1534 # CHECK: rrxsge r8, r3
1542 #------------------------------------------------------------------------------
1544 #------------------------------------------------------------------------------
1545 # CHECK: rsb.w r2, r5, #1044480
1546 # CHECK: rsbs.w r3, r12, #15
1547 # CHECK: rsb.w r1, r1, #255
1554 #------------------------------------------------------------------------------
1556 #------------------------------------------------------------------------------
1557 # CHECK: rsb r4, r4, r8
1558 # CHECK: rsb r4, r9, r8
1559 # CHECK: rsb r1, r4, r8, asr #3
1560 # CHECK: rsbs r2, r1, r7, lsl #1
1568 #------------------------------------------------------------------------------
1570 #------------------------------------------------------------------------------
1571 # CHECK: sadd16 r3, r4, r8
1573 # CHECK: sadd16ne r3, r4, r8
1580 #------------------------------------------------------------------------------
1582 #------------------------------------------------------------------------------
1583 # CHECK: sadd8 r3, r4, r8
1585 # CHECK: sadd8ne r3, r4, r8
1592 #------------------------------------------------------------------------------
1594 #------------------------------------------------------------------------------
1595 # CHECK: sasx r9, r2, r7
1597 # CHECK: sasxne r2, r5, r6
1604 #------------------------------------------------------------------------------
1606 #------------------------------------------------------------------------------
1607 # CHECK: sbc r0, r1, #4
1608 # CHECK: sbcs r0, r1, #0
1609 # CHECK: sbc r1, r2, #255
1610 # CHECK: sbc r3, r7, #5570645
1611 # CHECK: sbc r8, r12, #2852170240
1612 # CHECK: sbc r9, r7, #2779096485
1613 # CHECK: sbc r5, r3, #2264924160
1614 # CHECK: sbc r4, r2, #2139095040
1615 # CHECK: sbc r4, r2, #1664
1628 #------------------------------------------------------------------------------
1630 #------------------------------------------------------------------------------
1631 # CHECK: sbc.w r4, r5, r6
1632 # CHECK: sbcs.w r4, r5, r6
1633 # CHECK: sbc.w r9, r1, r3
1634 # CHECK: sbcs.w r9, r1, r3
1635 # CHECK: sbc.w r0, r1, r3, ror #4
1636 # CHECK: sbcs.w r0, r1, r3, lsl #7
1637 # CHECK: sbc.w r0, r1, r3, lsr #31
1638 # CHECK: sbcs.w r0, r1, r3, asr #32
1650 #------------------------------------------------------------------------------
1652 #------------------------------------------------------------------------------
1653 # CHECK: sbfx r4, r5, #16, #1
1655 # CHECK: sbfxgt r4, r5, #16, #16
1662 #------------------------------------------------------------------------------
1664 #------------------------------------------------------------------------------
1665 # CHECK: sel r5, r9, r2
1667 # CHECK: selle r5, r9, r2
1674 #------------------------------------------------------------------------------
1676 #------------------------------------------------------------------------------
1686 #------------------------------------------------------------------------------
1688 #------------------------------------------------------------------------------
1689 # CHECK: sadd16 r1, r2, r3
1690 # CHECK: sadd8 r1, r2, r3
1692 # CHECK: sadd16gt r1, r2, r3
1693 # CHECK: sadd8le r1, r2, r3
1702 #------------------------------------------------------------------------------
1704 #------------------------------------------------------------------------------
1705 # CHECK: shasx r4, r8, r2
1707 # CHECK: shasxgt r4, r8, r2
1714 #------------------------------------------------------------------------------
1716 #------------------------------------------------------------------------------
1717 # CHECK: shsax r4, r8, r2
1719 # CHECK: shsaxgt r4, r8, r2
1726 #------------------------------------------------------------------------------
1728 #------------------------------------------------------------------------------
1729 # CHECK: shsub16 r4, r8, r2
1730 # CHECK: shsub8 r4, r8, r2
1732 # CHECK: shsub16gt r4, r8, r2
1733 # CHECK: shsub8gt r4, r8, r2
1742 #------------------------------------------------------------------------------
1743 # SMLABB/SMLABT/SMLATB/SMLATT
1744 #------------------------------------------------------------------------------
1745 # CHECK: smlabb r3, r1, r9, r0
1746 # CHECK: smlabt r5, r6, r4, r1
1747 # CHECK: smlatb r4, r2, r3, r2
1748 # CHECK: smlatt r8, r3, r8, r4
1750 # CHECK: smlabbgt r3, r1, r9, r0
1751 # CHECK: smlabtle r5, r6, r4, r1
1752 # CHECK: smlatbgt r4, r2, r3, r2
1753 # CHECK: smlattle r8, r3, r8, r4
1766 #------------------------------------------------------------------------------
1768 #------------------------------------------------------------------------------
1769 # CHECK: smlad r2, r3, r5, r8
1770 # CHECK: smladx r2, r3, r5, r8
1772 # CHECK: smladhi r2, r3, r5, r8
1773 # CHECK: smladxhi r2, r3, r5, r8
1782 #------------------------------------------------------------------------------
1784 #------------------------------------------------------------------------------
1785 # CHECK: smlal r2, r3, r5, r8
1787 # CHECK: smlaleq r2, r3, r5, r8
1794 #------------------------------------------------------------------------------
1795 # SMLALBB/SMLALBT/SMLALTB/SMLALTT
1796 #------------------------------------------------------------------------------
1797 # CHECK: smlalbb r3, r1, r9, r0
1798 # CHECK: smlalbt r5, r6, r4, r1
1799 # CHECK: smlaltb r4, r2, r3, r2
1800 # CHECK: smlaltt r8, r3, r8, r4
1802 # CHECK: smlalbbge r3, r1, r9, r0
1803 # CHECK: smlalbtlt r5, r6, r4, r1
1804 # CHECK: smlaltblt r4, r2, r3, r2
1805 # CHECK: smlalttge r8, r3, r8, r4
1817 #------------------------------------------------------------------------------
1819 #------------------------------------------------------------------------------
1820 # CHECK: smlald r2, r3, r5, r8
1821 # CHECK: smlaldx r2, r3, r5, r8
1823 # CHECK: smlaldeq r2, r3, r5, r8
1824 # CHECK: smlaldxne r2, r3, r5, r8
1833 #------------------------------------------------------------------------------
1835 #------------------------------------------------------------------------------
1836 # CHECK: smlawb r2, r3, r10, r8
1837 # CHECK: smlawt r8, r3, r5, r9
1839 # CHECK: smlawbeq r2, r7, r5, r8
1840 # CHECK: smlawtne r1, r3, r0, r8
1849 #------------------------------------------------------------------------------
1851 #------------------------------------------------------------------------------
1852 # CHECK: smlsd r2, r3, r5, r8
1853 # CHECK: smlsdx r2, r3, r5, r8
1855 # CHECK: smlsdle r2, r3, r5, r8
1856 # CHECK: smlsdxgt r2, r3, r5, r8
1865 #------------------------------------------------------------------------------
1867 #------------------------------------------------------------------------------
1868 # CHECK: smlsld r2, r9, r5, r1
1869 # CHECK: smlsldx r4, r11, r2, r8
1871 # CHECK: smlsldge r8, r2, r5, r6
1872 # CHECK: smlsldxlt r1, r0, r3, r8
1881 #------------------------------------------------------------------------------
1883 #------------------------------------------------------------------------------
1884 # CHECK: smmla r1, r2, r3, r4
1885 # CHECK: smmlar r4, r3, r2, r1
1887 # CHECK: smmlalo r1, r2, r3, r4
1888 # CHECK: smmlarhs r4, r3, r2, r1
1897 #------------------------------------------------------------------------------
1899 #------------------------------------------------------------------------------
1900 # CHECK: smmls r1, r2, r3, r4
1901 # CHECK: smmlsr r4, r3, r2, r1
1903 # CHECK: smmlslo r1, r2, r3, r4
1904 # CHECK: smmlsrhs r4, r3, r2, r1
1912 #------------------------------------------------------------------------------
1914 #------------------------------------------------------------------------------
1915 # CHECK: ssat r9, #30, r0, asr #2
1919 #------------------------------------------------------------------------------
1921 #------------------------------------------------------------------------------
1922 # CHECK: str r10, [r11], #0
1926 #------------------------------------------------------------------------------
1928 #------------------------------------------------------------------------------
1929 # CHECK: strd r6, r3, [r5], #-8
1930 # CHECK: strd r8, r5, [r5], #-0
1931 # CHECK: strd r7, r4, [r5], #-4
1932 # CHECK: strd r0, r1, [r2, #-0]!
1933 # CHECK: strd r0, r1, [r2, #0]!
1934 # CHECK: strd r0, r1, [r2, #-0]
1943 #------------------------------------------------------------------------------
1944 # STREX/STREXB/STREXH/STREXD
1945 #------------------------------------------------------------------------------
1946 # CHECK: strex r1, r8, [r4]
1947 # CHECK: strex r8, r2, [r4]
1948 # CHECK: strex r2, r12, [sp, #128]
1949 # CHECK: strexb r5, r1, [r7]
1950 # CHECK: strexh r9, r7, [r12]
1951 # CHECK: strexd r9, r3, r6, [r4]
1961 #------------------------------------------------------------------------------
1963 #------------------------------------------------------------------------------
1964 # CHECK: strh r5, [r5, #-4]
1965 # CHECK: strh r5, [r6, #32]
1966 # CHECK: strh.w r5, [r6, #33]
1967 # CHECK: strh.w r5, [r6, #257]
1968 # CHECK: strh.w lr, [r7, #257]
1969 # CHECK: strh r5, [r8, #255]!
1970 # CHECK: strh r2, [r5, #4]!
1971 # CHECK: strh r1, [r4, #-4]!
1972 # CHECK: strh r1, [r4, #0]!
1973 # CHECK: strh lr, [r3], #255
1974 # CHECK: strh r9, [r2], #4
1975 # CHECK: strh r3, [sp], #-4
1991 #------------------------------------------------------------------------------
1993 #------------------------------------------------------------------------------
1994 # CHECK: strh.w r1, [r8, r1]
1995 # CHECK: strh.w r4, [r5, r2]
1996 # CHECK: strh.w r6, [r0, r2, lsl #3]
1997 # CHECK: strh.w r8, [r8, r2, lsl #2]
1998 # CHECK: strh.w r7, [sp, r2, lsl #1]
1999 # CHECK: strh.w r7, [sp, r2]
2009 #------------------------------------------------------------------------------
2011 #------------------------------------------------------------------------------
2012 # CHECK: strht r1, [r2]
2013 # CHECK: strht r1, [r8]
2014 # CHECK: strht r1, [r8, #3]
2015 # CHECK: strht r1, [r8, #255]
2023 #------------------------------------------------------------------------------
2025 #------------------------------------------------------------------------------
2026 # CHECK: strt r1, [r2]
2027 # CHECK: strt r1, [r8]
2028 # CHECK: strt r1, [r8, #3]
2029 # CHECK: strt r1, [r8, #255]
2037 #------------------------------------------------------------------------------
2039 #------------------------------------------------------------------------------
2041 # CHECK: subeq r1, r2, #4
2042 # CHECK: subwne r5, r3, #1023
2043 # CHECK: subweq r4, r5, #293
2044 # CHECK: sub.w r2, sp, #1024
2045 # CHECK: sub.w r2, r8, #65280
2046 # CHECK: subw r2, r3, #257
2047 # CHECK: sub.w r12, r6, #256
2048 # CHECK: subw r12, r6, #256
2049 # CHECK: subs.w r1, r2, #496
2063 #------------------------------------------------------------------------------
2065 #------------------------------------------------------------------------------
2066 # CHECK: sub.w r4, r5, r6
2067 # CHECK: sub.w r4, r5, r6, lsl #5
2068 # CHECK: sub.w r4, r5, r6, lsr #5
2069 # CHECK: sub.w r4, r5, r6, lsr #5
2070 # CHECK: sub.w r4, r5, r6, asr #5
2071 # CHECK: sub.w r4, r5, r6, ror #5
2072 # CHECK: sub.w r5, r2, r12, rrx
2083 #------------------------------------------------------------------------------
2085 #------------------------------------------------------------------------------
2096 #------------------------------------------------------------------------------
2098 #------------------------------------------------------------------------------
2099 # CHECK: sxtab r2, r3, r4
2100 # CHECK: sxtab r4, r5, r6
2102 # CHECK: sxtablt r6, r2, r9, ror #8
2103 # CHECK: sxtab r5, r1, r4, ror #16
2104 # CHECK: sxtab r7, r8, r3, ror #24
2114 #------------------------------------------------------------------------------
2116 #------------------------------------------------------------------------------
2117 # CHECK: sxtab16 r6, r2, r7
2118 # CHECK: sxtab16 r3, r5, r8, ror #8
2119 # CHECK: sxtab16 r3, r2, r1, ror #16
2121 # CHECK: sxtab16ne r0, r1, r4
2122 # CHECK: sxtab16eq r1, r2, r3, ror #24
2132 #------------------------------------------------------------------------------
2134 #------------------------------------------------------------------------------
2135 # CHECK: sxtah r1, r3, r9
2136 # CHECK: sxtah r3, r8, r3, ror #8
2137 # CHECK: sxtah r9, r3, r3, ror #24
2139 # CHECK: sxtahhi r6, r1, r6
2140 # CHECK: sxtahls r2, r2, r4, ror #16
2150 #------------------------------------------------------------------------------
2152 #------------------------------------------------------------------------------
2153 # CHECK: sxtb r5, r6
2154 # CHECK: sxtb.w r6, r9, ror #8
2155 # CHECK: sxtb.w r8, r3, ror #24
2157 # CHECK: sxtbge r2, r4
2158 # CHECK: sxtblt.w r5, r1, ror #16
2168 #------------------------------------------------------------------------------
2170 #------------------------------------------------------------------------------
2171 # CHECK: sxtb16 r1, r4
2172 # CHECK: sxtb16 r6, r7
2173 # CHECK: sxtb16 r3, r1, ror #16
2175 # CHECK: sxtb16hs r3, r5, ror #8
2176 # CHECK: sxtb16lo r2, r3, ror #24
2186 #------------------------------------------------------------------------------
2188 #------------------------------------------------------------------------------
2189 # CHECK: sxth r1, r6
2190 # CHECK: sxth.w r3, r8, ror #8
2191 # CHECK: sxth.w r9, r3, ror #24
2193 # CHECK: sxthne.w r3, r9
2194 # CHECK: sxthne.w r2, r2, ror #16
2204 #------------------------------------------------------------------------------
2206 #------------------------------------------------------------------------------
2207 # CHECK: sxtb r5, r6
2208 # CHECK: sxtb.w r6, r9, ror #8
2209 # CHECK: sxtb.w r8, r3, ror #24
2211 # CHECK: sxtbge r2, r4
2212 # CHECK: sxtblt.w r5, r1, ror #16
2222 #------------------------------------------------------------------------------
2224 #------------------------------------------------------------------------------
2225 # CHECK: sxtb16 r1, r4
2226 # CHECK: sxtb16 r6, r7
2227 # CHECK: sxtb16 r3, r1, ror #16
2229 # CHECK: sxtb16hs r3, r5, ror #8
2230 # CHECK: sxtb16lo r2, r3, ror #24
2240 #------------------------------------------------------------------------------
2242 #------------------------------------------------------------------------------
2243 # CHECK: sxth r1, r6
2244 # CHECK: sxth.w r3, r8, ror #8
2245 # CHECK: sxth.w r9, r3, ror #24
2247 # CHECK: sxthne.w r3, r9
2248 # CHECK: sxthne.w r2, r2, ror #16
2258 #------------------------------------------------------------------------------
2260 #------------------------------------------------------------------------------
2261 # CHECK: tbb [r3, r8]
2262 # CHECK: tbh [r3, r8, lsl #1]
2264 # CHECK: tbbeq [r3, r8]
2266 # CHECK: tbhhs [r3, r8, lsl #1]
2276 #------------------------------------------------------------------------------
2278 #------------------------------------------------------------------------------
2279 # CHECK: teq.w r5, #61440
2280 # CHECK: teq.w r4, r5
2281 # CHECK: teq.w r4, r5, lsl #5
2282 # CHECK: teq.w r4, r5, lsr #5
2283 # CHECK: teq.w r4, r5, lsr #5
2284 # CHECK: teq.w r4, r5, asr #5
2285 # CHECK: teq.w r4, r5, ror #5
2296 #------------------------------------------------------------------------------
2298 #------------------------------------------------------------------------------
2299 # CHECK: tst.w r5, #61440
2301 # CHECK: tst.w r3, r12, lsl #5
2302 # CHECK: tst.w r4, r11, lsr #4
2303 # CHECK: tst.w r5, r10, lsr #12
2304 # CHECK: tst.w r6, r9, asr #30
2305 # CHECK: tst.w r7, r8, ror #2
2316 #------------------------------------------------------------------------------
2318 #------------------------------------------------------------------------------
2319 # CHECK: uadd16 r1, r2, r3
2320 # CHECK: uadd8 r1, r2, r3
2322 # CHECK: uadd16gt r1, r2, r3
2323 # CHECK: uadd8le r1, r2, r3
2332 #------------------------------------------------------------------------------
2334 #------------------------------------------------------------------------------
2335 # CHECK: uasx r9, r12, r0
2337 # CHECK: uasxeq r9, r12, r0
2338 # CHECK: uasx r9, r12, r0
2340 # CHECK: uasxeq r9, r12, r0
2350 #------------------------------------------------------------------------------
2352 #------------------------------------------------------------------------------
2353 # CHECK: ubfx r4, r5, #16, #1
2355 # CHECK: ubfxgt r4, r5, #16, #16
2362 #------------------------------------------------------------------------------
2364 #------------------------------------------------------------------------------
2365 # CHECK: uhadd16 r4, r8, r2
2366 # CHECK: uhadd8 r4, r8, r2
2368 # CHECK: uhadd16gt r4, r8, r2
2369 # CHECK: uhadd8gt r4, r8, r2
2378 #------------------------------------------------------------------------------
2380 #------------------------------------------------------------------------------
2381 # CHECK: uhasx r4, r1, r5
2382 # CHECK: uhsax r5, r6, r6
2384 # CHECK: uhasxgt r6, r9, r8
2385 # CHECK: uhsaxgt r7, r8, r12
2393 #------------------------------------------------------------------------------
2395 #------------------------------------------------------------------------------
2396 # CHECK: uhsub16 r5, r8, r3
2397 # CHECK: uhsub8 r1, r7, r6
2399 # CHECK: uhsub16lt r4, r9, r12
2400 # CHECK: uhsub8lt r3, r1, r5
2409 #------------------------------------------------------------------------------
2411 #------------------------------------------------------------------------------
2412 # CHECK: umaal r3, r4, r5, r6
2414 # CHECK: umaallt r3, r4, r5, r6
2421 #------------------------------------------------------------------------------
2423 #------------------------------------------------------------------------------
2424 # CHECK: umlal r2, r4, r6, r8
2426 # CHECK: umlalgt r6, r1, r2, r6
2433 #------------------------------------------------------------------------------
2435 #------------------------------------------------------------------------------
2436 # CHECK: umull r2, r4, r6, r8
2438 # CHECK: umullgt r6, r1, r2, r6
2445 #------------------------------------------------------------------------------
2447 #------------------------------------------------------------------------------
2448 # CHECK: uqadd16 r1, r2, r3
2449 # CHECK: uqadd8 r3, r4, r8
2451 # CHECK: uqadd16gt r4, r7, r9
2452 # CHECK: uqadd8le r8, r1, r2
2461 #------------------------------------------------------------------------------
2463 #------------------------------------------------------------------------------
2464 # CHECK: uqasx r1, r2, r3
2465 # CHECK: uqsax r3, r4, r8
2467 # CHECK: uqasxgt r4, r7, r9
2468 # CHECK: uqsaxle r8, r1, r2
2477 #------------------------------------------------------------------------------
2479 #------------------------------------------------------------------------------
2480 # CHECK: uqsub8 r8, r2, r9
2481 # CHECK: uqsub16 r1, r9, r7
2483 # CHECK: uqsub8gt r3, r1, r6
2484 # CHECK: uqsub16le r4, r6, r4
2493 #------------------------------------------------------------------------------
2495 #------------------------------------------------------------------------------
2496 # CHECK: usad8 r1, r9, r7
2497 # CHECK: usada8 r8, r2, r9, r12
2499 # CHECK: usada8gt r3, r1, r6, r9
2500 # CHECK: usad8le r4, r6, r4
2509 #------------------------------------------------------------------------------
2511 #------------------------------------------------------------------------------
2512 # CHECK: usat r8, #1, r10
2513 # CHECK: usat r8, #4, r10
2514 # CHECK: usat r8, #5, r10, lsl #31
2515 # CHECK: usat r8, #16, r10, asr #1
2523 #------------------------------------------------------------------------------
2525 #------------------------------------------------------------------------------
2526 # CHECK: usat16 r2, #2, r7
2527 # CHECK: usat16 r3, #15, r5
2533 #------------------------------------------------------------------------------
2535 #------------------------------------------------------------------------------
2536 # CHECK: usax r2, r3, r4
2538 # CHECK: usaxne r6, r1, r9
2539 # CHECK: usax r2, r3, r4
2541 # CHECK: usaxne r6, r1, r9
2551 #------------------------------------------------------------------------------
2553 #------------------------------------------------------------------------------
2554 # CHECK: usub16 r4, r2, r7
2555 # CHECK: usub8 r1, r8, r5
2557 # CHECK: usub16hi r1, r1, r3
2558 # CHECK: usub8ls r9, r2, r3
2567 #------------------------------------------------------------------------------
2569 #------------------------------------------------------------------------------
2570 # CHECK: uxtab r2, r3, r4
2571 # CHECK: uxtab r4, r5, r6
2573 # CHECK: uxtablt r6, r2, r9, ror #8
2574 # CHECK: uxtab r5, r1, r4, ror #16
2575 # CHECK: uxtab r7, r8, r3, ror #24
2585 #------------------------------------------------------------------------------
2587 #------------------------------------------------------------------------------
2589 # CHECK: uxtab16ge r0, r1, r4
2590 # CHECK: uxtab16 r6, r2, r7
2591 # CHECK: uxtab16 r3, r5, r8, ror #8
2592 # CHECK: uxtab16 r3, r2, r1, ror #16
2594 # CHECK: uxtab16eq r1, r2, r3, ror #24
2605 #------------------------------------------------------------------------------
2607 #------------------------------------------------------------------------------
2608 # CHECK: uxtah r1, r3, r9
2610 # CHECK: uxtahhi r6, r1, r6
2611 # CHECK: uxtah r3, r8, r3, ror #8
2613 # CHECK: uxtahlo r2, r2, r4, ror #16
2614 # CHECK: uxtah r9, r3, r3, ror #24
2625 #------------------------------------------------------------------------------
2627 #------------------------------------------------------------------------------
2629 # CHECK: uxtbge r2, r4
2630 # CHECK: uxtb r5, r6
2631 # CHECK: uxtb.w r6, r9, ror #8
2633 # CHECK: uxtblo.w r5, r1, ror #16
2634 # CHECK: uxtb.w r8, r3, ror #24
2645 #------------------------------------------------------------------------------
2647 #------------------------------------------------------------------------------
2648 # CHECK: uxtb16 r1, r4
2649 # CHECK: uxtb16 r6, r7
2651 # CHECK: uxtb16hs r3, r5, ror #8
2652 # CHECK: uxtb16 r3, r1, ror #16
2654 # CHECK: uxtb16ge r2, r3, ror #24
2665 #------------------------------------------------------------------------------
2667 #------------------------------------------------------------------------------
2669 # CHECK: uxthne.w r3, r9
2670 # CHECK: uxth r1, r6
2671 # CHECK: uxth.w r3, r8, ror #8
2673 # CHECK: uxthle.w r2, r2, ror #16
2674 # CHECK: uxth.w r9, r3, ror #24
2685 #------------------------------------------------------------------------------
2687 #------------------------------------------------------------------------------