mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-10 13:51:37 +00:00
d56655b31e
The implementation follows the MIPS backend and expands the pseudo instruction directly during asm parsing. As the result, only real MC instructions are emitted to the MCStreamer. The actual expansion to real instructions is similar to the expansion performed by the GNU Assembler. This patch supersedes D41949. Differential Revision: https://reviews.llvm.org/D46118 Patch by Mario Werner. llvm-svn: 334203
81 lines
2.3 KiB
ArmAsm
81 lines
2.3 KiB
ArmAsm
# RUN: llvm-mc %s -triple=riscv32 -riscv-no-aliases \
|
|
# RUN: | FileCheck -check-prefixes=CHECK-EXPAND,CHECK-INST %s
|
|
# RUN: llvm-mc %s -triple=riscv32 \
|
|
# RUN: | FileCheck -check-prefixes=CHECK-EXPAND,CHECK-ALIAS %s
|
|
# RUN: llvm-mc -filetype=obj -triple riscv32 < %s \
|
|
# RUN: | llvm-objdump -riscv-no-aliases -d - \
|
|
# RUN: | FileCheck -check-prefixes=CHECK-EXPAND,CHECK-INST %s
|
|
# RUN: llvm-mc -filetype=obj -triple riscv32 < %s \
|
|
# RUN: | llvm-objdump -d - \
|
|
# RUN: | FileCheck -check-prefixes=CHECK-EXPAND,CHECK-ALIAS %s
|
|
|
|
# The following check prefixes are used in this test:
|
|
# CHECK-INST.....Match the canonical instr (tests alias to instr. mapping)
|
|
# CHECK-ALIAS....Match the alias (tests instr. to alias mapping)
|
|
# CHECK-EXPAND...Match canonical instr. unconditionally (tests alias expansion)
|
|
|
|
|
|
# CHECK-INST: addi a0, zero, 0
|
|
# CHECK-ALIAS: mv a0, zero
|
|
li x10, 0
|
|
# CHECK-EXPAND: addi a0, zero, 1
|
|
li x10, 1
|
|
# CHECK-EXPAND: addi a0, zero, -1
|
|
li x10, -1
|
|
# CHECK-EXPAND: addi a0, zero, 2047
|
|
li x10, 2047
|
|
# CHECK-EXPAND: addi a0, zero, -2047
|
|
li x10, -2047
|
|
# CHECK-EXPAND: lui a1, 1
|
|
# CHECK-EXPAND: addi a1, a1, -2048
|
|
li x11, 2048
|
|
# CHECK-EXPAND: addi a1, zero, -2048
|
|
li x11, -2048
|
|
# CHECK-EXPAND: lui a1, 1
|
|
# CHECK-EXPAND: addi a1, a1, -2047
|
|
li x11, 2049
|
|
# CHECK-EXPAND: lui a1, 1048575
|
|
# CHECK-EXPAND: addi a1, a1, 2047
|
|
li x11, -2049
|
|
# CHECK-EXPAND: lui a1, 1
|
|
# CHECK-EXPAND: addi a1, a1, -1
|
|
li x11, 4095
|
|
# CHECK-EXPAND: lui a1, 1048575
|
|
# CHECK-EXPAND: addi a1, a1, 1
|
|
li x11, -4095
|
|
# CHECK-EXPAND: lui a2, 1
|
|
li x12, 4096
|
|
# CHECK-EXPAND: lui a2, 1048575
|
|
li x12, -4096
|
|
# CHECK-EXPAND: lui a2, 1
|
|
# CHECK-EXPAND: addi a2, a2, 1
|
|
li x12, 4097
|
|
# CHECK-EXPAND: lui a2, 1048575
|
|
# CHECK-EXPAND: addi a2, a2, -1
|
|
li x12, -4097
|
|
# CHECK-EXPAND: lui a2, 524288
|
|
# CHECK-EXPAND: addi a2, a2, -1
|
|
li x12, 2147483647
|
|
# CHECK-EXPAND: lui a2, 524288
|
|
# CHECK-EXPAND: addi a2, a2, 1
|
|
li x12, -2147483647
|
|
# CHECK-EXPAND: lui a2, 524288
|
|
li x12, -2147483648
|
|
# CHECK-EXPAND: lui a2, 524288
|
|
li x12, -0x80000000
|
|
|
|
# CHECK-EXPAND: lui a2, 524288
|
|
li x12, 0x80000000
|
|
# CHECK-EXPAND: addi a2, zero, -1
|
|
li x12, 0xFFFFFFFF
|
|
|
|
# CHECK-INST: csrrs t4, 3202, zero
|
|
# CHECK-ALIAS: rdinstreth t4
|
|
rdinstreth x29
|
|
# CHECK-INST: csrrs s11, 3200, zero
|
|
# CHECK-ALIAS: rdcycleh s11
|
|
rdcycleh x27
|
|
# CHECK-INST: csrrs t3, 3201, zero
|
|
# CHECK-ALIAS: rdtimeh t3
|
|
rdtimeh x28
|