2012-01-13 18:45:31 +00:00
|
|
|
// RUN: llvm-mc -triple x86_64-unknown-unknown -x86-asm-syntax=intel %s | FileCheck %s
|
|
|
|
|
2012-01-17 18:30:45 +00:00
|
|
|
_test:
|
|
|
|
xor EAX, EAX
|
|
|
|
ret
|
|
|
|
|
|
|
|
_main:
|
2012-01-13 18:45:31 +00:00
|
|
|
// CHECK: movl $257, -4(%rsp)
|
|
|
|
mov DWORD PTR [RSP - 4], 257
|
2012-01-17 19:08:07 +00:00
|
|
|
// CHECK: movl $258, 4(%rsp)
|
|
|
|
mov DWORD PTR [RSP + 4], 258
|
2012-01-13 18:45:31 +00:00
|
|
|
// 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]
|
2012-01-17 18:00:18 +00:00
|
|
|
// 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]
|
2012-01-17 21:25:10 +00:00
|
|
|
// CHECK: movb %dil, (%rdx,%rcx)
|
|
|
|
mov BYTE PTR [RDX + RCX], DIL
|
2012-01-17 21:48:03 +00:00
|
|
|
// CHECK: movzwl 2(%rcx), %edi
|
|
|
|
movzx EDI, WORD PTR [RCX + 2]
|
2012-01-17 18:30:45 +00:00
|
|
|
// CHECK: callq _test
|
|
|
|
call _test
|
2012-01-18 22:42:29 +00:00
|
|
|
// 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
|
2012-01-20 22:32:05 +00:00
|
|
|
// CHECK: fld %st(0)
|
|
|
|
fld ST(0)
|
2012-01-23 18:31:58 +00:00
|
|
|
// CHECK: movl %fs:(%rdi), %eax
|
2012-01-23 22:35:25 +00:00
|
|
|
mov EAX, DWORD PTR FS:[RDI]
|
2012-01-23 20:20:06 +00:00
|
|
|
// CHECK: leal (,%rdi,4), %r8d
|
2012-01-23 22:35:25 +00:00
|
|
|
lea R8D, DWORD PTR [4*RDI]
|
|
|
|
// CHECK: movl _fnan(,%ecx,4), %ecx
|
|
|
|
mov ECX, DWORD PTR [4*ECX + _fnan]
|
2012-01-27 19:48:28 +00:00
|
|
|
// CHECK: movq %fs:320, %rax
|
|
|
|
mov RAX, QWORD PTR FS:[320]
|
2012-07-18 04:11:12 +00:00
|
|
|
// CHECK: vpgatherdd %xmm8, (%r15,%xmm9,2), %xmm1
|
|
|
|
vpgatherdd XMM10, DWORD PTR [R15 + 2*XMM9], XMM8
|
2012-01-17 18:30:45 +00:00
|
|
|
ret
|