llvm-6502/test/MC/AsmParser/X86/x86_operands.s
Chris Lattner 1eb1b68e3a Fix an inconsistency in the x86 backend that led it to reject "calll foo" on
x86-32: 32-bit calls were named "call" not "calll".  64-bit calls were correctly
named "callq", so this only impacted x86-32.

This fixes rdar://8456370 - llvm-mc rejects 'calll'

This also exposes that mingw/64 is generating a 32-bit call instead of a 64-bit call,
I will file a bugzilla.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@114534 91177308-0d34-0410-b5e6-96231b3b80d8
2010-09-22 05:49:14 +00:00

59 lines
1.3 KiB
ArmAsm

// RUN: llvm-mc -triple i386-unknown-unknown %s | FileCheck %s
# Immediates
# CHECK: addl $1, %eax
addl $1, %eax
# CHECK: addl $3, %eax
addl $(1+2), %eax
# CHECK: addl $a, %eax
addl $a, %eax
# CHECK: addl $3, %eax
addl $1 + 2, %eax
# Disambiguation
# CHECK: addl $1, 8
addl $1, 4+4
# CHECK: addl $1, 8
addl $1, (4+4)
# CHECK: addl $1, 8(%eax)
addl $1, 4+4(%eax)
# CHECK: addl $1, 8(%eax)
addl $1, (4+4)(%eax)
# CHECK: addl $1, 8(%eax)
addl $1, 8(%eax)
# CHECK: addl $1, (%eax)
addl $1, (%eax)
# CHECK: addl $1, 8(,%eax)
addl $1, (4+4)(,%eax)
# Indirect Memory Operands
# CHECK: addl $1, 1(%eax)
addl $1, 1(%eax)
# CHECK: addl $1, 1(%eax,%ebx)
addl $1, 1(%eax,%ebx)
# CHECK: addl $1, 1(%eax,%ebx)
addl $1, 1(%eax,%ebx,)
# CHECK: addl $1, 1(%eax,%ebx,4)
addl $1, 1(%eax,%ebx,4)
# CHECK: addl $1, 1(,%ebx)
addl $1, 1(,%ebx)
# CHECK: addl $1, 1(,%ebx)
addl $1, 1(,%ebx,)
# CHECK: addl $1, 1(,%ebx,4)
addl $1, 1(,%ebx,4)
# CHECK: addl $1, 1(,%ebx,4)
addl $1, 1(,%ebx,(2+2))
# '*'
# CHECK: calll a
call a
# CHECK: calll *%eax
call *%eax
# CHECK: calll *4(%eax)
call *4(%eax)
# CHECK: movl %gs:8, %eax
movl %gs:8, %eax