mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-10 22:00:58 +00:00
515efbb17e
For RISCV branch instructions, we need to preserve relocation types when linker relaxation enabled, so then linker could modify offset when the branch offsets changed. We preserve relocation types by define shouldForceRelocation. IsResolved return by evaluateFixup will always false when shouldForceRelocation return true. It will make RISCV MC Branch Relaxation always relax 16-bit branches to 32-bit form, even if the symbol actually could be resolved. To avoid 16-bit branches always relax to 32-bit form when linker relaxation enabled, we add a new parameter WasForced to indicate that the symbol actually couldn't be resolved and not forced by shouldForceRelocation return true. RISCVAsmBackend::fixupNeedsRelaxationAdvanced could relax branches with unresolved symbols by (!IsResolved && !WasForced). RISCV MC Branch Relaxation is needed because RISCV could perform 32-bit to 16-bit transformation in MC layer. Differential Revision: https://reviews.llvm.org/D46350 llvm-svn: 332696
128 lines
3.2 KiB
ArmAsm
128 lines
3.2 KiB
ArmAsm
# RUN: llvm-mc -filetype=obj -triple riscv32 -mattr=+c < %s \
|
|
# RUN: | llvm-objdump -d -riscv-no-aliases - | FileCheck -check-prefix=INSTR %s
|
|
# RUN: llvm-mc -filetype=obj -triple riscv32 -mattr=+c,+relax < %s \
|
|
# RUN: | llvm-objdump -d -riscv-no-aliases - | FileCheck -check-prefix=RELAX-INSTR %s
|
|
# RUN: llvm-mc -filetype=obj -triple riscv32 -mattr=+c,+relax < %s \
|
|
# RUN: | llvm-readobj -r | FileCheck -check-prefix=RELAX-RELOC %s
|
|
|
|
FAR_JUMP_NEGATIVE:
|
|
c.nop
|
|
.space 2000
|
|
|
|
FAR_BRANCH_NEGATIVE:
|
|
c.nop
|
|
.space 256
|
|
|
|
NEAR_NEGATIVE:
|
|
c.nop
|
|
|
|
start:
|
|
c.bnez a0, NEAR
|
|
#INSTR: c.bnez a0, 72
|
|
#RELAX-INSTR: c.bnez a0, 0
|
|
#RELAX-RELOC: R_RISCV_RVC_BRANCH
|
|
c.bnez a0, NEAR_NEGATIVE
|
|
#INSTR: c.bnez a0, -4
|
|
#RELAX-INSTR: c.bnez a0, 0
|
|
#RELAX-RELOC: R_RISCV_RVC_BRANCH
|
|
c.bnez a0, FAR_BRANCH
|
|
#INSTR-NEXT: bne a0, zero, 326
|
|
#RELAX-INSTR-NEXT: bne a0, zero, 0
|
|
#RELAX-RELOC: R_RISCV_BRANCH
|
|
c.bnez a0, FAR_BRANCH_NEGATIVE
|
|
#INSTR-NEXT: bne a0, zero, -268
|
|
#RELAX-INSTR-NEXT: bne a0, zero, 0
|
|
#RELAX-RELOC: R_RISCV_BRANCH
|
|
c.bnez a0, FAR_JUMP
|
|
#INSTR-NEXT: bne a0, zero, 2320
|
|
#RELAX-INSTR-NEXT: bne a0, zero, 0
|
|
#RELAX-RELOC: R_RISCV_BRANCH
|
|
c.bnez a0, FAR_JUMP_NEGATIVE
|
|
#INSTR-NEXT: bne a0, zero, -2278
|
|
#RELAX-INSTR-NEXT: bne a0, zero, 0
|
|
#RELAX-RELOC: R_RISCV_BRANCH
|
|
|
|
c.beqz a0, NEAR
|
|
#INSTR-NEXT: c.beqz a0, 52
|
|
#RELAX-INSTR-NEXT: c.beqz a0, 0
|
|
#RELAX-RELOC: R_RISCV_RVC_BRANCH
|
|
c.beqz a0, NEAR_NEGATIVE
|
|
#INSTR-NEXT: c.beqz a0, -24
|
|
#RELAX-INSTR-NEXT: c.beqz a0, 0
|
|
#RELAX-RELOC: R_RISCV_RVC_BRANCH
|
|
c.beqz a0, FAR_BRANCH
|
|
#INSTR-NEXT: beq a0, zero, 306
|
|
#RELAX-INSTR-NEXT: beq a0, zero, 0
|
|
#RELAX-RELOC: R_RISCV_BRANCH
|
|
c.beqz a0, FAR_BRANCH_NEGATIVE
|
|
#INSTR-NEXT: beq a0, zero, -288
|
|
#RELAX-INSTR-NEXT: beq a0, zero, 0
|
|
#RELAX-RELOC: R_RISCV_BRANCH
|
|
c.beqz a0, FAR_JUMP
|
|
#INSTR-NEXT: beq a0, zero, 2300
|
|
#RELAX-INSTR-NEXT: beq a0, zero, 0
|
|
#RELAX-RELOC: R_RISCV_BRANCH
|
|
c.beqz a0, FAR_JUMP_NEGATIVE
|
|
#INSTR-NEXT: beq a0, zero, -2298
|
|
#RELAX-INSTR-NEXT: beq a0, zero, 0
|
|
#RELAX-RELOC: R_RISCV_BRANCH
|
|
|
|
c.j NEAR
|
|
#INSTR-NEXT: c.j 32
|
|
#RELAX-INSTR-NEXT: c.j 0
|
|
#RELAX-RELOC: R_RISCV_RVC_JUMP
|
|
c.j NEAR_NEGATIVE
|
|
#INSTR-NEXT: c.j -44
|
|
#RELAX-INSTR-NEXT: c.j 0
|
|
#RELAX-RELOC: R_RISCV_RVC_JUMP
|
|
c.j FAR_BRANCH
|
|
#INSTR-NEXT: c.j 286
|
|
#RELAX-INSTR-NEXT: c.j 0
|
|
#RELAX-RELOC: R_RISCV_RVC_JUMP
|
|
c.j FAR_BRANCH_NEGATIVE
|
|
#INSTR-NEXT: c.j -306
|
|
#RELAX-INSTR-NEXT: c.j 0
|
|
#RELAX-RELOC: R_RISCV_RVC_JUMP
|
|
c.j FAR_JUMP
|
|
#INSTR-NEXT: jal zero, 2284
|
|
#RELAX-INSTR-NEXT: jal zero, 0
|
|
#RELAX-RELOC: R_RISCV_JAL
|
|
c.j FAR_JUMP_NEGATIVE
|
|
#INSTR-NEXT: jal zero, -2314
|
|
#RELAX-INSTR-NEXT: jal zero, 0
|
|
#RELAX-RELOC: R_RISCV_JAL
|
|
|
|
c.jal NEAR
|
|
#INSTR: c.jal 16
|
|
#RELAX-INSTR: c.jal 0
|
|
#RELAX-RELOC: R_RISCV_RVC_JUMP
|
|
c.jal NEAR_NEGATIVE
|
|
#INSTR: c.jal -60
|
|
#RELAX-INSTR: c.jal 0
|
|
#RELAX-RELOC: R_RISCV_RVC_JUMP
|
|
c.jal FAR_BRANCH
|
|
#INSTR-NEXT: c.jal 270
|
|
#RELAX-INSTR-NEXT: c.jal 0
|
|
#RELAX-RELOC: R_RISCV_RVC_JUMP
|
|
c.jal FAR_BRANCH_NEGATIVE
|
|
#INSTR-NEXT: c.jal -322
|
|
#RELAX-INSTR-NEXT: c.jal 0
|
|
#RELAX-RELOC: R_RISCV_RVC_JUMP
|
|
c.jal FAR_JUMP
|
|
#INSTR-NEXT: jal ra, 2268
|
|
#RELAX-INSTR-NEXT: jal ra, 0
|
|
#RELAX-RELOC: R_RISCV_JAL
|
|
c.jal FAR_JUMP_NEGATIVE
|
|
#INSTR-NEXT: jal ra, -2330
|
|
#RELAX-INSTR-NEXT: jal ra, 0
|
|
#RELAX-RELOC: R_RISCV_JAL
|
|
|
|
NEAR:
|
|
c.nop
|
|
.space 256
|
|
FAR_BRANCH:
|
|
c.nop
|
|
.space 2000
|
|
FAR_JUMP:
|
|
c.nop
|