Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / MC / MSP430 / opcode.s
blob70334291810214f25886df4cda90372bd1e9c8f8
1 ; RUN: llvm-mc -triple msp430 -show-encoding %s \
2 ; RUN: | FileCheck -check-prefixes=CHECK,CHECK-INST %s
4 ; RUN: llvm-mc -triple msp430 -filetype=obj %s \
5 ; RUN: | llvm-objdump -d - | FileCheck --check-prefix=CHECK-INST %s
7 ;; IForm8 instructions
8 mov.b r7, r8 ; CHECK-INST: mov.b r7, r8
9 ; CHECK: encoding: [0x48,0x47]
10 add.b r7, r8 ; CHECK-INST: add.b r7, r8
11 ; CHECK: encoding: [0x48,0x57]
12 addc.b r7, r8 ; CHECK-INST: addc.b r7, r8
13 ; CHECK: encoding: [0x48,0x67]
14 subc.b r7, r8 ; CHECK-INST: subc.b r7, r8
15 ; CHECK: encoding: [0x48,0x77]
16 sub.b r7, r8 ; CHECK-INST: sub.b r7, r8
17 ; CHECK: encoding: [0x48,0x87]
18 cmp.b r7, r8 ; CHECK-INST: cmp.b r7, r8
19 ; CHECK: encoding: [0x48,0x97]
20 dadd.b r7, r8 ; CHECK-INST: dadd.b r7, r8
21 ; CHECK: encoding: [0x48,0xa7]
22 bit.b r7, r8 ; CHECK-INST: bit.b r7, r8
23 ; CHECK: encoding: [0x48,0xb7]
24 bic.b r7, r8 ; CHECK-INST: bic.b r7, r8
25 ; CHECK: encoding: [0x48,0xc7]
26 bis.b r7, r8 ; CHECK-INST: bis.b r7, r8
27 ; CHECK: encoding: [0x48,0xd7]
28 xor.b r7, r8 ; CHECK-INST: xor.b r7, r8
29 ; CHECK: encoding: [0x48,0xe7]
30 and.b r7, r8 ; CHECK-INST: and.b r7, r8
31 ; CHECK: encoding: [0x48,0xf7]
33 ;; IForm16 instructions
34 mov r7, r8 ; CHECK-INST: mov r7, r8
35 ; CHECK: encoding: [0x08,0x47]
36 add r7, r8 ; CHECK-INST: add r7, r8
37 ; CHECK: encoding: [0x08,0x57]
38 addc r7, r8 ; CHECK-INST: addc r7, r8
39 ; CHECK: encoding: [0x08,0x67]
40 subc r7, r8 ; CHECK-INST: subc r7, r8
41 ; CHECK: encoding: [0x08,0x77]
42 sub r7, r8 ; CHECK-INST: sub r7, r8
43 ; CHECK: encoding: [0x08,0x87]
44 cmp r7, r8 ; CHECK-INST: cmp r7, r8
45 ; CHECK: encoding: [0x08,0x97]
46 dadd r7, r8 ; CHECK-INST: dadd r7, r8
47 ; CHECK: encoding: [0x08,0xa7]
48 bit r7, r8 ; CHECK-INST: bit r7, r8
49 ; CHECK: encoding: [0x08,0xb7]
50 bic r7, r8 ; CHECK-INST: bic r7, r8
51 ; CHECK: encoding: [0x08,0xc7]
52 bis r7, r8 ; CHECK-INST: bis r7, r8
53 ; CHECK: encoding: [0x08,0xd7]
54 xor r7, r8 ; CHECK-INST: xor r7, r8
55 ; CHECK: encoding: [0x08,0xe7]
56 and r7, r8 ; CHECK-INST: and r7, r8
57 ; CHECK: encoding: [0x08,0xf7]
59 ;; IIForm8 instructions
60 rrc.b r7 ; CHECK-INST: rrc.b r7
61 ; CHECK: encoding: [0x47,0x10]
62 rra.b r7 ; CHECK-INST: rra.b r7
63 ; CHECK: encoding: [0x47,0x11]
64 push.b r7 ; CHECK-INST: push.b r7
65 ; CHECK: encoding: [0x47,0x12]
67 ;; IIForm16 instructions
68 rrc r7 ; CHECK-INST: rrc r7
69 ; CHECK: encoding: [0x07,0x10]
70 swpb r7 ; CHECK-INST: swpb r7
71 ; CHECK: encoding: [0x87,0x10]
72 rra r7 ; CHECK-INST: rra r7
73 ; CHECK: encoding: [0x07,0x11]
74 sxt r7 ; CHECK-INST: sxt r7
75 ; CHECK: encoding: [0x87,0x11]
76 push r7 ; CHECK-INST: push r7
77 ; CHECK: encoding: [0x07,0x12]
78 call r7 ; CHECK-INST: call r7
79 ; CHECK: encoding: [0x87,0x12]
80 reti ; CHECK-INST: reti
81 ; CHECK: encoding: [0x00,0x13]
83 ;; CJForm instructions
84 jnz -2 ; CHECK-INST: jne $-2
85 ; CHECK: encoding: [0xfe,0x23]
86 jne -2 ; CHECK-INST: jne $-2
87 ; CHECK: encoding: [0xfe,0x23]
88 jeq -2 ; CHECK-INST: jeq $-2
89 ; CHECK: encoding: [0xfe,0x27]
90 jz -2 ; CHECK-INST: jeq $-2
91 ; CHECK: encoding: [0xfe,0x27]
92 jnc -2 ; CHECK-INST: jlo $-2
93 ; CHECK: encoding: [0xfe,0x2b]
94 jlo -2 ; CHECK-INST: jlo $-2
95 ; CHECK: encoding: [0xfe,0x2b]
96 jc -2 ; CHECK-INST: jhs $-2
97 ; CHECK: encoding: [0xfe,0x2f]
98 jhs -2 ; CHECK-INST: jhs $-2
99 ; CHECK: encoding: [0xfe,0x2f]
100 jn -2 ; CHECK-INST: jn $-2
101 ; CHECK: encoding: [0xfe,0x33]
102 jge -2 ; CHECK-INST: jge $-2
103 ; CHECK: encoding: [0xfe,0x37]
104 jl -2 ; CHECK-INST: jl $-2
105 ; CHECK: encoding: [0xfe,0x3b]
106 jmp $-2 ; CHECK-INST: jmp $-2
107 ; CHECK: encoding: [0xfe,0x3f]
109 ;; Emulated arithmetic instructions
110 adc r7 ; CHECK-INST: adc r7
111 ; CHECK: encoding: [0x07,0x63]
112 dadc r7 ; CHECK-INST: dadc r7
113 ; CHECK: encoding: [0x07,0xa3]
114 dec r7 ; CHECK-INST: dec r7
115 ; CHECK: encoding: [0x17,0x83]
116 decd r7 ; CHECK-INST: decd r7
117 ; CHECK: encoding: [0x27,0x83]
118 inc r7 ; CHECK-INST: inc r7
119 ; CHECK: encoding: [0x17,0x53]
120 incd r7 ; CHECK-INST: incd r7
121 ; CHECK: encoding: [0x27,0x53]
122 sbc r7 ; CHECK-INST: sbc r7
123 ; CHECK: encoding: [0x07,0x73]
125 ;; Emulated logical instructions
126 inv r7 ; CHECK-INST: inv r7
127 ; CHECK: encoding: [0x37,0xe3]
128 rla r7 ; CHECK-INST: add r7, r7
129 ; CHECK: encoding: [0x07,0x57]
130 rlc r7 ; CHECK-INST: addc r7, r7
131 ; CHECK: encoding: [0x07,0x67]
133 ;; Emulated program flow control instructions
134 br r7 ; CHECK-INST: br r7
135 ; CHECK: encoding: [0x00,0x47]
136 dint ; CHECK-INST: dint
137 ; CHECK: encoding: [0x32,0xc2]
138 eint ; CHECK-INST: eint
139 ; CHECK: encoding: [0x32,0xd2]
140 nop ; CHECK-INST: nop
141 ; CHECK: encoding: [0x03,0x43]
142 ret ; CHECK-INST: ret
143 ; CHECK: encoding: [0x30,0x41]
145 ;; Emulated data instruction
146 clr r7 ; CHECK-INST: clr r7
147 ; CHECK: encoding: [0x07,0x43]
148 clrc ; CHECK-INST: clrc
149 ; CHECK: encoding: [0x12,0xc3]
150 clrn ; CHECK-INST: clrn
151 ; CHECK: encoding: [0x22,0xc2]
152 clrz ; CHECK-INST: clrz
153 ; CHECK: encoding: [0x22,0xc3]
154 pop r7 ; CHECK-INST: pop r7
155 ; CHECK: encoding: [0x37,0x41]
156 setc ; CHECK-INST: setc
157 ; CHECK: encoding: [0x12,0xd3]
158 setn ; CHECK-INST: setn
159 ; CHECK: encoding: [0x22,0xd2]
160 setz ; CHECK-INST: setz
161 ; CHECK: encoding: [0x22,0xd3]
162 tst r7 ; CHECK-INST: tst r7
163 ; CHECK: encoding: [0x07,0x93]