// RUN: llvm-mc -triple x86_64-unknown-unknown -x86-asm-syntax=intel %s | FileCheck %s _test: xor EAX, EAX ret _main: // CHECK: movl $257, -4(%rsp) mov DWORD PTR [RSP - 4], 257 // CHECK: movl $258, 4(%rsp) mov DWORD PTR [RSP + 4], 258 // CHECK: movq $123, -16(%rsp) mov QWORD PTR [RSP - 16], 123 // CHECK: movb $97, -17(%rsp) mov BYTE PTR [RSP - 17], 97 // CHECK: movl -4(%rsp), %eax mov EAX, DWORD PTR [RSP - 4] // CHECK: movq (%rsp), %rax mov RAX, QWORD PTR [RSP] // CHECK: movl $-4, -4(%rsp) mov DWORD PTR [RSP - 4], -4 // CHECK: movq 0, %rcx mov RCX, QWORD PTR [0] // CHECK: movl -24(%rsp,%rax,4), %eax mov EAX, DWORD PTR [RSP + 4*RAX - 24] // CHECK: movb %dil, (%rdx,%rcx) mov BYTE PTR [RDX + RCX], DIL // CHECK: movzwl 2(%rcx), %edi movzx EDI, WORD PTR [RCX + 2] // CHECK: callq _test call _test // CHECK: andw $12, %ax and ax, 12 // CHECK: andw $-12, %ax and ax, -12 // CHECK: andw $257, %ax and ax, 257 // CHECK: andw $-257, %ax and ax, -257 // CHECK: andl $12, %eax and eax, 12 // CHECK: andl $-12, %eax and eax, -12 // CHECK: andl $257, %eax and eax, 257 // CHECK: andl $-257, %eax and eax, -257 // CHECK: andq $12, %rax and rax, 12 // CHECK: andq $-12, %rax and rax, -12 // CHECK: andq $257, %rax and rax, 257 // CHECK: andq $-257, %rax and rax, -257 // CHECK: fld %st(0) fld ST(0) // CHECK: movl %fs:(%rdi), %eax mov EAX, DWORD PTR FS:[RDI] // CHECK: leal (,%rdi,4), %r8d lea R8D, DWORD PTR [4*RDI] // CHECK: movl _fnan(,%ecx,4), %ecx mov ECX, DWORD PTR [4*ECX + _fnan] // CHECK: movq %fs:320, %rax mov RAX, QWORD PTR FS:[320] // CHECK: vpgatherdd %xmm8, (%r15,%xmm9,2), %xmm1 vpgatherdd XMM10, DWORD PTR [R15 + 2*XMM9], XMM8 ret