905 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
			
		
		
	
	
			905 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
| // RUN: llvm-mc -triple x86_64-unknown-unknown -x86-asm-syntax=intel %s > %t 2> %t.err
 | |
| // RUN: FileCheck < %t %s
 | |
| // RUN: FileCheck --check-prefix=CHECK-STDERR < %t.err %s
 | |
| 
 | |
| _test:
 | |
| 	xor	EAX, EAX
 | |
| 	ret
 | |
| 
 | |
| .set  number, 8
 | |
| .global _foo
 | |
| 
 | |
| .text
 | |
|   .global main
 | |
| main:
 | |
| 
 | |
| // CHECK: leaq    _foo(%rbx,%rax,8), %rdx
 | |
|   lea RDX, [8 * RAX + RBX      + _foo]
 | |
| // CHECK: leaq _foo(%rbx,%rax,8), %rdx
 | |
|   lea RDX, [_foo + 8 * RAX + RBX]
 | |
| // CHECK: leaq 8(%rcx,%rax,8), %rdx
 | |
|   lea RDX, [8 + RAX * 8 + RCX]
 | |
| // CHECK: leaq 8(%rcx,%rax,8), %rdx
 | |
|   lea RDX, [number + 8 * RAX + RCX]
 | |
| // CHECK: leaq _foo(,%rax,8), %rdx
 | |
|   lea RDX, [_foo + RAX * 8]
 | |
| // CHECK:  leaq _foo(%rbx,%rax,8), %rdx
 | |
|   lea RDX, [_foo + RAX * 8 + RBX]
 | |
| // CHECK: leaq -8(%rax), %rdx
 | |
|   lea RDX, [RAX - number]
 | |
| // CHECK: leaq -8(%rax), %rdx
 | |
|   lea RDX, [RAX - 8]
 | |
| // CHECK: leaq    _foo(%rax), %rdx
 | |
|   lea RDX, [RAX + _foo]
 | |
| // CHECK: leaq    8(%rax), %rdx
 | |
|   lea RDX, [RAX + number]
 | |
| // CHECK: leaq    8(%rax), %rdx
 | |
|   lea RDX, [RAX + 8]
 | |
| // CHECK: leaq    _foo(%rbx,%rax,8), %rdx
 | |
|   lea RDX, [RAX * number + RBX + _foo]
 | |
| // CHECK: leaq    _foo(%rbx,%rax,8), %rdx
 | |
|   lea RDX, [_foo + RAX * number + RBX]
 | |
| // CHECK: leaq    8(%rcx,%rax,8), %rdx
 | |
|   lea RDX, [number + RAX * number + RCX]
 | |
| // CHECK: leaq    _foo(,%rax,8), %rdx
 | |
|   lea RDX, [_foo + RAX * number]
 | |
| // CHECK: leaq    _foo(%rbx,%rax,8), %rdx
 | |
|   lea RDX, [number * RAX + RBX + _foo]
 | |
| // CHECK: leaq    _foo(%rbx,%rax,8), %rdx
 | |
|   lea RDX, [_foo + number * RAX + RBX]
 | |
| // CHECK: leaq    8(%rcx,%rax,8), %rdx
 | |
|   lea RDX, [8 + number * RAX + RCX]
 | |
| // CHECK: leaq    _foo(%rax), %rdx
 | |
|   lea RDX, [_foo + RAX]
 | |
| // CHECK: leaq    8(%rax), %rdx
 | |
|   lea RDX, [number + RAX]
 | |
| // CHECK: leaq    8(%rax), %rdx
 | |
|   lea RDX, [8 + RAX]
 | |
| 
 | |
| // CHECK: lcalll *(%rax)
 | |
|   call FWORD ptr [rax]
 | |
| // CHECK: lcalll *(%rax)
 | |
|   lcall [rax]
 | |
| // CHECK: ljmpl *(%rax)
 | |
|   jmp FWORD ptr [rax]
 | |
| // CHECK: ljmpq *(%rax)
 | |
|   ljmp [rax]
 | |
| 
 | |
| // 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: movabsq $4294967289, %rax
 | |
| 	mov     RAX, 4294967289
 | |
| // 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: movq %fs:320, %rax
 | |
|     mov RAX, QWORD PTR FS:320
 | |
| // CHECK: movq %rax, %fs:320
 | |
|     mov QWORD PTR FS:320, RAX
 | |
| // CHECK: movq %rax, %fs:20(%rbx)
 | |
|     mov QWORD PTR FS:20[rbx], RAX
 | |
| // CHECK: vshufpd $1, %xmm2, %xmm1, %xmm0
 | |
|     vshufpd XMM0, XMM1, XMM2, 1
 | |
| // CHECK: vpgatherdd %xmm8, (%r15,%xmm9,2), %xmm1
 | |
