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 r1, [r8, r1]
559 # CHECK: ldr.w r4, [r5, r2]
560 # CHECK: ldr.w r6, [r0, r2, lsl #3]
561 # CHECK: ldr.w r8, [r8, r2, lsl #2]
562 # CHECK: ldr.w r7, [sp, r2, lsl #1]
563 # CHECK: ldr.w r7, [sp, r2]
564 # CHECK: ldr pc, [sp], #12
565 # CHECK: ldr r2, [r4, #255]!
566 # CHECK: ldr r8, [sp, #4]!
567 # CHECK: ldr lr, [sp, #-4]!
568 # CHECK: ldr r2, [r4], #255
569 # CHECK: ldr r8, [sp], #4
570 # CHECK: ldr lr, [sp], #-4
587 #------------------------------------------------------------------------------
589 #------------------------------------------------------------------------------
590 # CHECK: ldrb r5, [r5, #-4]
591 # CHECK: ldrb.w r5, [r6, #32]
592 # CHECK: ldrb.w r5, [r6, #33]
593 # CHECK: ldrb.w r5, [r6, #257]
594 # CHECK: ldrb.w lr, [r7, #257]
603 #------------------------------------------------------------------------------
605 #------------------------------------------------------------------------------
606 # CHECK: ldrb.w r1, [r8, r1]
607 # CHECK: ldrb.w r4, [r5, r2]
608 # CHECK: ldrb.w r6, [r0, r2, lsl #3]
609 # CHECK: ldrb.w r8, [r8, r2, lsl #2]
610 # CHECK: ldrb.w r7, [sp, r2, lsl #1]
611 # CHECK: ldrb.w r7, [sp, r2]
612 # CHECK: ldrb r5, [r8, #255]!
613 # CHECK: ldrb r2, [r5, #4]!
614 # CHECK: ldrb r1, [r4, #-4]!
615 # CHECK: ldrb lr, [r3], #255
616 # CHECK: ldrb r9, [r2], #4
617 # CHECK: ldrb r3, [sp], #-4
633 #------------------------------------------------------------------------------
635 #------------------------------------------------------------------------------
636 # CHECK: ldrbt r1, [r2]
637 # CHECK: ldrbt r1, [r8]
638 # CHECK: ldrbt r1, [r8, #3]
639 # CHECK: ldrbt r1, [r8, #255]
647 #------------------------------------------------------------------------------
649 #------------------------------------------------------------------------------
650 # CHECK: ldrd r3, r5, [r6, #24]
651 # CHECK: ldrd r3, r5, [r6, #24]!
652 # CHECK: ldrd r3, r5, [r6], #4
653 # CHECK: ldrd r3, r5, [r6], #-8
654 # CHECK: ldrd r3, r5, [r6]
655 # CHECK: ldrd r8, r1, [r3]
656 # CHECK: ldrd r0, r1, [r2], #-0
657 # CHECK: ldrd r0, r1, [r2, #-0]!
658 # CHECK: ldrd r0, r1, [r2, #-0]
671 #------------------------------------------------------------------------------
672 # FIXME: LDRD(literal)
673 #------------------------------------------------------------------------------
676 #------------------------------------------------------------------------------
677 # LDREX/LDREXB/LDREXH/LDREXD
678 #------------------------------------------------------------------------------
679 # CHECK: ldrex r1, [r4]
680 # CHECK: ldrex r8, [r4]
681 # CHECK: ldrex r2, [sp, #128]
682 # CHECK: ldrexb r5, [r7]
683 # CHECK: ldrexh r9, [r12]
684 # CHECK: ldrexd r9, r3, [r4]
694 #------------------------------------------------------------------------------
696 #------------------------------------------------------------------------------
697 # CHECK: ldrh r5, [r5, #-4]
698 # CHECK: ldrh r5, [r6, #32]
699 # CHECK: ldrh.w r5, [r6, #33]
700 # CHECK: ldrh.w r5, [r6, #257]
701 # CHECK: ldrh.w lr, [r7, #257]
702 # CHECK: ldrh.w r0, [pc, #-21]
712 #------------------------------------------------------------------------------
714 #------------------------------------------------------------------------------
715 # CHECK: ldrh.w r1, [r8, r1]
716 # CHECK: ldrh.w r4, [r5, r2]
717 # CHECK: ldrh.w r6, [r0, r2, lsl #3]
718 # CHECK: ldrh.w r8, [r8, r2, lsl #2]
719 # CHECK: ldrh.w r7, [sp, r2, lsl #1]
720 # CHECK: ldrh.w r7, [sp, r2]
721 # CHECK: ldrh r5, [r8, #255]!
722 # CHECK: ldrh r2, [r5, #4]!
723 # CHECK: ldrh r1, [r4, #-4]!
724 # CHECK: ldrh lr, [r3], #255
725 # CHECK: ldrh r9, [r2], #4
726 # CHECK: ldrh r3, [sp], #-4
742 #------------------------------------------------------------------------------
744 #------------------------------------------------------------------------------
745 # CHECK: ldrsb r5, [r5, #-4]
746 # CHECK: ldrsb.w r5, [r6, #32]
747 # CHECK: ldrsb.w r5, [r6, #33]
748 # CHECK: ldrsb.w r5, [r6, #257]
749 # CHECK: ldrsb.w lr, [r7, #257]
758 #------------------------------------------------------------------------------
760 #------------------------------------------------------------------------------
761 # CHECK: ldrsb.w r1, [r8, r1]
762 # CHECK: ldrsb.w r4, [r5, r2]
763 # CHECK: ldrsb.w r6, [r0, r2, lsl #3]
764 # CHECK: ldrsb.w r8, [r8, r2, lsl #2]
765 # CHECK: ldrsb.w r7, [sp, r2, lsl #1]
766 # CHECK: ldrsb.w r7, [sp, r2]
767 # CHECK: ldrsb r5, [r8, #255]!
768 # CHECK: ldrsb r2, [r5, #4]!
769 # CHECK: ldrsb r1, [r4, #-4]!
770 # CHECK: ldrsb lr, [r3], #255
771 # CHECK: ldrsb r9, [r2], #4
772 # CHECK: ldrsb r3, [sp], #-4
788 #------------------------------------------------------------------------------
790 #------------------------------------------------------------------------------
791 # CHECK: ldrsbt r1, [r2]
792 # CHECK: ldrsbt r1, [r8]
793 # CHECK: ldrsbt r1, [r8, #3]
794 # CHECK: ldrsbt r1, [r8, #255]
802 #------------------------------------------------------------------------------
804 #------------------------------------------------------------------------------
805 # CHECK: ldrsh r5, [r5, #-4]
806 # CHECK: ldrsh.w r5, [r6, #32]
807 # CHECK: ldrsh.w r5, [r6, #33]
808 # CHECK: ldrsh.w r5, [r6, #257]
809 # CHECK: ldrsh.w lr, [r7, #257]
810 # CHECK: ldrsh r10, [r5, #-0]
819 #------------------------------------------------------------------------------
821 #------------------------------------------------------------------------------
822 # CHECK: ldrsh.w r1, [r8, r1]
823 # CHECK: ldrsh.w r4, [r5, r2]
824 # CHECK: ldrsh.w r6, [r0, r2, lsl #3]
825 # CHECK: ldrsh.w r8, [r8, r2, lsl #2]
826 # CHECK: ldrsh.w r7, [sp, r2, lsl #1]
827 # CHECK: ldrsh.w r7, [sp, r2]
828 # CHECK: ldrsh r5, [r8, #255]!
829 # CHECK: ldrsh r2, [r5, #4]!
830 # CHECK: ldrsh r1, [r4, #-4]!
831 # CHECK: ldrsh lr, [r3], #255
832 # CHECK: ldrsh r9, [r2], #4
833 # CHECK: ldrsh r3, [sp], #-4
849 #------------------------------------------------------------------------------
851 #------------------------------------------------------------------------------
852 # CHECK: ldrsht r1, [r2]
853 # CHECK: ldrsht r1, [r8]
854 # CHECK: ldrsht r1, [r8, #3]
855 # CHECK: ldrsht r1, [r8, #255]
863 #------------------------------------------------------------------------------
865 #------------------------------------------------------------------------------
866 # CHECK: ldrt r1, [r2]
867 # CHECK: ldrt r2, [r6]
868 # CHECK: ldrt r3, [r7, #3]
869 # CHECK: ldrt r4, [r9, #255]
877 #------------------------------------------------------------------------------
879 #------------------------------------------------------------------------------
880 # CHECK: lsl.w r2, r3, #12
881 # CHECK: lsls.w r8, r3, #31
882 # CHECK: lsls.w r2, r3, #1
883 # CHECK: lsl.w r2, r3, #4
884 # CHECK: lsls.w r2, r12, #15
886 # CHECK: lsl.w r3, r3, #19
887 # CHECK: lsls.w r8, r8, #2
888 # CHECK: lsls.w r7, r7, #5
889 # CHECK: lsl.w r12, r12, #21
903 #------------------------------------------------------------------------------
905 #------------------------------------------------------------------------------
906 # CHECK: lsl.w r3, r4, r2
907 # CHECK: lsl.w r1, r1, r2
908 # CHECK: lsls.w r3, r4, r8
915 #------------------------------------------------------------------------------
917 #------------------------------------------------------------------------------
918 # CHECK: lsr.w r2, r3, #12
919 # CHECK: lsrs.w r8, r3, #32
920 # CHECK: lsrs.w r2, r3, #1
921 # CHECK: lsr.w r2, r3, #4
922 # CHECK: lsrs.w r2, r12, #15
924 # CHECK: lsr.w r3, r3, #19
925 # CHECK: lsrs.w r8, r8, #2
926 # CHECK: lsrs.w r7, r7, #5
927 # CHECK: lsr.w r12, r12, #21
941 #------------------------------------------------------------------------------
943 #------------------------------------------------------------------------------
944 # CHECK: lsr.w r3, r4, r2
945 # CHECK: lsr.w r1, r1, r2
946 # CHECK: lsrs.w r3, r4, r8
952 #------------------------------------------------------------------------------
954 #------------------------------------------------------------------------------
955 # CHECK: mcr p7, #1, r5, c1, c1, #4
956 # CHECK: mcr2 p7, #1, r5, c1, c1, #4
962 #------------------------------------------------------------------------------
964 #------------------------------------------------------------------------------
965 # CHECK: mcrr p7, #15, r5, r4, c1
966 # CHECK: mcrr2 p7, #15, r5, r4, c1
972 #------------------------------------------------------------------------------
974 #------------------------------------------------------------------------------
975 # CHECK: mla r1, r2, r3, r4
976 # CHECK: mls r1, r2, r3, r4
982 #------------------------------------------------------------------------------
984 #------------------------------------------------------------------------------
985 # CHECK: movs r1, #21
986 # CHECK: movs.w r1, #21
987 # CHECK: movs.w r8, #21
988 # CHECK: movw r0, #65535
989 # CHECK: movw r1, #43777
990 # CHECK: movw r1, #43792
991 # CHECK: mov.w r0, #66846720
992 # CHECK: mov.w r0, #66846720
993 # CHECK: movs.w r0, #66846720
1005 #------------------------------------------------------------------------------
1007 #------------------------------------------------------------------------------
1008 # CHECK: movt r3, #7
1009 # CHECK: movt r6, #65535
1011 # CHECK: movteq r4, #4080
1018 #------------------------------------------------------------------------------
1020 #------------------------------------------------------------------------------
1021 # CHECK: mrc p14, #0, r1, c1, c2, #4
1022 # CHECK: mrc2 p14, #0, r1, c1, c2, #4
1028 #------------------------------------------------------------------------------
1030 #------------------------------------------------------------------------------
1031 # CHECK: mrrc p7, #1, r5, r4, c1
1032 # CHECK: mrrc2 p7, #1, r5, r4, c1
1038 #------------------------------------------------------------------------------
1040 #------------------------------------------------------------------------------
1041 # CHECK: mrs r8, apsr
1042 # CHECK: mrs r8, spsr
1048 #------------------------------------------------------------------------------
1050 #------------------------------------------------------------------------------
1051 # CHECK: msr APSR_nzcvq, r1
1052 # CHECK: msr APSR_g, r2
1053 # CHECK: msr APSR_nzcvq, r3
1054 # CHECK: msr APSR_nzcvq, r4
1055 # CHECK: msr APSR_nzcvqg, r5
1056 # CHECK: msr CPSR_fc, r6
1057 # CHECK: msr CPSR_c, r7
1058 # CHECK: msr CPSR_x, r8
1059 # CHECK: msr CPSR_fc, r9
1060 # CHECK: msr CPSR_fc, r11
1061 # CHECK: msr CPSR_fsx, r12
1062 # CHECK: msr SPSR_fc, r0
1063 # CHECK: msr SPSR_fsxc, r5
1064 # CHECK: msr CPSR_fsxc, r8
1082 #------------------------------------------------------------------------------
1084 #------------------------------------------------------------------------------
1085 # CHECK: muls r3, r4, r3
1086 # CHECK: mul r3, r4, r3
1087 # CHECK: mul r3, r4, r6
1089 # CHECK: muleq r3, r4, r5
1098 #------------------------------------------------------------------------------
1100 #------------------------------------------------------------------------------
1101 # CHECK: mvns r8, #21
1102 # CHECK: mvn r0, #66846720
1103 # CHECK: mvns r0, #66846720
1105 # CHECK: mvnseq r1, #12
1106 # CHECK: mvneq r1, #12
1107 # CHECK: mvnne r1, #12
1118 #------------------------------------------------------------------------------
1120 #------------------------------------------------------------------------------
1121 # CHECK: mvn.w r2, r3
1122 # CHECK: mvns r2, r3
1123 # CHECK: mvn.w r5, r6, lsl #19
1124 # CHECK: mvn.w r5, r6, lsr #9
1125 # CHECK: mvn.w r5, r6, asr #4
1126 # CHECK: mvn.w r5, r6, ror #6
1127 # CHECK: mvn.w r5, r6, rrx
1129 # CHECK: mvneq r2, r3
1141 #------------------------------------------------------------------------------
1143 #------------------------------------------------------------------------------
1149 #------------------------------------------------------------------------------
1151 #------------------------------------------------------------------------------
1152 # CHECK: orn r4, r5, #61440
1153 # CHECK: orn r4, r5, r6
1154 # CHECK: orns r4, r5, r6
1155 # CHECK: orn r4, r5, r6, lsl #5
1156 # CHECK: orns r4, r5, r6, lsr #5
1157 # CHECK: orn r4, r5, r6, lsr #5
1158 # CHECK: orns r4, r5, r6, asr #5
1159 # CHECK: orn r4, r5, r6, ror #5
1171 #------------------------------------------------------------------------------
1173 #------------------------------------------------------------------------------
1174 # CHECK: orr r4, r5, #61440
1175 # CHECK: orr.w r4, r5, r6
1176 # CHECK: orr.w r4, r5, r6, lsl #5
1177 # CHECK: orrs.w r4, r5, r6, lsr #5
1178 # CHECK: orr.w r4, r5, r6, lsr #5
1179 # CHECK: orrs.w r4, r5, r6, asr #5
1180 # CHECK: orr.w r4, r5, r6, ror #5
1191 #------------------------------------------------------------------------------
1193 #------------------------------------------------------------------------------
1194 # CHECK: pkhbt r2, r2, r3
1195 # CHECK: pkhbt r2, r2, r3, lsl #31
1196 # CHECK: pkhbt r2, r2, r3, lsl #15
1198 # CHECK: pkhtb r2, r2, r3, asr #31
1199 # CHECK: pkhtb r2, r2, r3, asr #15
1209 #------------------------------------------------------------------------------
1211 #------------------------------------------------------------------------------
1212 # CHECK: pld [r5, #-4]
1213 # CHECK: pld [r6, #32]
1214 # CHECK: pld [r6, #33]
1215 # CHECK: pld [r6, #257]
1216 # CHECK: pld [r7, #257]
1224 #------------------------------------------------------------------------------
1226 #------------------------------------------------------------------------------
1227 # CHECK: pld [r8, r1]
1228 # CHECK: pld [r5, r2]
1229 # CHECK: pld [r0, r2, lsl #3]
1230 # CHECK: pld [r8, r2, lsl #2]
1231 # CHECK: pld [sp, r2, lsl #1]
1232 # CHECK: pld [sp, r2]
1241 #------------------------------------------------------------------------------
1243 #------------------------------------------------------------------------------
1244 # CHECK: pli [r5, #-4]
1245 # CHECK: pli [r6, #32]
1246 # CHECK: pli [r6, #33]
1247 # CHECK: pli [r6, #257]
1248 # CHECK: pli [r7, #257]
1256 #------------------------------------------------------------------------------
1258 #------------------------------------------------------------------------------
1259 # CHECK: pli [r8, r1]
1260 # CHECK: pli [r5, r2]
1261 # CHECK: pli [r0, r2, lsl #3]
1262 # CHECK: pli [r8, r2, lsl #2]
1263 # CHECK: pli [sp, r2, lsl #1]
1264 # CHECK: pli [sp, r2]
1274 #------------------------------------------------------------------------------
1276 #------------------------------------------------------------------------------
1277 # CHECK: qadd r1, r2, r3
1278 # CHECK: qadd16 r1, r2, r3
1279 # CHECK: qadd8 r1, r2, r3
1281 # CHECK: qaddgt r1, r2, r3
1282 # CHECK: qadd16gt r1, r2, r3
1283 # CHECK: qadd8le r1, r2, r3
1294 #------------------------------------------------------------------------------
1296 #------------------------------------------------------------------------------
1297 # CHECK: qdadd r6, r7, r8
1298 # CHECK: qdsub r6, r7, r8
1300 # CHECK: qdaddhi r6, r7, r8
1301 # CHECK: qdsubhi r6, r7, r8
1310 #------------------------------------------------------------------------------
1312 #------------------------------------------------------------------------------
1313 # CHECK: qsax r9, r12, r0
1315 # CHECK: qsaxeq r9, r12, r0
1322 #------------------------------------------------------------------------------
1324 #------------------------------------------------------------------------------
1325 # CHECK: qsub r1, r2, r3
1326 # CHECK: qsub16 r1, r2, r3
1327 # CHECK: qsub8 r1, r2, r3
1329 # CHECK: qsuble r1, r2, r3
1330 # CHECK: qsub16gt r1, r2, r3
1331 # CHECK: qsub8le r1, r2, r3
1342 #------------------------------------------------------------------------------
1344 #------------------------------------------------------------------------------
1345 # CHECK: rbit r1, r2
1347 # CHECK: rbitne r1, r2
1354 #------------------------------------------------------------------------------
1356 #------------------------------------------------------------------------------
1357 # CHECK: rev.w r1, r2
1358 # CHECK: rev.w r2, r8
1360 # CHECK: revne r1, r2
1361 # CHECK: revne.w r1, r8
1370 #------------------------------------------------------------------------------
1372 #------------------------------------------------------------------------------
1373 # CHECK: rev16.w r1, r2
1374 # CHECK: rev16.w r2, r8
1376 # CHECK: rev16ne r1, r2
1377 # CHECK: rev16ne.w r1, r8
1386 #------------------------------------------------------------------------------
1388 #------------------------------------------------------------------------------
1389 # CHECK: revsh.w r1, r2
1390 # CHECK: revsh.w r2, r8
1392 # CHECK: revshne r1, r2
1393 # CHECK: revshne.w r1, r8
1402 #------------------------------------------------------------------------------
1404 #------------------------------------------------------------------------------
1405 # CHECK: ror.w r2, r3, #12
1406 # CHECK: rors.w r8, r3, #31
1407 # CHECK: rors.w r2, r3, #1
1408 # CHECK: ror.w r2, r3, #4
1409 # CHECK: rors.w r2, r12, #15
1411 # CHECK: ror.w r3, r3, #19
1412 # CHECK: rors.w r8, r8, #2
1413 # CHECK: rors.w r7, r7, #5
1414 # CHECK: ror.w r12, r12, #21
1428 #------------------------------------------------------------------------------
1430 #------------------------------------------------------------------------------
1431 # CHECK: ror.w r3, r4, r2
1432 # CHECK: ror.w r1, r1, r2
1433 # CHECK: rors.w r3, r4, r8
1440 #------------------------------------------------------------------------------
1442 #------------------------------------------------------------------------------
1444 # CHECK: rrxs r1, r2
1446 # CHECK: rrxlt r9, r12
1447 # CHECK: rrxsge r8, r3
1455 #------------------------------------------------------------------------------
1457 #------------------------------------------------------------------------------
1458 # CHECK: rsb.w r2, r5, #1044480
1459 # CHECK: rsbs.w r3, r12, #15
1460 # CHECK: rsb.w r1, r1, #255
1467 #------------------------------------------------------------------------------
1469 #------------------------------------------------------------------------------
1470 # CHECK: rsb r4, r4, r8
1471 # CHECK: rsb r4, r9, r8
1472 # CHECK: rsb r1, r4, r8, asr #3
1473 # CHECK: rsbs r2, r1, r7, lsl #1
1481 #------------------------------------------------------------------------------
1483 #------------------------------------------------------------------------------
1484 # CHECK: sadd16 r3, r4, r8
1486 # CHECK: sadd16ne r3, r4, r8
1493 #------------------------------------------------------------------------------
1495 #------------------------------------------------------------------------------
1496 # CHECK: sadd8 r3, r4, r8
1498 # CHECK: sadd8ne r3, r4, r8
1505 #------------------------------------------------------------------------------
1507 #------------------------------------------------------------------------------
1508 # CHECK: sasx r9, r2, r7
1510 # CHECK: sasxne r2, r5, r6
1517 #------------------------------------------------------------------------------
1519 #------------------------------------------------------------------------------
1520 # CHECK: sbc r0, r1, #4
1521 # CHECK: sbcs r0, r1, #0
1522 # CHECK: sbc r1, r2, #255
1523 # CHECK: sbc r3, r7, #5570645
1524 # CHECK: sbc r8, r12, #2852170240
1525 # CHECK: sbc r9, r7, #2779096485
1526 # CHECK: sbc r5, r3, #2264924160
1527 # CHECK: sbc r4, r2, #2139095040
1528 # CHECK: sbc r4, r2, #1664
1541 #------------------------------------------------------------------------------
1543 #------------------------------------------------------------------------------
1544 # CHECK: sbc.w r4, r5, r6
1545 # CHECK: sbcs.w r4, r5, r6
1546 # CHECK: sbc.w r9, r1, r3
1547 # CHECK: sbcs.w r9, r1, r3
1548 # CHECK: sbc.w r0, r1, r3, ror #4
1549 # CHECK: sbcs.w r0, r1, r3, lsl #7
1550 # CHECK: sbc.w r0, r1, r3, lsr #31
1551 # CHECK: sbcs.w r0, r1, r3, asr #32
1563 #------------------------------------------------------------------------------
1565 #------------------------------------------------------------------------------
1566 # CHECK: sbfx r4, r5, #16, #1
1568 # CHECK: sbfxgt r4, r5, #16, #16
1575 #------------------------------------------------------------------------------
1577 #------------------------------------------------------------------------------
1578 # CHECK: sel r5, r9, r2
1580 # CHECK: selle r5, r9, r2
1587 #------------------------------------------------------------------------------
1589 #------------------------------------------------------------------------------
1599 #------------------------------------------------------------------------------
1601 #------------------------------------------------------------------------------
1602 # CHECK: sadd16 r1, r2, r3
1603 # CHECK: sadd8 r1, r2, r3
1605 # CHECK: sadd16gt r1, r2, r3
1606 # CHECK: sadd8le r1, r2, r3
1615 #------------------------------------------------------------------------------
1617 #------------------------------------------------------------------------------
1618 # CHECK: shasx r4, r8, r2
1620 # CHECK: shasxgt r4, r8, r2
1627 #------------------------------------------------------------------------------
1629 #------------------------------------------------------------------------------
1630 # CHECK: shsax r4, r8, r2
1632 # CHECK: shsaxgt r4, r8, r2
1639 #------------------------------------------------------------------------------
1641 #------------------------------------------------------------------------------
1642 # CHECK: shsub16 r4, r8, r2
1643 # CHECK: shsub8 r4, r8, r2
1645 # CHECK: shsub16gt r4, r8, r2
1646 # CHECK: shsub8gt r4, r8, r2
1655 #------------------------------------------------------------------------------
1656 # SMLABB/SMLABT/SMLATB/SMLATT
1657 #------------------------------------------------------------------------------
1658 # CHECK: smlabb r3, r1, r9, r0
1659 # CHECK: smlabt r5, r6, r4, r1
1660 # CHECK: smlatb r4, r2, r3, r2
1661 # CHECK: smlatt r8, r3, r8, r4
1663 # CHECK: smlabbgt r3, r1, r9, r0
1664 # CHECK: smlabtle r5, r6, r4, r1
1665 # CHECK: smlatbgt r4, r2, r3, r2
1666 # CHECK: smlattle r8, r3, r8, r4
1679 #------------------------------------------------------------------------------
1681 #------------------------------------------------------------------------------
1682 # CHECK: smlad r2, r3, r5, r8
1683 # CHECK: smladx r2, r3, r5, r8
1685 # CHECK: smladhi r2, r3, r5, r8
1686 # CHECK: smladxhi r2, r3, r5, r8
1695 #------------------------------------------------------------------------------
1697 #------------------------------------------------------------------------------
1698 # CHECK: smlal r2, r3, r5, r8
1700 # CHECK: smlaleq r2, r3, r5, r8
1707 #------------------------------------------------------------------------------
1708 # SMLALBB/SMLALBT/SMLALTB/SMLALTT
1709 #------------------------------------------------------------------------------
1710 # CHECK: smlalbb r3, r1, r9, r0
1711 # CHECK: smlalbt r5, r6, r4, r1
1712 # CHECK: smlaltb r4, r2, r3, r2
1713 # CHECK: smlaltt r8, r3, r8, r4
1715 # CHECK: smlalbbge r3, r1, r9, r0
1716 # CHECK: smlalbtlt r5, r6, r4, r1
1717 # CHECK: smlaltblt r4, r2, r3, r2
1718 # CHECK: smlalttge r8, r3, r8, r4
1730 #------------------------------------------------------------------------------
1732 #------------------------------------------------------------------------------
1733 # CHECK: smlald r2, r3, r5, r8
1734 # CHECK: smlaldx r2, r3, r5, r8
1736 # CHECK: smlaldeq r2, r3, r5, r8
1737 # CHECK: smlaldxne r2, r3, r5, r8
1746 #------------------------------------------------------------------------------
1748 #------------------------------------------------------------------------------
1749 # CHECK: smlawb r2, r3, r10, r8
1750 # CHECK: smlawt r8, r3, r5, r9
1752 # CHECK: smlawbeq r2, r7, r5, r8
1753 # CHECK: smlawtne r1, r3, r0, r8
1762 #------------------------------------------------------------------------------
1764 #------------------------------------------------------------------------------
1765 # CHECK: smlsd r2, r3, r5, r8
1766 # CHECK: smlsdx r2, r3, r5, r8
1768 # CHECK: smlsdle r2, r3, r5, r8
1769 # CHECK: smlsdxgt r2, r3, r5, r8
1778 #------------------------------------------------------------------------------
1780 #------------------------------------------------------------------------------
1781 # CHECK: smlsld r2, r9, r5, r1
1782 # CHECK: smlsldx r4, r11, r2, r8
1784 # CHECK: smlsldge r8, r2, r5, r6
1785 # CHECK: smlsldxlt r1, r0, r3, r8
1794 #------------------------------------------------------------------------------
1796 #------------------------------------------------------------------------------
1797 # CHECK: smmla r1, r2, r3, r4
1798 # CHECK: smmlar r4, r3, r2, r1
1800 # CHECK: smmlalo r1, r2, r3, r4
1801 # CHECK: smmlarhs r4, r3, r2, r1
1810 #------------------------------------------------------------------------------
1812 #------------------------------------------------------------------------------
1813 # CHECK: smmls r1, r2, r3, r4
1814 # CHECK: smmlsr r4, r3, r2, r1
1816 # CHECK: smmlslo r1, r2, r3, r4
1817 # CHECK: smmlsrhs r4, r3, r2, r1
1825 #------------------------------------------------------------------------------
1827 #------------------------------------------------------------------------------
1828 # CHECK: ssat r9, #30, r0, asr #2
1832 #------------------------------------------------------------------------------
1834 #------------------------------------------------------------------------------
1835 # CHECK: str r10, [r11], #0
1839 #------------------------------------------------------------------------------
1841 #------------------------------------------------------------------------------
1842 # CHECK: strd r6, r3, [r5], #-8
1843 # CHECK: strd r8, r5, [r5], #-0
1844 # CHECK: strd r7, r4, [r5], #-4
1845 # CHECK: strd r0, r1, [r2, #-0]!
1846 # CHECK: strd r0, r1, [r2, #-0]
1854 #------------------------------------------------------------------------------
1855 # STREX/STREXB/STREXH/STREXD
1856 #------------------------------------------------------------------------------
1857 # CHECK: strex r1, r8, [r4]
1858 # CHECK: strex r8, r2, [r4]
1859 # CHECK: strex r2, r12, [sp, #128]
1860 # CHECK: strexb r5, r1, [r7]
1861 # CHECK: strexh r9, r7, [r12]
1862 # CHECK: strexd r9, r3, r6, [r4]
1872 #------------------------------------------------------------------------------
1874 #------------------------------------------------------------------------------
1875 # CHECK: strh r5, [r5, #-4]
1876 # CHECK: strh r5, [r6, #32]
1877 # CHECK: strh.w r5, [r6, #33]
1878 # CHECK: strh.w r5, [r6, #257]
1879 # CHECK: strh.w lr, [r7, #257]
1880 # CHECK: strh r5, [r8, #255]!
1881 # CHECK: strh r2, [r5, #4]!
1882 # CHECK: strh r1, [r4, #-4]!
1883 # CHECK: strh lr, [r3], #255
1884 # CHECK: strh r9, [r2], #4
1885 # CHECK: strh r3, [sp], #-4
1900 #------------------------------------------------------------------------------
1902 #------------------------------------------------------------------------------
1903 # CHECK: strh.w r1, [r8, r1]
1904 # CHECK: strh.w r4, [r5, r2]
1905 # CHECK: strh.w r6, [r0, r2, lsl #3]
1906 # CHECK: strh.w r8, [r8, r2, lsl #2]
1907 # CHECK: strh.w r7, [sp, r2, lsl #1]
1908 # CHECK: strh.w r7, [sp, r2]
1918 #------------------------------------------------------------------------------
1920 #------------------------------------------------------------------------------
1921 # CHECK: strht r1, [r2]
1922 # CHECK: strht r1, [r8]
1923 # CHECK: strht r1, [r8, #3]
1924 # CHECK: strht r1, [r8, #255]
1932 #------------------------------------------------------------------------------
1934 #------------------------------------------------------------------------------
1935 # CHECK: strt r1, [r2]
1936 # CHECK: strt r1, [r8]
1937 # CHECK: strt r1, [r8, #3]
1938 # CHECK: strt r1, [r8, #255]
1946 #------------------------------------------------------------------------------
1948 #------------------------------------------------------------------------------
1950 # CHECK: subeq r1, r2, #4
1951 # CHECK: subwne r5, r3, #1023
1952 # CHECK: subweq r4, r5, #293
1953 # CHECK: sub.w r2, sp, #1024
1954 # CHECK: sub.w r2, r8, #65280
1955 # CHECK: subw r2, r3, #257
1956 # CHECK: sub.w r12, r6, #256
1957 # CHECK: subw r12, r6, #256
1958 # CHECK: subs.w r1, r2, #496
1972 #------------------------------------------------------------------------------
1974 #------------------------------------------------------------------------------
1975 # CHECK: sub.w r4, r5, r6
1976 # CHECK: sub.w r4, r5, r6, lsl #5
1977 # CHECK: sub.w r4, r5, r6, lsr #5
1978 # CHECK: sub.w r4, r5, r6, lsr #5
1979 # CHECK: sub.w r4, r5, r6, asr #5
1980 # CHECK: sub.w r4, r5, r6, ror #5
1981 # CHECK: sub.w r5, r2, r12, rrx
1992 #------------------------------------------------------------------------------
1994 #------------------------------------------------------------------------------
2005 #------------------------------------------------------------------------------
2007 #------------------------------------------------------------------------------
2008 # CHECK: sxtab r2, r3, r4
2009 # CHECK: sxtab r4, r5, r6
2011 # CHECK: sxtablt r6, r2, r9, ror #8
2012 # CHECK: sxtab r5, r1, r4, ror #16
2013 # CHECK: sxtab r7, r8, r3, ror #24
2023 #------------------------------------------------------------------------------
2025 #------------------------------------------------------------------------------
2026 # CHECK: sxtab16 r6, r2, r7
2027 # CHECK: sxtab16 r3, r5, r8, ror #8
2028 # CHECK: sxtab16 r3, r2, r1, ror #16
2030 # CHECK: sxtab16ne r0, r1, r4
2031 # CHECK: sxtab16eq r1, r2, r3, ror #24
2041 #------------------------------------------------------------------------------
2043 #------------------------------------------------------------------------------
2044 # CHECK: sxtah r1, r3, r9
2045 # CHECK: sxtah r3, r8, r3, ror #8
2046 # CHECK: sxtah r9, r3, r3, ror #24
2048 # CHECK: sxtahhi r6, r1, r6
2049 # CHECK: sxtahls r2, r2, r4, ror #16
2059 #------------------------------------------------------------------------------
2061 #------------------------------------------------------------------------------
2062 # CHECK: sxtb r5, r6
2063 # CHECK: sxtb.w r6, r9, ror #8
2064 # CHECK: sxtb.w r8, r3, ror #24
2066 # CHECK: sxtbge r2, r4
2067 # CHECK: sxtblt.w r5, r1, ror #16
2077 #------------------------------------------------------------------------------
2079 #------------------------------------------------------------------------------
2080 # CHECK: sxtb16 r1, r4
2081 # CHECK: sxtb16 r6, r7
2082 # CHECK: sxtb16 r3, r1, ror #16
2084 # CHECK: sxtb16hs r3, r5, ror #8
2085 # CHECK: sxtb16lo r2, r3, ror #24
2095 #------------------------------------------------------------------------------
2097 #------------------------------------------------------------------------------
2098 # CHECK: sxth r1, r6
2099 # CHECK: sxth.w r3, r8, ror #8
2100 # CHECK: sxth.w r9, r3, ror #24
2102 # CHECK: sxthne.w r3, r9
2103 # CHECK: sxthne.w r2, r2, ror #16
2113 #------------------------------------------------------------------------------
2115 #------------------------------------------------------------------------------
2116 # CHECK: sxtb r5, r6
2117 # CHECK: sxtb.w r6, r9, ror #8
2118 # CHECK: sxtb.w r8, r3, ror #24
2120 # CHECK: sxtbge r2, r4
2121 # CHECK: sxtblt.w r5, r1, ror #16
2131 #------------------------------------------------------------------------------
2133 #------------------------------------------------------------------------------
2134 # CHECK: sxtb16 r1, r4
2135 # CHECK: sxtb16 r6, r7
2136 # CHECK: sxtb16 r3, r1, ror #16
2138 # CHECK: sxtb16hs r3, r5, ror #8
2139 # CHECK: sxtb16lo r2, r3, ror #24
2149 #------------------------------------------------------------------------------
2151 #------------------------------------------------------------------------------
2152 # CHECK: sxth r1, r6
2153 # CHECK: sxth.w r3, r8, ror #8
2154 # CHECK: sxth.w r9, r3, ror #24
2156 # CHECK: sxthne.w r3, r9
2157 # CHECK: sxthne.w r2, r2, ror #16
2167 #------------------------------------------------------------------------------
2169 #------------------------------------------------------------------------------
2170 # CHECK: tbb [r3, r8]
2171 # CHECK: tbh [r3, r8, lsl #1]
2173 # CHECK: tbbeq [r3, r8]
2175 # CHECK: tbhhs [r3, r8, lsl #1]
2185 #------------------------------------------------------------------------------
2187 #------------------------------------------------------------------------------
2188 # CHECK: teq.w r5, #61440
2189 # CHECK: teq.w r4, r5
2190 # CHECK: teq.w r4, r5, lsl #5
2191 # CHECK: teq.w r4, r5, lsr #5
2192 # CHECK: teq.w r4, r5, lsr #5
2193 # CHECK: teq.w r4, r5, asr #5
2194 # CHECK: teq.w r4, r5, ror #5
2205 #------------------------------------------------------------------------------
2207 #------------------------------------------------------------------------------
2208 # CHECK: tst.w r5, #61440
2210 # CHECK: tst.w r3, r12, lsl #5
2211 # CHECK: tst.w r4, r11, lsr #4
2212 # CHECK: tst.w r5, r10, lsr #12
2213 # CHECK: tst.w r6, r9, asr #30
2214 # CHECK: tst.w r7, r8, ror #2
2225 #------------------------------------------------------------------------------
2227 #------------------------------------------------------------------------------
2228 # CHECK: uadd16 r1, r2, r3
2229 # CHECK: uadd8 r1, r2, r3
2231 # CHECK: uadd16gt r1, r2, r3
2232 # CHECK: uadd8le r1, r2, r3
2241 #------------------------------------------------------------------------------
2243 #------------------------------------------------------------------------------
2244 # CHECK: uasx r9, r12, r0
2246 # CHECK: uasxeq r9, r12, r0
2247 # CHECK: uasx r9, r12, r0
2249 # CHECK: uasxeq r9, r12, r0
2259 #------------------------------------------------------------------------------
2261 #------------------------------------------------------------------------------
2262 # CHECK: ubfx r4, r5, #16, #1
2264 # CHECK: ubfxgt r4, r5, #16, #16
2271 #------------------------------------------------------------------------------
2273 #------------------------------------------------------------------------------
2274 # CHECK: uhadd16 r4, r8, r2
2275 # CHECK: uhadd8 r4, r8, r2
2277 # CHECK: uhadd16gt r4, r8, r2
2278 # CHECK: uhadd8gt r4, r8, r2
2287 #------------------------------------------------------------------------------
2289 #------------------------------------------------------------------------------
2290 # CHECK: uhasx r4, r1, r5
2291 # CHECK: uhsax r5, r6, r6
2293 # CHECK: uhasxgt r6, r9, r8
2294 # CHECK: uhsaxgt r7, r8, r12
2302 #------------------------------------------------------------------------------
2304 #------------------------------------------------------------------------------
2305 # CHECK: uhsub16 r5, r8, r3
2306 # CHECK: uhsub8 r1, r7, r6
2308 # CHECK: uhsub16lt r4, r9, r12
2309 # CHECK: uhsub8lt r3, r1, r5
2318 #------------------------------------------------------------------------------
2320 #------------------------------------------------------------------------------
2321 # CHECK: umaal r3, r4, r5, r6
2323 # CHECK: umaallt r3, r4, r5, r6
2330 #------------------------------------------------------------------------------
2332 #------------------------------------------------------------------------------
2333 # CHECK: umlal r2, r4, r6, r8
2335 # CHECK: umlalgt r6, r1, r2, r6
2342 #------------------------------------------------------------------------------
2344 #------------------------------------------------------------------------------
2345 # CHECK: umull r2, r4, r6, r8
2347 # CHECK: umullgt r6, r1, r2, r6
2354 #------------------------------------------------------------------------------
2356 #------------------------------------------------------------------------------
2357 # CHECK: uqadd16 r1, r2, r3
2358 # CHECK: uqadd8 r3, r4, r8
2360 # CHECK: uqadd16gt r4, r7, r9
2361 # CHECK: uqadd8le r8, r1, r2
2370 #------------------------------------------------------------------------------
2372 #------------------------------------------------------------------------------
2373 # CHECK: uqasx r1, r2, r3
2374 # CHECK: uqsax r3, r4, r8
2376 # CHECK: uqasxgt r4, r7, r9
2377 # CHECK: uqsaxle r8, r1, r2
2386 #------------------------------------------------------------------------------
2388 #------------------------------------------------------------------------------
2389 # CHECK: uqsub8 r8, r2, r9
2390 # CHECK: uqsub16 r1, r9, r7
2392 # CHECK: uqsub8gt r3, r1, r6
2393 # CHECK: uqsub16le r4, r6, r4
2402 #------------------------------------------------------------------------------
2404 #------------------------------------------------------------------------------
2405 # CHECK: usad8 r1, r9, r7
2406 # CHECK: usada8 r8, r2, r9, r12
2408 # CHECK: usada8gt r3, r1, r6, r9
2409 # CHECK: usad8le r4, r6, r4
2418 #------------------------------------------------------------------------------
2420 #------------------------------------------------------------------------------
2421 # CHECK: usat r8, #1, r10
2422 # CHECK: usat r8, #4, r10
2423 # CHECK: usat r8, #5, r10, lsl #31
2424 # CHECK: usat r8, #16, r10, asr #1
2432 #------------------------------------------------------------------------------
2434 #------------------------------------------------------------------------------
2435 # CHECK: usat16 r2, #2, r7
2436 # CHECK: usat16 r3, #15, r5
2442 #------------------------------------------------------------------------------
2444 #------------------------------------------------------------------------------
2445 # CHECK: usax r2, r3, r4
2447 # CHECK: usaxne r6, r1, r9
2448 # CHECK: usax r2, r3, r4
2450 # CHECK: usaxne r6, r1, r9
2460 #------------------------------------------------------------------------------
2462 #------------------------------------------------------------------------------
2463 # CHECK: usub16 r4, r2, r7
2464 # CHECK: usub8 r1, r8, r5
2466 # CHECK: usub16hi r1, r1, r3
2467 # CHECK: usub8ls r9, r2, r3
2476 #------------------------------------------------------------------------------
2478 #------------------------------------------------------------------------------
2479 # CHECK: uxtab r2, r3, r4
2480 # CHECK: uxtab r4, r5, r6
2482 # CHECK: uxtablt r6, r2, r9, ror #8
2483 # CHECK: uxtab r5, r1, r4, ror #16
2484 # CHECK: uxtab r7, r8, r3, ror #24
2494 #------------------------------------------------------------------------------
2496 #------------------------------------------------------------------------------
2498 # CHECK: uxtab16ge r0, r1, r4
2499 # CHECK: uxtab16 r6, r2, r7
2500 # CHECK: uxtab16 r3, r5, r8, ror #8
2501 # CHECK: uxtab16 r3, r2, r1, ror #16
2503 # CHECK: uxtab16eq r1, r2, r3, ror #24
2514 #------------------------------------------------------------------------------
2516 #------------------------------------------------------------------------------
2517 # CHECK: uxtah r1, r3, r9
2519 # CHECK: uxtahhi r6, r1, r6
2520 # CHECK: uxtah r3, r8, r3, ror #8
2522 # CHECK: uxtahlo r2, r2, r4, ror #16
2523 # CHECK: uxtah r9, r3, r3, ror #24
2534 #------------------------------------------------------------------------------
2536 #------------------------------------------------------------------------------
2538 # CHECK: uxtbge r2, r4
2539 # CHECK: uxtb r5, r6
2540 # CHECK: uxtb.w r6, r9, ror #8
2542 # CHECK: uxtblo.w r5, r1, ror #16
2543 # CHECK: uxtb.w r8, r3, ror #24
2554 #------------------------------------------------------------------------------
2556 #------------------------------------------------------------------------------
2557 # CHECK: uxtb16 r1, r4
2558 # CHECK: uxtb16 r6, r7
2560 # CHECK: uxtb16hs r3, r5, ror #8
2561 # CHECK: uxtb16 r3, r1, ror #16
2563 # CHECK: uxtb16ge r2, r3, ror #24
2574 #------------------------------------------------------------------------------
2576 #------------------------------------------------------------------------------
2578 # CHECK: uxthne.w r3, r9
2579 # CHECK: uxth r1, r6
2580 # CHECK: uxth.w r3, r8, ror #8
2582 # CHECK: uxthle.w r2, r2, ror #16
2583 # CHECK: uxth.w r9, r3, ror #24
2594 #------------------------------------------------------------------------------
2596 #------------------------------------------------------------------------------