Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / MC / X86 / x86_64-tbm-encoding.s
blob8c7fe21844870bedfd6d5c1dfdfdafcbbb70fd32
1 // RUN: llvm-mc -triple x86_64-unknown-unknown --show-encoding %s | FileCheck %s
3 // bextri 32 reg
4 // CHECK: bextrl $2814, %edi, %eax
5 // CHECK: encoding: [0x8f,0xea,0x78,0x10,0xc7,0xfe,0x0a,0x00,0x00]
6 bextr $2814, %edi, %eax
8 // bextri 32 mem
9 // CHECK: bextrl $2814, (%rdi), %eax
10 // CHECK: encoding: [0x8f,0xea,0x78,0x10,0x07,0xfe,0x0a,0x00,0x00]
11 bextr $2814, (%rdi), %eax
13 // bextri 64 reg
14 // CHECK: bextrq $2814, %rdi, %rax
15 // CHECK: encoding: [0x8f,0xea,0xf8,0x10,0xc7,0xfe,0x0a,0x00,0x00]
16 bextr $2814, %rdi, %rax
18 // bextri 64 mem
19 // CHECK: bextrq $2814, (%rdi), %rax
20 // CHECK: encoding: [0x8f,0xea,0xf8,0x10,0x07,0xfe,0x0a,0x00,0x00]
21 bextr $2814, (%rdi), %rax
23 // blcfill 32 reg
24 // CHECK: blcfilll %edi, %eax
25 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0xcf]
26 blcfill %edi, %eax
28 // blcfill 32 mem
29 // CHECK: blcfilll (%rdi), %eax
30 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0x0f]
31 blcfill (%rdi), %eax
33 // blcfill 64 reg
34 // CHECK: blcfillq %rdi, %rax
35 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0xcf]
36 blcfill %rdi, %rax
38 // blcfill 64 mem
39 // CHECK: blcfillq (%rdi), %rax
40 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0x0f]
41 blcfill (%rdi), %rax
43 // blci 32 reg
44 // CHECK: blcil %edi, %eax
45 // CHECK: encoding: [0x8f,0xe9,0x78,0x02,0xf7]
46 blci %edi, %eax
48 // blci 32 mem
49 // CHECK: blcil (%rdi), %eax
50 // CHECK: encoding: [0x8f,0xe9,0x78,0x02,0x37]
51 blci (%rdi), %eax
53 // blci 64 reg
54 // CHECK: blciq %rdi, %rax
55 // CHECK: encoding: [0x8f,0xe9,0xf8,0x02,0xf7]
56 blci %rdi, %rax
58 // blci 64 mem
59 // CHECK: blciq (%rdi), %rax
60 // CHECK: encoding: [0x8f,0xe9,0xf8,0x02,0x37]
61 blci (%rdi), %rax
63 // blcic 32 reg
64 // CHECK: blcicl %edi, %eax
65 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0xef]
66 blcic %edi, %eax
68 // blcic 32 mem
69 // CHECK: blcicl (%rdi), %eax
70 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0x2f]
71 blcic (%rdi), %eax
73 // blcic 64 reg
74 // CHECK: blcicq %rdi, %rax
75 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0xef]
76 blcic %rdi, %rax
78 // blcic 64 mem
79 // CHECK: blcicq (%rdi), %rax
80 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0x2f]
81 blcic (%rdi), %rax
83 // blcmsk 32 reg
84 // CHECK: blcmskl %edi, %eax
85 // CHECK: encoding: [0x8f,0xe9,0x78,0x02,0xcf]
86 blcmsk %edi, %eax
88 // blcmsk 32 mem
89 // CHECK: blcmskl (%rdi), %eax
90 // CHECK: encoding: [0x8f,0xe9,0x78,0x02,0x0f]
91 blcmsk (%rdi), %eax
93 // blcmsk 64 reg
94 // CHECK: blcmskq %rdi, %rax
95 // CHECK: encoding: [0x8f,0xe9,0xf8,0x02,0xcf]
96 blcmsk %rdi, %rax
98 // blcmsk 64 mem
99 // CHECK: blcmskq (%rdi), %rax
100 // CHECK: encoding: [0x8f,0xe9,0xf8,0x02,0x0f]
101 blcmsk (%rdi), %rax
103 // blcs 32 reg
104 // CHECK: blcsl %edi, %eax
105 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0xdf]
106 blcs %edi, %eax
108 // blcs 32 mem
109 // CHECK: blcsl (%rdi), %eax
110 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0x1f]
111 blcs (%rdi), %eax
113 // blcs 64 reg
114 // CHECK: blcsq %rdi, %rax
115 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0xdf]
116 blcs %rdi, %rax
118 // blcs 64 mem
119 // CHECK: blcsq (%rdi), %rax
120 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0x1f]
121 blcs (%rdi), %rax
123 // blsfill 32 reg
124 // CHECK: blsfilll %edi, %eax
125 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0xd7]
126 blsfill %edi, %eax
128 // blsfill 32 mem
129 // CHECK: blsfilll (%rdi), %eax
130 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0x17]
131 blsfill (%rdi), %eax
133 // blsfill 64 reg
134 // CHECK: blsfillq %rdi, %rax
135 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0xd7]
136 blsfill %rdi, %rax
138 // blsfill 64 mem
139 // CHECK: blsfillq (%rdi), %rax
140 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0x17]
141 blsfill (%rdi), %rax
143 // blsic 32 reg
144 // CHECK: blsicl %edi, %eax
145 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0xf7]
146 blsic %edi, %eax
148 // blsic 32 mem
149 // CHECK: blsicl (%rdi), %eax
150 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0x37]
151 blsic (%rdi), %eax
153 // blsic 64 reg
154 // CHECK: blsicq %rdi, %rax
155 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0xf7]
156 blsic %rdi, %rax
158 // t1mskc 32 reg
159 // CHECK: t1mskcl %edi, %eax
160 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0xff]
161 t1mskc %edi, %eax
163 // t1mskc 32 mem
164 // CHECK: t1mskcl (%rdi), %eax
165 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0x3f]
166 t1mskc (%rdi), %eax
168 // t1mskc 64 reg
169 // CHECK: t1mskcq %rdi, %rax
170 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0xff]
171 t1mskc %rdi, %rax
173 // t1mskc 64 mem
174 // CHECK: t1mskcq (%rdi), %rax
175 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0x3f]
176 t1mskc (%rdi), %rax
178 // tzmsk 32 reg
179 // CHECK: tzmskl %edi, %eax
180 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0xe7]
181 tzmsk %edi, %eax
183 // tzmsk 32 mem
184 // CHECK: tzmskl (%rdi), %eax
185 // CHECK: encoding: [0x8f,0xe9,0x78,0x01,0x27]
186 tzmsk (%rdi), %eax
188 // tzmsk 64 reg
189 // CHECK: tzmskq %rdi, %rax
190 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0xe7]
191 tzmsk %rdi, %rax
193 // tzmsk 64 mem
194 // CHECK: tzmskq (%rdi), %rax
195 // CHECK: encoding: [0x8f,0xe9,0xf8,0x01,0x27]
196 tzmsk (%rdi), %rax
198 // CHECK: encoding: [0x67,0xc4,0xe2,0x60,0xf7,0x07]
199 bextr %ebx, (%edi), %eax
201 // CHECK: encoding: [0x67,0x8f,0xea,0x78,0x10,0x07,A,A,A,A]
202 bextr $foo, (%edi), %eax