1 // RUN: llvm-mc -triple x86_64-unknown-unknown -x86-asm-syntax=intel %s | FileCheck %s
8 // CHECK: movl $257, -4(%rsp)
9 mov DWORD PTR [RSP - 4], 257
10 // CHECK: movl $258, 4(%rsp)
11 mov DWORD PTR [RSP + 4], 258
12 // CHECK: movq $123, -16(%rsp)
13 mov QWORD PTR [RSP - 16], 123
14 // CHECK: movb $97, -17(%rsp)
15 mov BYTE PTR [RSP - 17], 97
16 // CHECK: movl -4(%rsp), %eax
17 mov EAX, DWORD PTR [RSP - 4]
18 // CHECK: movq (%rsp), %rax
19 mov RAX, QWORD PTR [RSP]
20 // CHECK: movl $-4, -4(%rsp)
21 mov DWORD PTR [RSP - 4], -4
22 // CHECK: movq 0, %rcx
23 mov RCX, QWORD PTR [0]
24 // CHECK: movl -24(%rsp,%rax,4), %eax
25 mov EAX, DWORD PTR [RSP + 4*RAX - 24]
26 // CHECK: movb %dil, (%rdx,%rcx)
27 mov BYTE PTR [RDX + RCX], DIL
28 // CHECK: movzwl 2(%rcx), %edi
29 movzx EDI, WORD PTR [RCX + 2]
32 // CHECK: andw $12, %ax
34 // CHECK: andw $-12, %ax
36 // CHECK: andw $257, %ax
38 // CHECK: andw $-257, %ax
40 // CHECK: andl $12, %eax
42 // CHECK: andl $-12, %eax
44 // CHECK: andl $257, %eax
46 // CHECK: andl $-257, %eax
48 // CHECK: andq $12, %rax
50 // CHECK: andq $-12, %rax
52 // CHECK: andq $257, %rax
54 // CHECK: andq $-257, %rax
58 // CHECK: movl %fs:(%rdi), %eax
59 mov EAX, DWORD PTR FS:[RDI]
60 // CHECK: leal (,%rdi,4), %r8d
61 lea R8D, DWORD PTR [4*RDI]
62 // CHECK: movl _fnan(,%ecx,4), %ecx
63 mov ECX, DWORD PTR [4*ECX + _fnan]
64 // CHECK: movq %fs:320, %rax
65 mov RAX, QWORD PTR FS:[320]
66 // CHECK: movq %fs:320, %rax
67 mov RAX, QWORD PTR FS:320
68 // CHECK: movq %rax, %fs:320
69 mov QWORD PTR FS:320, RAX
70 // CHECK: movq %rax, %fs:20(%rbx)
71 mov QWORD PTR FS:20[rbx], RAX
72 // CHECK: vshufpd $1, %xmm2, %xmm1, %xmm0
73 vshufpd XMM0, XMM1, XMM2, 1
74 // CHECK: vpgatherdd %xmm8, (%r15,%xmm9,2), %xmm1
75 vpgatherdd XMM10, DWORD PTR [R15 + 2*XMM9], XMM8
76 // CHECK: movsd -8, %xmm5
77 movsd XMM5, QWORD PTR [-8]
78 // CHECK: movl %ecx, (%eax)
80 // CHECK: movl %ecx, (,%ebx,4)
82 // CHECK: movl %ecx, (,%ebx,4)
84 // CHECK: movl %ecx, 1024
86 // CHECK: movl %ecx, 4132
88 // CHECK: movl %ecx, 32
90 // CHECK: movl %ecx, 0
92 // CHECK: movl %ecx, 32
94 // CHECK: movl %ecx, (%eax,%ebx,4)
95 mov [eax + 4*ebx], ecx
96 // CHECK: movl %ecx, (%eax,%ebx,4)
97 mov [eax + ebx*4], ecx
98 // CHECK: movl %ecx, (%eax,%ebx,4)
99 mov [4*ebx + eax], ecx
100 // CHECK: movl %ecx, (%eax,%ebx,4)
101 mov [ebx*4 + eax], ecx
102 // CHECK: movl %ecx, (%eax,%ebx,4)
103 mov [eax][4*ebx], ecx
104 // CHECK: movl %ecx, (%eax,%ebx,4)
105 mov [eax][ebx*4], ecx
106 // CHECK: movl %ecx, (%eax,%ebx,4)
107 mov [4*ebx][eax], ecx
108 // CHECK: movl %ecx, (%eax,%ebx,4)
109 mov [ebx*4][eax], ecx
110 // CHECK: movl %ecx, 12(%eax)
112 // CHECK: movl %ecx, 12(%eax)
114 // CHECK: movl %ecx, 32(%eax)
115 mov [eax + 16 + 16], ecx
116 // CHECK: movl %ecx, 32(%eax)
117 mov [16 + eax + 16], ecx
118 // CHECK: movl %ecx, 32(%eax)
119 mov [16 + 16 + eax], ecx
120 // CHECK: movl %ecx, 12(%eax)
122 // CHECK: movl %ecx, 12(%eax)
124 // CHECK: movl %ecx, 32(%eax)
125 mov [eax][16 + 16], ecx
126 // CHECK: movl %ecx, 32(%eax)
127 mov [eax + 16][16], ecx
128 // CHECK: movl %ecx, 32(%eax)
129 mov [eax][16][16], ecx
130 // CHECK: movl %ecx, 32(%eax)
131 mov [16][eax + 16], ecx
132 // CHECK: movl %ecx, 32(%eax)
133 mov [16 + eax][16], ecx
134 // CHECK: movl %ecx, 32(%eax)
135 mov [16][16 + eax], ecx
136 // CHECK: movl %ecx, 32(%eax)
137 mov [16 + 16][eax], ecx
138 // CHECK: movl %ecx, 32(%eax)
139 mov [eax][16][16], ecx
140 // CHECK: movl %ecx, 32(%eax)
141 mov [16][eax][16], ecx
142 // CHECK: movl %ecx, 32(%eax)
143 mov [16][16][eax], ecx
144 // CHECK: movl %ecx, 16(,%ebx,4)
145 mov [4*ebx + 16], ecx
146 // CHECK: movl %ecx, 16(,%ebx,4)
147 mov [ebx*4 + 16], ecx
148 // CHECK: movl %ecx, 16(,%ebx,4)
150 // CHECK: movl %ecx, 16(,%ebx,4)
152 // CHECK: movl %ecx, 16(,%ebx,4)
153 mov [16 + 4*ebx], ecx
154 // CHECK: movl %ecx, 16(,%ebx,4)
155 mov [16 + ebx*4], ecx
156 // CHECK: movl %ecx, 16(,%ebx,4)
158 // CHECK: movl %ecx, 16(,%ebx,4)
160 // CHECK: movl %ecx, 16(%eax,%ebx,4)
161 mov [eax + 4*ebx + 16], ecx
162 // CHECK: movl %ecx, 16(%eax,%ebx,4)
163 mov [eax + 16 + 4*ebx], ecx
164 // CHECK: movl %ecx, 16(%eax,%ebx,4)
165 mov [4*ebx + eax + 16], ecx
166 // CHECK: movl %ecx, 16(%eax,%ebx,4)
167 mov [4*ebx + 16 + eax], ecx
168 // CHECK: movl %ecx, 16(%eax,%ebx,4)
169 mov [16 + eax + 4*ebx], ecx
170 // CHECK: movl %ecx, 16(%eax,%ebx,4)
171 mov [16 + eax + 4*ebx], ecx
172 // CHECK: movl %ecx, 16(%eax,%ebx,4)
173 mov [eax][4*ebx + 16], ecx
174 // CHECK: movl %ecx, 16(%eax,%ebx,4)
175 mov [eax][16 + 4*ebx], ecx
176 // CHECK: movl %ecx, 16(%eax,%ebx,4)
177 mov [4*ebx][eax + 16], ecx
178 // CHECK: movl %ecx, 16(%eax,%ebx,4)
179 mov [4*ebx][16 + eax], ecx
180 // CHECK: movl %ecx, 16(%eax,%ebx,4)
181 mov [16][eax + 4*ebx], ecx
182 // CHECK: movl %ecx, 16(%eax,%ebx,4)
183 mov [16][eax + 4*ebx], ecx
184 // CHECK: movl %ecx, 16(%eax,%ebx,4)
185 mov [eax + 4*ebx][16], ecx
186 // CHECK: movl %ecx, 16(%eax,%ebx,4)
187 mov [eax + 16][4*ebx], ecx
188 // CHECK: movl %ecx, 16(%eax,%ebx,4)
189 mov [4*ebx + eax][16], ecx
190 // CHECK: movl %ecx, 16(%eax,%ebx,4)
191 mov [4*ebx + 16][eax], ecx
192 // CHECK: movl %ecx, 16(%eax,%ebx,4)
193 mov [16 + eax][4*ebx], ecx
194 // CHECK: movl %ecx, 16(%eax,%ebx,4)
195 mov [16 + eax][4*ebx], ecx
196 // CHECK: movl %ecx, 16(%eax,%ebx,4)
197 mov [eax][4*ebx][16], ecx
198 // CHECK: movl %ecx, 16(%eax,%ebx,4)
199 mov [eax][16][4*ebx], ecx
200 // CHECK: movl %ecx, 16(%eax,%ebx,4)
201 mov [4*ebx][eax][16], ecx
202 // CHECK: movl %ecx, 16(%eax,%ebx,4)
203 mov [4*ebx][16][eax], ecx
204 // CHECK: movl %ecx, 16(%eax,%ebx,4)
205 mov [16][eax][4*ebx], ecx
206 // CHECK: movl %ecx, 16(%eax,%ebx,4)
207 mov [16][eax][4*ebx], ecx
208 // CHECK: movl %ecx, 16(%eax,%ebx,4)
209 mov [eax + ebx*4 + 16], ecx
210 // CHECK: movl %ecx, 16(%eax,%ebx,4)
211 mov [eax + 16 + ebx*4], ecx
212 // CHECK: movl %ecx, 16(%eax,%ebx,4)
213 mov [ebx*4 + eax + 16], ecx
214 // CHECK: movl %ecx, 16(%eax,%ebx,4)
215 mov [ebx*4 + 16 + eax], ecx
216 // CHECK: movl %ecx, 16(%eax,%ebx,4)
217 mov [16 + eax + ebx*4], ecx
218 // CHECK: movl %ecx, 16(%eax,%ebx,4)
219 mov [16 + eax + ebx*4], ecx
220 // CHECK: movl %ecx, 16(%eax,%ebx,4)
221 mov [eax][ebx*4 + 16], ecx
222 // CHECK: movl %ecx, 16(%eax,%ebx,4)
223 mov [eax][16 + ebx*4], ecx
224 // CHECK: movl %ecx, 16(%eax,%ebx,4)
225 mov [ebx*4][eax + 16], ecx
226 // CHECK: movl %ecx, 16(%eax,%ebx,4)
227 mov [ebx*4][16 + eax], ecx
228 // CHECK: movl %ecx, 16(%eax,%ebx,4)
229 mov [16][eax + ebx*4], ecx
230 // CHECK: movl %ecx, 16(%eax,%ebx,4)
231 mov [16][eax + ebx*4], ecx
232 // CHECK: movl %ecx, 16(%eax,%ebx,4)
233 mov [eax + ebx*4][16], ecx
234 // CHECK: movl %ecx, 16(%eax,%ebx,4)
235 mov [eax + 16][ebx*4], ecx
236 // CHECK: movl %ecx, 16(%eax,%ebx,4)
237 mov [ebx*4 + eax][16], ecx
238 // CHECK: movl %ecx, 16(%eax,%ebx,4)
239 mov [ebx*4 + 16][eax], ecx
240 // CHECK: movl %ecx, 16(%eax,%ebx,4)
241 mov [16 + eax][ebx*4], ecx
242 // CHECK: movl %ecx, 16(%eax,%ebx,4)
243 mov [16 + eax][ebx*4], ecx
244 // CHECK: movl %ecx, 16(%eax,%ebx,4)
245 mov [eax][ebx*4][16], ecx
246 // CHECK: movl %ecx, 16(%eax,%ebx,4)
247 mov [eax][16][ebx*4], ecx
248 // CHECK: movl %ecx, 16(%eax,%ebx,4)
249 mov [ebx*4][eax][16], ecx
250 // CHECK: movl %ecx, 16(%eax,%ebx,4)
251 mov [ebx*4][16][eax], ecx
252 // CHECK: movl %ecx, 16(%eax,%ebx,4)
253 mov [16][eax][ebx*4], ecx
254 // CHECK: movl %ecx, 16(%eax,%ebx,4)
255 mov [16][eax][ebx*4], ecx
256 // CHECK: movl %ecx, -16(%eax,%ebx,4)
257 mov [eax][ebx*4 - 16], ecx
259 // CHECK: prefetchnta 12800(%esi)
260 prefetchnta [esi + (200*64)]
261 // CHECK: prefetchnta 32(%esi)
262 prefetchnta [esi + (64/2)]
263 // CHECK: prefetchnta 128(%esi)
264 prefetchnta [esi + (64/2*4)]
265 // CHECK: prefetchnta 8(%esi)
266 prefetchnta [esi + (64/(2*4))]
267 // CHECK: prefetchnta 48(%esi)
268 prefetchnta [esi + (64/(2*4)+40)]
270 // CHECK: movl %ecx, -16(%eax,%ebx,4)
271 mov [eax][ebx*4 - 2*8], ecx
272 // CHECK: movl %ecx, -16(%eax,%ebx,4)
273 mov [eax][4*ebx - 2*8], ecx
274 // CHECK: movl %ecx, -16(%eax,%ebx,4)
275 mov [eax + 4*ebx - 2*8], ecx
276 // CHECK: movl %ecx, -16(%eax,%ebx,4)
277 mov [12 + eax + (4*ebx) - 2*14], ecx
278 // CHECK: movl %ecx, -16(%eax,%ebx,4)
279 mov [eax][ebx*4 - 2*2*2*2], ecx
280 // CHECK: movl %ecx, -16(%eax,%ebx,4)
281 mov [eax][ebx*4 - (2*8)], ecx
282 // CHECK: movl %ecx, -16(%eax,%ebx,4)
283 mov [eax][ebx*4 - 2 * 8 + 4 - 4], ecx
284 // CHECK: movl %ecx, -16(%eax,%ebx,4)
285 mov [eax + ebx*4 - 2 * 8 + 4 - 4], ecx
286 // CHECK: movl %ecx, -16(%eax,%ebx,4)
287 mov [eax + ebx*4 - 2 * ((8 + 4) - 4)], ecx
288 // CHECK: movl %ecx, -16(%eax,%ebx,4)
289 mov [-2 * ((8 + 4) - 4) + eax + ebx*4], ecx
290 // CHECK: movl %ecx, -16(%eax,%ebx,4)
291 mov [((-2) * ((8 + 4) - 4)) + eax + ebx*4], ecx
292 // CHECK: movl %ecx, -16(%eax,%ebx,4)
293 mov [eax + ((-2) * ((8 + 4) - 4)) + ebx*4], ecx
294 // CHECK: movl %ecx, 96(%eax,%ebx,4)
295 mov [eax + ((-2) * ((8 + 4) * -4)) + ebx*4], ecx
296 // CHECK: movl %ecx, -8(%eax,%ebx,4)
297 mov [eax][-8][ebx*4], ecx
298 // CHECK: movl %ecx, -2(%eax,%ebx,4)
299 mov [eax][16/-8][ebx*4], ecx
300 // CHECK: movl %ecx, -2(%eax,%ebx,4)
301 mov [eax][(16)/-8][ebx*4], ecx
333 // CHECK: outb %al, $4
337 // CHECK: cmovbl %ebx, %eax
339 // CHECK: cmovel %ebx, %eax
341 // CHECK: cmovbel %ebx, %eax
343 // CHECK: cmovael %ebx, %eax
345 // CHECK: cmovael %ebx, %eax
347 // CHECK: cmovlel %ebx, %eax
349 // CHECK: cmovgel %ebx, %eax
351 // CHECK: cmovnel %ebx, %eax
353 // CHECK: cmovpl %ebx, %eax
355 // CHECK: cmovnpl %ebx, %eax
357 // CHECK: cmovbl %ebx, %eax
359 // CHECK: cmoval %ebx, %eax
361 // CHECK: cmovll %ebx, %eax
363 // CHECK: cmovgl %ebx, %eax
366 // CHECK: shldw %cl, %bx, %dx
367 // CHECK: shldw %cl, %bx, %dx
368 // CHECK: shldw $1, %bx, %dx
369 // CHECK: shldw %cl, %bx, (%rax)
370 // CHECK: shldw %cl, %bx, (%rax)
371 // CHECK: shrdw %cl, %bx, %dx
372 // CHECK: shrdw %cl, %bx, %dx
373 // CHECK: shrdw $1, %bx, %dx
374 // CHECK: shrdw %cl, %bx, (%rax)
375 // CHECK: shrdw %cl, %bx, (%rax)
388 // CHECK: btl $1, (%eax)
389 // CHECK: btsl $1, (%eax)
390 // CHECK: btrl $1, (%eax)
391 // CHECK: btcl $1, (%eax)
392 bt DWORD PTR [EAX], 1
393 bt DWORD PTR [EAX], 1
394 bts DWORD PTR [EAX], 1
395 btr DWORD PTR [EAX], 1
396 btc DWORD PTR [EAX], 1
401 //CHECK: divl 3735928559(%ebx,%ecx,8)
404 //CHECK: divl 3133065982
405 //CHECK: divl 305419896
409 //CHECK: idivl 3735928559(%ebx,%ecx,8)
412 //CHECK: idivl 3133065982
413 //CHECK: idivl 305419896
417 div EAX, [ECX*8+EBX+0xdeadbeef]
420 div EAX, [0xbabecafe]
421 div EAX, [0x12345678]
425 idiv EAX, [ECX*8+EBX+0xdeadbeef]
428 idiv EAX, [0xbabecafe]
429 idiv EAX, [0x12345678]
432 // CHECK: inb %dx, %al
433 // CHECK: inw %dx, %ax
434 // CHECK: inl %dx, %eax
435 // CHECK: outb %al, %dx
436 // CHECK: outw %ax, %dx
437 // CHECK: outl %eax, %dx
445 // CHECK: xchgq %rcx, %rax
446 // CHECK: xchgq %rcx, %rax
447 // CHECK: xchgl %ecx, %eax
448 // CHECK: xchgl %ecx, %eax
449 // CHECK: xchgw %cx, %ax
450 // CHECK: xchgw %cx, %ax
458 // CHECK: xchgq %rax, (%ecx)
459 // CHECK: xchgq %rax, (%ecx)
460 // CHECK: xchgl %eax, (%ecx)
461 // CHECK: xchgl %eax, (%ecx)
462 // CHECK: xchgw %ax, (%ecx)
463 // CHECK: xchgw %ax, (%ecx)
471 // CHECK: testq (%ecx), %rax
472 // CHECK: testq (%ecx), %rax
473 // CHECK: testl (%ecx), %eax
474 // CHECK: testl (%ecx), %eax
475 // CHECK: testw (%ecx), %ax
476 // CHECK: testw (%ecx), %ax
477 // CHECK: testb (%ecx), %al
478 // CHECK: testb (%ecx), %al
497 // CHECK: faddp %st(1)
498 // CHECK: fmulp %st(1)
499 // CHECK: fsubrp %st(1)
500 // CHECK: fsubp %st(1)
501 // CHECK: fdivrp %st(1)
502 // CHECK: fdivp %st(1)
510 // CHECK: faddp %st(1)
511 // CHECK: fmulp %st(1)
512 // CHECK: fsubrp %st(1)
513 // CHECK: fsubp %st(1)
514 // CHECK: fdivrp %st(1)
515 // CHECK: fdivp %st(1)
523 // CHECK: faddp %st(1)
524 // CHECK: fmulp %st(1)
525 // CHECK: fsubrp %st(1)
526 // CHECK: fsubp %st(1)
527 // CHECK: fdivrp %st(1)
528 // CHECK: fdivp %st(1)
536 // CHECK: faddp %st(1)
537 // CHECK: fmulp %st(1)
538 // CHECK: fsubrp %st(1)
539 // CHECK: fsubp %st(1)
540 // CHECK: fdivrp %st(1)
541 // CHECK: fdivp %st(1)
549 // CHECK: fadd %st(1)
550 // CHECK: fmul %st(1)
551 // CHECK: fsub %st(1)
552 // CHECK: fsubr %st(1)
553 // CHECK: fdiv %st(1)
554 // CHECK: fdivr %st(1)
562 // CHECK: fadd %st(0), %st(1)
563 // CHECK: fmul %st(0), %st(1)
564 // CHECK: fsubr %st(0), %st(1)
565 // CHECK: fsub %st(0), %st(1)
566 // CHECK: fdivr %st(0), %st(1)
567 // CHECK: fdiv %st(0), %st(1)
575 // CHECK: fadd %st(1)
576 // CHECK: fmul %st(1)
577 // CHECK: fsub %st(1)
578 // CHECK: fsubr %st(1)
579 // CHECK: fdiv %st(1)
580 // CHECK: fdivr %st(1)
589 // CHECK: fxsaveq (%rax)
590 // CHECK: fxrstorq (%rax)
591 fxsave64 opaque ptr [rax]
592 fxrstor64 opaque ptr [rax]