|  | // 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 |