|     vpgatherdd XMM10, XMMWORD PTR [R15 + 2*XMM9], XMM8
 | |
| // CHECK: movsd -8, %xmm5
 | |
|     movsd   XMM5, QWORD PTR [-8]
 | |
| // CHECK: movsl (%rsi), %es:(%rdi)
 | |
|     movsd
 | |
| // CHECK: movl %ecx, (%eax)
 | |
|     mov [eax], ecx
 | |
| // CHECK: movl %ecx, (,%ebx,4)
 | |
|     mov [4*ebx], ecx
 | |
|  // CHECK:   movl %ecx, (,%ebx,4)
 | |
|     mov [ebx*4], ecx
 | |
| // CHECK: movl %ecx, 1024
 | |
|     mov [1024], ecx
 | |
| // CHECK: movl %ecx, 4132
 | |
|     mov [0x1024], ecx
 | |
| // CHECK: movl %ecx, 32        
 | |
|     mov [16 + 16], ecx
 | |
| // CHECK: movl %ecx, 0
 | |
|     mov [16 - 16], ecx        
 | |
| // CHECK: movl %ecx, 32        
 | |
|     mov [16][16], ecx
 | |
| // CHECK: movl %ecx, (%eax,%ebx,4)
 | |
|     mov [eax + 4*ebx], ecx
 | |
| // CHECK: movl %ecx, (%eax,%ebx,4)
 | |
|     mov [eax + ebx*4], ecx
 | |
| // CHECK: movl %ecx, (%eax,%ebx,4)
 | |
|     mov [4*ebx + eax], ecx
 | |
| // CHECK: movl %ecx, (%eax,%ebx,4)
 | |
|     mov [ebx*4 + eax], ecx
 | |
| // CHECK: movl %ecx, (%eax,%ebx,4)
 | |
|     mov [eax][4*ebx], ecx
 | |
| // CHECK: movl %ecx, (%eax,%ebx,4)
 | |
|     mov [eax][ebx*4], ecx
 | |
| // CHECK: movl %ecx, (%eax,%ebx,4)
 | |
|     mov [4*ebx][eax], ecx
 | |
| // CHECK: movl %ecx, (%eax,%ebx,4)
 | |
|     mov [ebx*4][eax], ecx
 | |
| // CHECK: movl %ecx, 12(%eax)
 | |
|     mov [eax + 12], ecx
 | |
| // CHECK: movl %ecx, 12(%eax)
 | |
|     mov [12 + eax], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [eax + 16 + 16], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [16 + eax + 16], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [16 + 16 + eax], ecx
 | |
| // CHECK: movl %ecx, 12(%eax)
 | |
|     mov [eax][12], ecx
 | |
| // CHECK: movl %ecx, 12(%eax)
 | |
|     mov [12][eax], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [eax][16 + 16], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [eax + 16][16], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [eax][16][16], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [16][eax + 16], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [16 + eax][16], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [16][16 + eax], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [16 + 16][eax], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [eax][16][16], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [16][eax][16], ecx
 | |
| // CHECK: movl %ecx, 32(%eax)
 | |
|     mov [16][16][eax], ecx
 | |
| // CHECK: movl %ecx, 16(,%ebx,4)
 | |
|     mov [4*ebx + 16], ecx
 | |
| // CHECK: movl %ecx, 16(,%ebx,4)
 | |
|     mov [ebx*4 + 16], ecx
 | |
| // CHECK: movl %ecx, 16(,%ebx,4)
 | |
|     mov [4*ebx][16], ecx
 | |
| // CHECK: movl %ecx, 16(,%ebx,4)
 | |
|     mov [ebx*4][16], ecx
 | |
| // CHECK: movl %ecx, 16(,%ebx,4)
 | |
