mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
3f22cc1df6
The binutils assembler supports a mode called DOLLAR_DOT which treats the dollar sign token as a reference to the current program counter if the dollar sign doesn't precede a constant or identifier. This commit adds a new MCAsmInfo flag stating whether or not a given target supports this interpretation of the dollar sign token; by default, this flag is not enabled. Further, enable this flag for PPC. The system assembler for AIX and binutils both support using the dollar sign in this manner. This fixes PR17353. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@191368 91177308-0d34-0410-b5e6-96231b3b80d8
116 lines
3.5 KiB
ArmAsm
116 lines
3.5 KiB
ArmAsm
|
|
# RUN: llvm-mc -triple powerpc64-unknown-unknown --show-encoding %s | FileCheck %s
|
|
|
|
# Register operands
|
|
|
|
# CHECK: add 1, 2, 3 # encoding: [0x7c,0x22,0x1a,0x14]
|
|
add 1, 2, 3
|
|
|
|
# CHECK: add 1, 2, 3 # encoding: [0x7c,0x22,0x1a,0x14]
|
|
add %r1, %r2, %r3
|
|
|
|
# CHECK: add 0, 0, 0 # encoding: [0x7c,0x00,0x02,0x14]
|
|
add 0, 0, 0
|
|
|
|
# CHECK: add 31, 31, 31 # encoding: [0x7f,0xff,0xfa,0x14]
|
|
add 31, 31, 31
|
|
|
|
# CHECK: addi 1, 0, 0 # encoding: [0x38,0x20,0x00,0x00]
|
|
addi 1, 0, 0
|
|
|
|
# CHECK: addi 1, 0, 0 # encoding: [0x38,0x20,0x00,0x00]
|
|
addi 1, %r0, 0
|
|
|
|
# Signed 16-bit immediate operands
|
|
|
|
# CHECK: addi 1, 2, 0 # encoding: [0x38,0x22,0x00,0x00]
|
|
addi 1, 2, 0
|
|
|
|
# CHECK: addi 1, 0, -32768 # encoding: [0x38,0x20,0x80,0x00]
|
|
addi 1, 0, -32768
|
|
|
|
# CHECK: addi 1, 0, 32767 # encoding: [0x38,0x20,0x7f,0xff]
|
|
addi 1, 0, 32767
|
|
|
|
# Unsigned 16-bit immediate operands
|
|
|
|
# CHECK: ori 1, 2, 0 # encoding: [0x60,0x41,0x00,0x00]
|
|
ori 1, 2, 0
|
|
|
|
# CHECK: ori 1, 2, 65535 # encoding: [0x60,0x41,0xff,0xff]
|
|
ori 1, 2, 65535
|
|
|
|
# Signed 16-bit immediate operands (extended range for addis)
|
|
|
|
# CHECK: addis 1, 0, 0 # encoding: [0x3c,0x20,0x00,0x00]
|
|
addis 1, 0, -65536
|
|
|
|
# CHECK: addis 1, 0, -1 # encoding: [0x3c,0x20,0xff,0xff]
|
|
addis 1, 0, 65535
|
|
|
|
# D-Form memory operands
|
|
|
|
# CHECK: lwz 1, 0(0) # encoding: [0x80,0x20,0x00,0x00]
|
|
lwz 1, 0(0)
|
|
|
|
# CHECK: lwz 1, 0(0) # encoding: [0x80,0x20,0x00,0x00]
|
|
lwz 1, 0(%r0)
|
|
|
|
# CHECK: lwz 1, 0(31) # encoding: [0x80,0x3f,0x00,0x00]
|
|
lwz 1, 0(31)
|
|
|
|
# CHECK: lwz 1, 0(31) # encoding: [0x80,0x3f,0x00,0x00]
|
|
lwz 1, 0(%r31)
|
|
|
|
# CHECK: lwz 1, -32768(2) # encoding: [0x80,0x22,0x80,0x00]
|
|
lwz 1, -32768(2)
|
|
|
|
# CHECK: lwz 1, 32767(2) # encoding: [0x80,0x22,0x7f,0xff]
|
|
lwz 1, 32767(2)
|
|
|
|
|
|
# CHECK: ld 1, 0(0) # encoding: [0xe8,0x20,0x00,0x00]
|
|
ld 1, 0(0)
|
|
|
|
# CHECK: ld 1, 0(0) # encoding: [0xe8,0x20,0x00,0x00]
|
|
ld 1, 0(%r0)
|
|
|
|
# CHECK: ld 1, 0(31) # encoding: [0xe8,0x3f,0x00,0x00]
|
|
ld 1, 0(31)
|
|
|
|
# CHECK: ld 1, 0(31) # encoding: [0xe8,0x3f,0x00,0x00]
|
|
ld 1, 0(%r31)
|
|
|
|
# CHECK: ld 1, -32768(2) # encoding: [0xe8,0x22,0x80,0x00]
|
|
ld 1, -32768(2)
|
|
|
|
# CHECK: ld 1, 32764(2) # encoding: [0xe8,0x22,0x7f,0xfc]
|
|
ld 1, 32764(2)
|
|
|
|
# CHECK: ld 1, 4(2) # encoding: [0xe8,0x22,0x00,0x04]
|
|
ld 1, 4(2)
|
|
|
|
# CHECK: ld 1, -4(2) # encoding: [0xe8,0x22,0xff,0xfc]
|
|
ld 1, -4(2)
|
|
|
|
|
|
# Immediate branch operands
|
|
|
|
# CHECK: b .+1024 # encoding: [0x48,0x00,0x04,0x00]
|
|
b 1024
|
|
|
|
# CHECK: ba 1024 # encoding: [0x48,0x00,0x04,0x02]
|
|
ba 1024
|
|
|
|
# CHECK: beq 0, .+1024 # encoding: [0x41,0x82,0x04,0x00]
|
|
beq 1024
|
|
|
|
# CHECK: beqa 0, 1024 # encoding: [0x41,0x82,0x04,0x02]
|
|
beqa 1024
|
|
|
|
# CHECK: # encoding: [0x42,0x9f,A,0bAAAAAA01]
|
|
bcl 20, 31, $+4
|
|
|
|
# CHECK: # encoding: [0x42,0x00,A,0bAAAAAA00]
|
|
bdnz $-8
|