Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / MC / X86 / BMI1-64.s
blob7865866234ffeb8744b94a8fa91d8094b85013f2
1 // RUN: llvm-mc -triple x86_64-unknown-unknown --show-encoding %s | FileCheck %s
3 // CHECK: andnl 485498096, %r13d, %r13d
4 // CHECK: encoding: [0xc4,0x62,0x10,0xf2,0x2c,0x25,0xf0,0x1c,0xf0,0x1c]
5 andnl 485498096, %r13d, %r13d
7 // CHECK: andnl 64(%rdx), %r13d, %r13d
8 // CHECK: encoding: [0xc4,0x62,0x10,0xf2,0x6a,0x40]
9 andnl 64(%rdx), %r13d, %r13d
11 // CHECK: andnl 64(%rdx,%rax,4), %r13d, %r13d
12 // CHECK: encoding: [0xc4,0x62,0x10,0xf2,0x6c,0x82,0x40]
13 andnl 64(%rdx,%rax,4), %r13d, %r13d
15 // CHECK: andnl -64(%rdx,%rax,4), %r13d, %r13d
16 // CHECK: encoding: [0xc4,0x62,0x10,0xf2,0x6c,0x82,0xc0]
17 andnl -64(%rdx,%rax,4), %r13d, %r13d
19 // CHECK: andnl 64(%rdx,%rax), %r13d, %r13d
20 // CHECK: encoding: [0xc4,0x62,0x10,0xf2,0x6c,0x02,0x40]
21 andnl 64(%rdx,%rax), %r13d, %r13d
23 // CHECK: andnl %r13d, %r13d, %r13d
24 // CHECK: encoding: [0xc4,0x42,0x10,0xf2,0xed]
25 andnl %r13d, %r13d, %r13d
27 // CHECK: andnl (%rdx), %r13d, %r13d
28 // CHECK: encoding: [0xc4,0x62,0x10,0xf2,0x2a]
29 andnl (%rdx), %r13d, %r13d
31 // CHECK: andnq 485498096, %r15, %r15
32 // CHECK: encoding: [0xc4,0x62,0x80,0xf2,0x3c,0x25,0xf0,0x1c,0xf0,0x1c]
33 andnq 485498096, %r15, %r15
35 // CHECK: andnq 64(%rdx), %r15, %r15
36 // CHECK: encoding: [0xc4,0x62,0x80,0xf2,0x7a,0x40]
37 andnq 64(%rdx), %r15, %r15
39 // CHECK: andnq 64(%rdx,%rax,4), %r15, %r15
40 // CHECK: encoding: [0xc4,0x62,0x80,0xf2,0x7c,0x82,0x40]
41 andnq 64(%rdx,%rax,4), %r15, %r15
43 // CHECK: andnq -64(%rdx,%rax,4), %r15, %r15
44 // CHECK: encoding: [0xc4,0x62,0x80,0xf2,0x7c,0x82,0xc0]
45 andnq -64(%rdx,%rax,4), %r15, %r15
47 // CHECK: andnq 64(%rdx,%rax), %r15, %r15
48 // CHECK: encoding: [0xc4,0x62,0x80,0xf2,0x7c,0x02,0x40]
49 andnq 64(%rdx,%rax), %r15, %r15
51 // CHECK: andnq %r15, %r15, %r15
52 // CHECK: encoding: [0xc4,0x42,0x80,0xf2,0xff]
53 andnq %r15, %r15, %r15
55 // CHECK: andnq (%rdx), %r15, %r15
56 // CHECK: encoding: [0xc4,0x62,0x80,0xf2,0x3a]
57 andnq (%rdx), %r15, %r15
59 // CHECK: bextrl %r13d, 485498096, %r13d
60 // CHECK: encoding: [0xc4,0x62,0x10,0xf7,0x2c,0x25,0xf0,0x1c,0xf0,0x1c]
61 bextrl %r13d, 485498096, %r13d
63 // CHECK: bextrl %r13d, 64(%rdx), %r13d
64 // CHECK: encoding: [0xc4,0x62,0x10,0xf7,0x6a,0x40]
65 bextrl %r13d, 64(%rdx), %r13d
67 // CHECK: bextrl %r13d, 64(%rdx,%rax,4), %r13d
68 // CHECK: encoding: [0xc4,0x62,0x10,0xf7,0x6c,0x82,0x40]
69 bextrl %r13d, 64(%rdx,%rax,4), %r13d
71 // CHECK: bextrl %r13d, -64(%rdx,%rax,4), %r13d
72 // CHECK: encoding: [0xc4,0x62,0x10,0xf7,0x6c,0x82,0xc0]
73 bextrl %r13d, -64(%rdx,%rax,4), %r13d
75 // CHECK: bextrl %r13d, 64(%rdx,%rax), %r13d
76 // CHECK: encoding: [0xc4,0x62,0x10,0xf7,0x6c,0x02,0x40]
77 bextrl %r13d, 64(%rdx,%rax), %r13d
79 // CHECK: bextrl %r13d, %r13d, %r13d
80 // CHECK: encoding: [0xc4,0x42,0x10,0xf7,0xed]
81 bextrl %r13d, %r13d, %r13d
83 // CHECK: bextrl %r13d, (%rdx), %r13d
84 // CHECK: encoding: [0xc4,0x62,0x10,0xf7,0x2a]
85 bextrl %r13d, (%rdx), %r13d
87 // CHECK: bextrq %r15, 485498096, %r15
88 // CHECK: encoding: [0xc4,0x62,0x80,0xf7,0x3c,0x25,0xf0,0x1c,0xf0,0x1c]
89 bextrq %r15, 485498096, %r15
91 // CHECK: bextrq %r15, 64(%rdx), %r15
92 // CHECK: encoding: [0xc4,0x62,0x80,0xf7,0x7a,0x40]
93 bextrq %r15, 64(%rdx), %r15
95 // CHECK: bextrq %r15, 64(%rdx,%rax,4), %r15
96 // CHECK: encoding: [0xc4,0x62,0x80,0xf7,0x7c,0x82,0x40]
97 bextrq %r15, 64(%rdx,%rax,4), %r15
99 // CHECK: bextrq %r15, -64(%rdx,%rax,4), %r15
100 // CHECK: encoding: [0xc4,0x62,0x80,0xf7,0x7c,0x82,0xc0]
101 bextrq %r15, -64(%rdx,%rax,4), %r15
103 // CHECK: bextrq %r15, 64(%rdx,%rax), %r15
104 // CHECK: encoding: [0xc4,0x62,0x80,0xf7,0x7c,0x02,0x40]
105 bextrq %r15, 64(%rdx,%rax), %r15
107 // CHECK: bextrq %r15, %r15, %r15
108 // CHECK: encoding: [0xc4,0x42,0x80,0xf7,0xff]
109 bextrq %r15, %r15, %r15
111 // CHECK: bextrq %r15, (%rdx), %r15
112 // CHECK: encoding: [0xc4,0x62,0x80,0xf7,0x3a]
113 bextrq %r15, (%rdx), %r15
115 // CHECK: blsil 485498096, %r13d
116 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x1c,0x25,0xf0,0x1c,0xf0,0x1c]
117 blsil 485498096, %r13d
119 // CHECK: blsil 64(%rdx), %r13d
120 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x5a,0x40]
121 blsil 64(%rdx), %r13d
123 // CHECK: blsil 64(%rdx,%rax,4), %r13d
124 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x5c,0x82,0x40]
125 blsil 64(%rdx,%rax,4), %r13d
127 // CHECK: blsil -64(%rdx,%rax,4), %r13d
128 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x5c,0x82,0xc0]
129 blsil -64(%rdx,%rax,4), %r13d
131 // CHECK: blsil 64(%rdx,%rax), %r13d
132 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x5c,0x02,0x40]
133 blsil 64(%rdx,%rax), %r13d
135 // CHECK: blsil %r13d, %r13d
136 // CHECK: encoding: [0xc4,0xc2,0x10,0xf3,0xdd]
137 blsil %r13d, %r13d
139 // CHECK: blsil (%rdx), %r13d
140 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x1a]
141 blsil (%rdx), %r13d
143 // CHECK: blsiq 485498096, %r15
144 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x1c,0x25,0xf0,0x1c,0xf0,0x1c]
145 blsiq 485498096, %r15
147 // CHECK: blsiq 64(%rdx), %r15
148 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x5a,0x40]
149 blsiq 64(%rdx), %r15
151 // CHECK: blsiq 64(%rdx,%rax,4), %r15
152 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x5c,0x82,0x40]
153 blsiq 64(%rdx,%rax,4), %r15
155 // CHECK: blsiq -64(%rdx,%rax,4), %r15
156 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x5c,0x82,0xc0]
157 blsiq -64(%rdx,%rax,4), %r15
159 // CHECK: blsiq 64(%rdx,%rax), %r15
160 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x5c,0x02,0x40]
161 blsiq 64(%rdx,%rax), %r15
163 // CHECK: blsiq %r15, %r15
164 // CHECK: encoding: [0xc4,0xc2,0x80,0xf3,0xdf]
165 blsiq %r15, %r15
167 // CHECK: blsiq (%rdx), %r15
168 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x1a]
169 blsiq (%rdx), %r15
171 // CHECK: blsmskl 485498096, %r13d
172 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x14,0x25,0xf0,0x1c,0xf0,0x1c]
173 blsmskl 485498096, %r13d
175 // CHECK: blsmskl 64(%rdx), %r13d
176 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x52,0x40]
177 blsmskl 64(%rdx), %r13d
179 // CHECK: blsmskl 64(%rdx,%rax,4), %r13d
180 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x54,0x82,0x40]
181 blsmskl 64(%rdx,%rax,4), %r13d
183 // CHECK: blsmskl -64(%rdx,%rax,4), %r13d
184 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x54,0x82,0xc0]
185 blsmskl -64(%rdx,%rax,4), %r13d
187 // CHECK: blsmskl 64(%rdx,%rax), %r13d
188 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x54,0x02,0x40]
189 blsmskl 64(%rdx,%rax), %r13d
191 // CHECK: blsmskl %r13d, %r13d
192 // CHECK: encoding: [0xc4,0xc2,0x10,0xf3,0xd5]
193 blsmskl %r13d, %r13d
195 // CHECK: blsmskl (%rdx), %r13d
196 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x12]
197 blsmskl (%rdx), %r13d
199 // CHECK: blsmskq 485498096, %r15
200 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x14,0x25,0xf0,0x1c,0xf0,0x1c]
201 blsmskq 485498096, %r15
203 // CHECK: blsmskq 64(%rdx), %r15
204 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x52,0x40]
205 blsmskq 64(%rdx), %r15
207 // CHECK: blsmskq 64(%rdx,%rax,4), %r15
208 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x54,0x82,0x40]
209 blsmskq 64(%rdx,%rax,4), %r15
211 // CHECK: blsmskq -64(%rdx,%rax,4), %r15
212 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x54,0x82,0xc0]
213 blsmskq -64(%rdx,%rax,4), %r15
215 // CHECK: blsmskq 64(%rdx,%rax), %r15
216 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x54,0x02,0x40]
217 blsmskq 64(%rdx,%rax), %r15
219 // CHECK: blsmskq %r15, %r15
220 // CHECK: encoding: [0xc4,0xc2,0x80,0xf3,0xd7]
221 blsmskq %r15, %r15
223 // CHECK: blsmskq (%rdx), %r15
224 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x12]
225 blsmskq (%rdx), %r15
227 // CHECK: blsrl 485498096, %r13d
228 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x0c,0x25,0xf0,0x1c,0xf0,0x1c]
229 blsrl 485498096, %r13d
231 // CHECK: blsrl 64(%rdx), %r13d
232 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x4a,0x40]
233 blsrl 64(%rdx), %r13d
235 // CHECK: blsrl 64(%rdx,%rax,4), %r13d
236 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x4c,0x82,0x40]
237 blsrl 64(%rdx,%rax,4), %r13d
239 // CHECK: blsrl -64(%rdx,%rax,4), %r13d
240 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x4c,0x82,0xc0]
241 blsrl -64(%rdx,%rax,4), %r13d
243 // CHECK: blsrl 64(%rdx,%rax), %r13d
244 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x4c,0x02,0x40]
245 blsrl 64(%rdx,%rax), %r13d
247 // CHECK: blsrl %r13d, %r13d
248 // CHECK: encoding: [0xc4,0xc2,0x10,0xf3,0xcd]
249 blsrl %r13d, %r13d
251 // CHECK: blsrl (%rdx), %r13d
252 // CHECK: encoding: [0xc4,0xe2,0x10,0xf3,0x0a]
253 blsrl (%rdx), %r13d
255 // CHECK: blsrq 485498096, %r15
256 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x0c,0x25,0xf0,0x1c,0xf0,0x1c]
257 blsrq 485498096, %r15
259 // CHECK: blsrq 64(%rdx), %r15
260 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x4a,0x40]
261 blsrq 64(%rdx), %r15
263 // CHECK: blsrq 64(%rdx,%rax,4), %r15
264 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x4c,0x82,0x40]
265 blsrq 64(%rdx,%rax,4), %r15
267 // CHECK: blsrq -64(%rdx,%rax,4), %r15
268 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x4c,0x82,0xc0]
269 blsrq -64(%rdx,%rax,4), %r15
271 // CHECK: blsrq 64(%rdx,%rax), %r15
272 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x4c,0x02,0x40]
273 blsrq 64(%rdx,%rax), %r15
275 // CHECK: blsrq %r15, %r15
276 // CHECK: encoding: [0xc4,0xc2,0x80,0xf3,0xcf]
277 blsrq %r15, %r15
279 // CHECK: blsrq (%rdx), %r15
280 // CHECK: encoding: [0xc4,0xe2,0x80,0xf3,0x0a]
281 blsrq (%rdx), %r15
283 // CHECK: tzcntl %r13d, %r13d
284 // CHECK: encoding: [0xf3,0x45,0x0f,0xbc,0xed]
285 tzcntl %r13d, %r13d