|     mov [16 + 4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(,%ebx,4)
 | |
|     mov [16 + ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(,%ebx,4)
 | |
|     mov [16][4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(,%ebx,4)
 | |
|     mov [16][ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax + 4*ebx + 16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax + 16 + 4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [4*ebx + eax + 16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [4*ebx + 16 + eax], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16 + eax + 4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16 + eax + 4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax][4*ebx + 16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax][16 + 4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [4*ebx][eax + 16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [4*ebx][16 + eax], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16][eax + 4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16][eax + 4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax + 4*ebx][16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax + 16][4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [4*ebx + eax][16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [4*ebx + 16][eax], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16 + eax][4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16 + eax][4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax][4*ebx][16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax][16][4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [4*ebx][eax][16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [4*ebx][16][eax], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16][eax][4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16][eax][4*ebx], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax + ebx*4 + 16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax + 16 + ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [ebx*4 + eax + 16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [ebx*4 + 16 + eax], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16 + eax + ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16 + eax + ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax][ebx*4 + 16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax][16 + ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [ebx*4][eax + 16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [ebx*4][16 + eax], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16][eax + ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16][eax + ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax + ebx*4][16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax + 16][ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [ebx*4 + eax][16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [ebx*4 + 16][eax], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16 + eax][ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16 + eax][ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax][ebx*4][16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [eax][16][ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [ebx*4][eax][16], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [ebx*4][16][eax], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16][eax][ebx*4], ecx
 | |
| // CHECK: movl %ecx, 16(%eax,%ebx,4)
 | |
|     mov [16][eax][ebx*4], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax][ebx*4 - 16], ecx
 | |
| 
 | |
| // CHECK: prefetchnta 12800(%esi)
 | |
|     prefetchnta [esi + (200*64)]
 | |
| // CHECK: prefetchnta 32(%esi)
 | |
|     prefetchnta [esi + (64/2)]
 | |
| // CHECK: prefetchnta 128(%esi)
 | |
|     prefetchnta [esi + (64/2*4)]
 | |
| // CHECK: prefetchnta 8(%esi)
 | |
|     prefetchnta [esi + (64/(2*4))]
 | |
| // CHECK: prefetchnta 48(%esi)
 | |
|     prefetchnta [esi + (64/(2*4)+40)]
 | |
| 
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax][ebx*4 - 2*8], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax][4*ebx - 2*8], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax + 4*ebx - 2*8], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [12 + eax + (4*ebx) - 2*14], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax][ebx*4 - 2*2*2*2], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax][ebx*4 - (2*8)], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax][ebx*4 - 2 * 8 + 4 - 4], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax + ebx*4 - 2 * 8 + 4 - 4], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax + ebx*4 - 2 * ((8 + 4) - 4)], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [-2 * ((8 + 4) - 4) + eax + ebx*4], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [((-2) * ((8 + 4) - 4)) + eax + ebx*4], ecx
 | |
| // CHECK: movl %ecx, -16(%eax,%ebx,4)
 | |
|     mov [eax + ((-2) * ((8 + 4) - 4)) + ebx*4], ecx
 | |
| // CHECK: movl %ecx, 96(%eax,%ebx,4)
 | |
|     mov [eax + ((-2) * ((8 + 4) * -4)) + ebx*4], ecx
 | |
| // CHECK: movl %ecx, -8(%eax,%ebx,4)
 | |
|     mov [eax][-8][ebx*4], ecx
 | |
| // CHECK: movl %ecx, -2(%eax,%ebx,4)
 | |
|     mov [eax][16/-8][ebx*4], ecx
 | |
| // CHECK: movl %ecx, -2(%eax,%ebx,4)
 | |
|     mov [eax][(16)/-8][ebx*4], ecx
 | |
| 
 | |
| // CHECK: setb %al
 | |
|     setc al
 | |
| // CHECK: sete %al
 | |
|     setz al
 | |
| // CHECK: setbe %al
 | |
|     setna al
 | |
| // CHECK: setae %al
 | |
|     setnb al
 | |
| // CHECK: setae %al
 | |
|     setnc al
 | |
| // CHECK: setle %al
 | |
|     setng al
 | |
| // CHECK: setge %al
 | |
|     setnl al
 | |
| // CHECK: setne %al
 | |
|     setnz al
 | |
| // CHECK: setp %al
 | |
|     setpe al
 | |
| // CHECK: setnp %al
 | |
|     setpo al
 | |
| // CHECK: setb %al
 | |
|     setnae al
 | |
| // CHECK: seta %al
 | |
|     setnbe al
 | |
| // CHECK: setl %al
 | |
|     setnge al
 | |
| // CHECK: setg %al
 | |
|     setnle al
 | |
| // CHECK: jne _foo
 | |
|     jnz _foo
 | |
| // CHECK: outb %al, $4
 | |
|     out 4, al
 | |
|     ret
 | |
| 
 | |
| // CHECK: cmovbl %ebx, %eax
 | |
|     cmovc eax, ebx
 | |
| // CHECK: cmovel %ebx, %eax
 | |
|     cmovz eax, ebx
 | |
| // CHECK: cmovbel %ebx, %eax
 | |
|     cmovna eax, ebx
 | |
| // CHECK: cmovael %ebx, %eax
 | |
|     cmovnb eax, ebx
 | |
| // CHECK: cmovael %ebx, %eax
 | |
|     cmovnc eax, ebx
 | |
| // CHECK: cmovlel %ebx, %eax
 | |
|     cmovng eax, ebx
 | |
| // CHECK: cmovgel %ebx, %eax
 | |
|     cmovnl eax, ebx
 | |
| // CHECK: cmovnel %ebx, %eax
 | |
|     cmovnz eax, ebx
 | |
| // CHECK: cmovpl %ebx, %eax
 | |
|     cmovpe eax, ebx
 | |
| // CHECK: cmovnpl %ebx, %eax
 | |
|     cmovpo eax, ebx
 | |
| // CHECK: cmovbl %ebx, %eax
 | |
|     cmovnae eax, ebx
 | |
| // CHECK: cmoval %ebx, %eax
 | |
|     cmovnbe eax, ebx
 | |
| // CHECK: cmovll %ebx, %eax
 | |
|     cmovnge eax, ebx
 | |
| // CHECK: cmovgl %ebx, %eax
 | |
|     cmovnle eax, ebx
 | |
| 
 | |
| // CHECK: shldw	%cl, %bx, %dx
 | |
| // CHECK: shldw	%cl, %bx, %dx
 | |
| // CHECK: shldw	$1, %bx, %dx
 | |
| // CHECK: shldw	%cl, %bx, (%rax)
 | |
| // CHECK: shldw	%cl, %bx, (%rax)
 | |
| // CHECK: shrdw	%cl, %bx, %dx
 | |
| // CHECK: shrdw	%cl, %bx, %dx
 | |
| // CHECK: shrdw	$1, %bx, %dx
 | |
| // CHECK: shrdw	%cl, %bx, (%rax)
 | |
| // CHECK: shrdw	%cl, %bx, (%rax)
 | |
| 
 | |
| shld  DX, BX
 | |
| shld  DX, BX, CL
 | |
| shld  DX, BX, 1
 | |
| shld  [RAX], BX
 | |
| shld  [RAX], BX, CL
 | |
| shrd  DX, BX
 | |
| shrd  DX, BX, CL
 | |
| shrd  DX, BX, 1
 | |
| shrd  [RAX], BX
 | |
| shrd  [RAX], BX, CL
 | |
| 
 | |
| // CHECK: btl $1, (%eax)
 | |
| // CHECK: btsl $1, (%eax)
 | |
| // CHECK: btrl $1, (%eax)
 | |
| // CHECK: btcl $1, (%eax)
 | |
|     bt DWORD PTR [EAX], 1
 | |
|     bt DWORD PTR [EAX], 1
 | |
|     bts DWORD PTR [EAX], 1
 | |
|     btr DWORD PTR [EAX], 1
 | |
|     btc DWORD PTR [EAX], 1
 | |
| 
 | |
| //CHECK: divb	%bl
 | |
| //CHECK: divw	%bx
 | |
| //CHECK: divl	%ecx
 | |
| //CHECK: divl	3735928559(%ebx,%ecx,8)
 | |
| //CHECK: divl	69
 | |
| //CHECK: divl	32493
 | |
| //CHECK: divl	3133065982
 | |
| //CHECK: divl	305419896
 | |
| //CHECK: idivb	%bl
 | |
| //CHECK: idivw	%bx
 | |
| //CHECK: idivl	%ecx
 | |
| //CHECK: idivl	3735928559(%ebx,%ecx,8)
 | |
| //CHECK: idivl	69
 | |
| //CHECK: idivl	32493
 | |
| //CHECK: idivl	3133065982
 | |
| //CHECK: idivl	305419896
 | |
|     div AL, BL
 | |
|     div AX, BX
 | |
|     div EAX, ECX
 | |
|     div EAX, [ECX*8+EBX+0xdeadbeef]
 | |
|     div EAX, [0x45]
 | |
|     div EAX, [0x7eed]
 | |
|     div EAX, [0xbabecafe]
 | |
|     div EAX, [0x12345678]
 | |
|     idiv AL, BL
 | |
|     idiv AX, BX
 | |
|     idiv EAX, ECX
 | |
|     idiv EAX, [ECX*8+EBX+0xdeadbeef]
 | |
|     idiv EAX, [0x45]
 | |
|     idiv EAX, [0x7eed]
 | |
|     idiv EAX, [0xbabecafe]
 | |
|     idiv EAX, [0x12345678]
 | |
| 
 | |
| 
 | |
| // CHECK: inb %dx, %al
 | |
| // CHECK: inw %dx, %ax
 | |
| // CHECK: inl %dx, %eax
 | |
| // CHECK: outb %al, %dx
 | |
| // CHECK: outw %ax, %dx
 | |
| // CHECK: outl %eax, %dx
 | |
|     inb DX
 | |
|     inw DX
 | |
|     inl DX
 | |
|     outb DX
 | |
|     outw DX
 | |
|     outl DX
 | |
| 
 | |
| // CHECK: xchgq %rcx, %rax
 | |
| // CHECK: xchgq %rcx, %rax
 | |
| // CHECK: xchgl %ecx, %eax
 | |
| // CHECK: xchgl %ecx, %eax
 | |
| // CHECK: xchgw %cx, %ax
 | |
| // CHECK: xchgw %cx, %ax
 | |
| xchg RAX, RCX
 | |
| xchg RCX, RAX
 | |
| xchg EAX, ECX
 | |
| xchg ECX, EAX
 | |
| xchg AX, CX
 | |
| xchg CX, AX
 | |
| 
 | |
| // CHECK: xchgq %rax, (%ecx)
 | |
| // CHECK: xchgq %rax, (%ecx)
 | |
| // CHECK: xchgl %eax, (%ecx)
 | |
| // CHECK: xchgl %eax, (%ecx)
 | |
| // CHECK: xchgw %ax, (%ecx)
 | |
| // CHECK: xchgw %ax, (%ecx)
 | |
| xchg RAX, [ECX]
 | |
| xchg [ECX], RAX
 | |
| xchg EAX, [ECX]
 | |
| xchg [ECX], EAX
 | |
| xchg AX, [ECX]
 | |
| xchg [ECX], AX
 | |
| 
 | |
| // CHECK: testq %rax, (%ecx)
 | |
| // CHECK: testq %rax, (%ecx)
 | |
| // CHECK: testl %eax, (%ecx)
 | |
| // CHECK: testl %eax, (%ecx)
 | |
| // CHECK: testw %ax, (%ecx)
 | |
| // CHECK: testw %ax, (%ecx)
 | |
| // CHECK: testb %al, (%ecx)
 | |
| // CHECK: testb %al, (%ecx)
 | |
| test RAX, [ECX]
 | |
| test [ECX], RAX
 | |
| test EAX, [ECX]
 | |
| test [ECX], EAX
 | |
| test AX, [ECX]
 | |
| test [ECX], AX
 | |
| test AL, [ECX]
 | |
| test [ECX], AL
 | |
| 
 | |
| // CHECK: fnstsw %ax
 | |
| // CHECK: fnstsw %ax
 | |
| // CHECK: fnstsw (%eax)
 | |
| fnstsw
 | |
| fnstsw AX
 | |
| fnstsw WORD PTR [EAX]
 | |
| 
 | |
| // CHECK: faddp %st(1)
 | |
| // CHECK: fmulp %st(1)
 | |
| // CHECK: fsubrp %st(1)
 | |
| // CHECK: fsubp %st(1)
 | |
| // CHECK: fdivrp %st(1)
 | |
| // CHECK: fdivp %st(1)
 | |
| faddp ST(1), ST(0)
 | |
| fmulp ST(1), ST(0)
 | |
| fsubp ST(1), ST(0)
 | |
| fsubrp ST(1), ST(0)
 | |
| fdivp ST(1), ST(0)
 | |
| fdivrp ST(1), ST(0)
 | |
| 
 | |
| // CHECK: faddp %st(1)
 | |
| // CHECK: fmulp %st(1)
 | |
| // CHECK: fsubrp %st(1)
 | |
| // CHECK: fsubp %st(1)
 | |
| // CHECK: fdivrp %st(1)
 | |
| // CHECK: fdivp %st(1)
 | |
| faddp ST(0), ST(1)
 | |
| fmulp ST(0), ST(1)
 | |
| fsubp ST(0), ST(1)
 | |
| fsubrp ST(0), ST(1)
 | |
| fdivp ST(0), ST(1)
 | |
| fdivrp ST(0), ST(1)
 | |
| 
 | |
| // CHECK: faddp %st(1)
 | |
| // CHECK: fmulp %st(1)
 | |
| // CHECK: fsubrp %st(1)
 | |
| // CHECK: fsubp %st(1)
 | |
| // CHECK: fdivrp %st(1)
 | |
| // CHECK: fdivp %st(1)
 | |
| faddp ST(1)
 | |
| fmulp ST(1)
 | |
| fsubp ST(1)
 | |
| fsubrp ST(1)
 | |
| fdivp ST(1)
 | |
| fdivrp ST(1)
 | |
| 
 | |
| 
 | |
| // CHECK: faddp %st(1)
 | |
| // CHECK: fmulp %st(1)
 | |
| // CHECK: fsubrp %st(1)
 | |
| // CHECK: fsubp %st(1)
 | |
| // CHECK: fdivrp %st(1)
 | |
| // CHECK: fdivp %st(1)
 | |
| fadd 
 | |
| fmul
 | |
| fsub
 | |
| fsubr
 | |
| fdiv
 | |
| fdivr
 | |
| 
 | |
| // CHECK: faddp %st(1)
 | |
| // CHECK: fmulp %st(1)
 | |
| // CHECK: fsubrp %st(1)
 | |
| // CHECK: fsubp %st(1)
 | |
| // CHECK: fdivrp %st(1)
 | |
| // CHECK: fdivp %st(1)
 | |
| faddp
 | |
| fmulp
 | |
| fsubp
 | |
| fsubrp
 | |
| fdivp
 | |
| fdivrp
 | |
| 
 | |
| // CHECK: fadd %st(1)
 | |
| // CHECK: fmul %st(1)
 | |
| // CHECK: fsub %st(1)
 | |
| // CHECK: fsubr %st(1)
 | |
| // CHECK: fdiv %st(1)
 | |
| // CHECK: fdivr %st(1)
 | |
| fadd ST(0), ST(1)
 | |
| fmul ST(0), ST(1)
 | |
| fsub ST(0), ST(1)
 | |
| fsubr ST(0), ST(1)
 | |
| fdiv ST(0), ST(1)
 | |
| fdivr ST(0), ST(1)
 | |
| 
 | |
| // CHECK: fadd %st(0), %st(1)
 | |
| // CHECK: fmul %st(0), %st(1)
 | |
| // CHECK: fsubr %st(0), %st(1)
 | |
| // CHECK: fsub %st(0), %st(1)
 | |
| // CHECK: fdivr %st(0), %st(1)
 | |
| // CHECK: fdiv %st(0), %st(1)
 | |
| fadd ST(1), ST(0)
 | |
| fmul ST(1), ST(0)
 | |
| fsub ST(1), ST(0)
 | |
| fsubr ST(1), ST(0)
 | |
| fdiv ST(1), ST(0)
 | |
| fdivr ST(1), ST(0)
 | |
| 
 | |
| // CHECK: fadd %st(1)
 | |
| // CHECK: fmul %st(1)
 | |
| // CHECK: fsub %st(1)
 | |
| // CHECK: fsubr %st(1)
 | |
| // CHECK: fdiv %st(1)
 | |
| // CHECK: fdivr %st(1)
 | |
| fadd ST(1)
 | |
| fmul ST(1)
 | |
| fsub ST(1)
 | |
| fsubr ST(1)
 | |
| fdiv ST(1)
 | |
| fdivr ST(1)
 | |
| 
 | |
| 
 | |
| // CHECK: fxsave64 (%rax)
 | |
| // CHECK: fxrstor64 (%rax)
 | |
| fxsave64 [rax]
 | |
| fxrstor64 [rax]
 | |
| 
 | |
| .bss
 | |
| .globl _g0
 | |
| .text
 | |
| 
 | |
| // CHECK: movq _g0, %rbx
 | |
| // CHECK: movq _g0+8, %rcx
 | |
| // CHECK: movq _g0+18(%rbp), %rax
 | |
| // CHECK: movq _g0(,%rsi,4), %rax
 | |
| mov rbx, qword ptr [_g0]
 | |
| mov rcx, qword ptr [_g0 + 8]
 | |
| mov rax, QWORD PTR _g0[rbp + 1 + (2 * 5) - 3 + 1<<1]
 | |
| mov rax, QWORD PTR _g0[rsi*4]
 | |
| 
 | |
| "?half@?0??bar@@YAXXZ@4NA":
 | |
| 	.quad   4602678819172646912
 | |
| 
 | |
| fadd   dword ptr "?half@?0??bar@@YAXXZ@4NA"
 | |
| fadd   dword ptr "?half@?0??bar@@YAXXZ@4NA"@IMGREL
 | |
| // CHECK: fadds   "?half@?0??bar@@YAXXZ@4NA"
 | |
| // CHECK: fadds   "?half@?0??bar@@YAXXZ@4NA"@IMGREL
 | |
| 
 | |
| inc qword ptr [rax]
 | |
| inc long ptr [rax]
 | |
| inc dword ptr [rax]
 | |
| inc word ptr [rax]
 | |
| inc byte ptr [rax]
 | |
| // CHECK: incq (%rax)
 | |
| // CHECK: incl (%rax)
 | |
| // CHECK: incl (%rax)
 | |
| // CHECK: incw (%rax)
 | |
| // CHECK: incb (%rax)
 | |
| 
 | |
| dec qword ptr [rax]
 | |
| dec dword ptr [rax]
 | |
| dec word ptr [rax]
 | |
| dec byte ptr [rax]
 | |
| // CHECK: decq (%rax)
 | |
| // CHECK: decl (%rax)
 | |
| // CHECK: decw (%rax)
 | |
| // CHECK: decb (%rax)
 | |
| 
 | |
| add qword ptr [rax], 1
 | |
| add dword ptr [rax], 1
 | |
| add word ptr [rax], 1
 | |
| add byte ptr [rax], 1
 | |
| // CHECK: addq $1, (%rax)
 | |
| // CHECK: addl $1, (%rax)
 | |
| // CHECK: addw $1, (%rax)
 | |
| // CHECK: addb $1, (%rax)
 | |
| 
 | |
| fstp tbyte ptr [rax]
 | |
| fstp xword ptr [rax]
 | |
| fstp qword ptr [rax]
 | |
| fstp dword ptr [rax]
 | |
| // CHECK: fstpt (%rax)
 | |
| // CHECK: fstpt (%rax)
 | |
| // CHECK: fstpl (%rax)
 | |
| // CHECK: fstps (%rax)
 | |
| 
 | |
| fxsave [eax]
 | |
| fsave [eax]
 | |
| fxrstor [eax]
 | |
| frstor [eax]
 | |
| // CHECK: fxsave (%eax)
 | |
| // CHECK: wait
 | |
| // CHECK: fnsave (%eax)
 | |
| // CHECK: fxrstor (%eax)
 | |
| // CHECK: frstor (%eax)
 | |
| 
 | |
| // FIXME: Should we accept this?  Masm accepts it, but gas does not.
 | |
| fxsave dword ptr [eax]
 | |
| fsave dword ptr [eax]
 | |
| fxrstor dword ptr [eax]
 | |
| frstor dword ptr [eax]
 | |
| // CHECK: fxsave (%eax)
 | |
| // CHECK: wait
 | |
| // CHECK: fnsave (%eax)
 | |
| // CHECK: fxrstor (%eax)
 | |
| // CHECK: frstor (%eax)
 | |
| 
 | |
| // CHECK: cmpnless %xmm1, %xmm0
 | |
| cmpnless xmm0, xmm1
 | |
| 
 | |
| insb
 | |
| insw
 | |
| insd
 | |
| // CHECK: insb %dx, %es:(%rdi)
 | |
| // CHECK: insw %dx, %es:(%rdi)
 | |
| // CHECK: insl %dx, %es:(%rdi)
 | |
| 
 | |
| outsb
 | |
| outsw
 | |
| outsd
 | |
| // CHECK: outsb (%rsi), %dx
 | |
| // CHECK: outsw (%rsi), %dx
 | |
| // CHECK: outsl (%rsi), %dx
 | |
| 
 | |
| imul bx, 123
 | |
| imul ebx, 123
 | |
| imul rbx, 123
 | |
| // CHECK: imulw $123, %bx
 | |
| // CHECK: imull $123, %ebx
 | |
| // CHECK: imulq $123, %rbx
 | |
| 
 | |
| repe cmpsb
 | |
| repz cmpsb
 | |
| repne cmpsb
 | |
| repnz cmpsb
 | |
| // CHECK: rep
 | |
| // CHECK: cmpsb	%es:(%rdi), (%rsi)
 | |
| // CHECK: rep
 | |
| // CHECK: cmpsb	%es:(%rdi), (%rsi)
 | |
| // CHECK: repne
 | |
| // CHECK: cmpsb	%es:(%rdi), (%rsi)
 | |
| // CHECK: repne
 | |
| // CHECK: cmpsb	%es:(%rdi), (%rsi)
 | |
| 
 | |
| sal eax, 123
 | |
| // CHECK: shll	$123, %eax
 | |
| 
 | |
| psignw    mm0, MMWORD PTR t2
 | |
| // CHECK: psignw t2, %mm0
 | |
| 
 | |
| comisd xmm0, QWORD PTR [eax]
 | |
| comiss xmm0, DWORD PTR [eax]
 | |
| vcomisd xmm0, QWORD PTR [eax]
 | |
| vcomiss xmm0, DWORD PTR [eax]
 | |
| 
 | |
| // CHECK: comisd (%eax), %xmm0
 | |
| // CHECK: comiss (%eax), %xmm0
 | |
| // CHECK: vcomisd (%eax), %xmm0
 | |
| // CHECK: vcomiss (%eax), %xmm0
 | |
| 
 | |
| fbld tbyte ptr [eax]
 | |
| fbstp tbyte ptr [eax]
 | |
| // CHECK: fbld (%eax)
 | |
| // CHECK: fbstp (%eax)
 | |
| 
 | |
| fld float ptr [rax]
 | |
| fld double ptr [rax]
 | |
| // CHECK: flds (%rax)
 | |
| // CHECK: fldl (%rax)
 | |
| 
 | |
| fcomip st, st(2)
 | |
| fucomip st, st(2)
 | |
| // CHECK: fcompi  %st(2)
 | |
| // CHECK: fucompi  %st(2)
 | |
| 
 | |
| loopz _foo
 | |
| loopnz _foo
 | |
| // CHECK: loope _foo
 | |
| // CHECK: loopne _foo
 | |
| 
 | |
| sidt fword ptr [eax]
 | |
| // CHECK: sidtq (%eax)
 | |
| 
 | |
| ins byte ptr [eax], dx
 | |
| // CHECK: insb %dx, %es:(%edi)
 | |
| // CHECK-STDERR: memory operand is only for determining the size, ES:(R|E)DI will be used for the location
 | |
| // CHECK-STDERR-NEXT: ins byte ptr [eax], dx
 | |
| outs dx, word ptr [eax]
 | |
| // CHECK: outsw (%esi), %dx
 | |
| // CHECK-STDERR: memory operand is only for determining the size, ES:(R|E)SI will be used for the location
 | |
| // CHECK-STDERR-NEXT: outs dx, word ptr [eax]
 | |
| lods dword ptr [eax]
 | |
| // CHECK: lodsl (%esi), %eax
 | |
| // CHECK-STDERR: memory operand is only for determining the size, ES:(R|E)SI will be used for the location
 | |
| // CHECK-STDERR-NEXT: lods dword ptr [eax]
 | |
| stos qword ptr [eax]
 | |
| // CHECK: stosq %rax, %es:(%edi)
 | |
| // CHECK-STDERR: memory operand is only for determining the size, ES:(R|E)DI will be used for the location
 | |
| // CHECK-STDERR-NEXT: stos qword ptr [eax]
 | |
| scas byte ptr [eax]
 | |
| // CHECK: scasb %es:(%edi), %al
 | |
| // CHECK-STDERR: memory operand is only for determining the size, ES:(R|E)DI will be used for the location
 | |
| // CHECK-STDERR-NEXT: scas byte ptr [eax]
 | |
| cmps word ptr [eax], word ptr [ebx]
 | |
| // CHECK: cmpsw %es:(%edi), (%esi)
 | |
| // CHECK-STDERR: memory operand is only for determining the size, ES:(R|E)SI will be used for the location
 | |
| // CHECK-STDERR-NEXT: cmps word ptr [eax], word ptr [ebx]
 | |
| // CHECK-STDERR: memory operand is only for determining the size, ES:(R|E)DI will be used for the location
 | |
| // CHECK-STDERR-NEXT: cmps word ptr [eax], word ptr [ebx]
 | |
| movs dword ptr [eax], dword ptr [ebx]
 | |
| // CHECK: movsl (%esi), %es:(%edi)
 | |
| // CHECK-STDERR: memory operand is only for determining the size, ES:(R|E)DI will be used for the location
 | |
| // CHECK-STDERR-NEXT: movs dword ptr [eax], dword ptr [ebx]
 | |
| // CHECK-STDERR: memory operand is only for determining the size, ES:(R|E)SI will be used for the location
 | |
| // CHECK-STDERR-NEXT: movs dword ptr [eax], dword ptr [ebx]
 | |
| 
 | |
| movsd  qword ptr [rax], xmm0
 | |
| // CHECK: movsd %xmm0, (%rax)
 | |
| // CHECK-STDERR-NOT: movsd qword ptr [rax], xmm0
 | |
| 
 | |
| xlat byte ptr [eax]
 | |
| // CHECK: xlatb
 | |
| // CHECK-STDERR: memory operand is only for determining the size, (R|E)BX will be used for the location
 | |
| 
 | |
| // CHECK:   punpcklbw
 | |
| punpcklbw mm0, dword ptr [rsp]
 | |
| // CHECK:   punpcklwd
 | |
| punpcklwd mm0, dword ptr [rsp]
 | |
| // CHECK:   punpckldq
 | |
| punpckldq mm0, dword ptr [rsp]
 | |
| 
 | |
| // CHECK: lslq (%eax), %rbx
 | |
| lsl rbx, word ptr [eax]
 | |
| 
 | |
| // CHECK: lsll (%eax), %ebx
 | |
| lsl ebx, word ptr [eax]
 | |
| 
 | |
| // CHECK: lslw (%eax), %bx
 | |
| lsl bx, word ptr [eax]
 | |
| 
 | |
| // CHECK: sysexitl
 | |
| sysexit
 | |
| // CHECK: sysexitq
 | |
| sysexitq
 | |
| // CHECK: sysretl
 | |
| sysret
 | |
| // CHECK: sysretq
 | |
| sysretq
 | |
| 
 | |
| // CHECK: leaq (%rsp,%rax), %rax
 | |
| lea rax, [rax+rsp]
 | |
| // CHECK: leaq (%rsp,%rax), %rax
 | |
| lea rax, [rsp+rax]
 | |
| // CHECK: leal (%esp,%eax), %eax
 | |
| lea eax, [eax+esp]
 | |
| // CHECK: leal (%esp,%eax), %eax
 | |
| lea eax, [esp+eax]
 | |
| 
 | |
| // CHECK: vpgatherdq      %ymm2, (%rdi,%xmm1), %ymm0
 | |
| vpgatherdq ymm0, [rdi+xmm1], ymm2
 | |
| // CHECK: vpgatherdq      %ymm2, (%rdi,%xmm1), %ymm0
 | |
| vpgatherdq ymm0, [xmm1+rdi], ymm2
 |