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