70 lines
2.3 KiB
ArmAsm
70 lines
2.3 KiB
ArmAsm
|
# REQUIRES: riscv
|
||
|
## Test that we can handle --emit-relocs while relaxing.
|
||
|
|
||
|
# RUN: rm -rf %t && mkdir %t && cd %t
|
||
|
|
||
|
# RUN: llvm-mc -filetype=obj -triple=riscv32 -mattr=+relax %s -o 32.o
|
||
|
# RUN: ld.lld -Ttext=0x10000 --emit-relocs 32.o -o 32
|
||
|
# RUN: llvm-objdump -dr --no-show-raw-insn -M no-aliases 32 | FileCheck %s
|
||
|
|
||
|
# RUN: llvm-mc -filetype=obj -triple=riscv64 -mattr=+relax %s -o 64.o
|
||
|
# RUN: ld.lld -Ttext=0x10000 --emit-relocs 64.o -o 64
|
||
|
# RUN: llvm-objdump -dr --no-show-raw-insn -M no-aliases 64 | FileCheck %s
|
||
|
|
||
|
## -r should keep original relocations.
|
||
|
# RUN: ld.lld -r 64.o -o 64.r
|
||
|
# RUN: llvm-objdump -dr --no-show-raw-insn -M no-aliases 64.r | FileCheck %s --check-prefix=CHECKR
|
||
|
|
||
|
## --no-relax should keep original relocations.
|
||
|
# RUN: ld.lld --emit-relocs --no-relax 64.o -o 64.norelax
|
||
|
# RUN: llvm-objdump -dr --no-show-raw-insn -M no-aliases 64.norelax | FileCheck %s --check-prefix=CHECKNORELAX
|
||
|
|
||
|
# CHECK: <_start>:
|
||
|
# CHECK-NEXT: jal ra, 0x10008 <f>
|
||
|
# CHECK-NEXT: R_RISCV_JAL f
|
||
|
# CHECK-NEXT: R_RISCV_RELAX *ABS*
|
||
|
# CHECK-NEXT: jal ra, 0x10008 <f>
|
||
|
# CHECK-NEXT: R_RISCV_JAL f
|
||
|
# CHECK-NEXT: R_RISCV_RELAX *ABS*
|
||
|
# CHECK-EMPTY:
|
||
|
# CHECK-NEXT: <f>:
|
||
|
# CHECK-NEXT: jalr zero, 0x0(ra)
|
||
|
# CHECK-NEXT: R_RISCV_ALIGN *ABS*+0x4
|
||
|
|
||
|
# CHECKR: <_start>:
|
||
|
# CHECKR-NEXT: auipc ra, 0x0
|
||
|
# CHECKR-NEXT: R_RISCV_CALL_PLT f
|
||
|
# CHECKR-NEXT: R_RISCV_RELAX *ABS*
|
||
|
# CHECKR-NEXT: jalr ra, 0x0(ra)
|
||
|
# CHECKR-NEXT: auipc ra, 0x0
|
||
|
# CHECKR-NEXT: R_RISCV_CALL_PLT f
|
||
|
# CHECKR-NEXT: R_RISCV_RELAX *ABS*
|
||
|
# CHECKR-NEXT: jalr ra, 0x0(ra)
|
||
|
# CHECKR-NEXT: addi zero, zero, 0x0
|
||
|
# CHECKR-NEXT: R_RISCV_ALIGN *ABS*+0x4
|
||
|
# CHECKR-EMPTY:
|
||
|
# CHECKR-NEXT: <f>:
|
||
|
# CHECKR-NEXT: jalr zero, 0x0(ra)
|
||
|
|
||
|
# CHECKNORELAX: <_start>:
|
||
|
# CHECKNORELAX-NEXT: auipc ra, 0x0
|
||
|
# CHECKNORELAX-NEXT: R_RISCV_CALL_PLT f
|
||
|
# CHECKNORELAX-NEXT: R_RISCV_RELAX *ABS*
|
||
|
# CHECKNORELAX-NEXT: jalr ra, 0x10(ra)
|
||
|
# CHECKNORELAX-NEXT: auipc ra, 0x0
|
||
|
# CHECKNORELAX-NEXT: R_RISCV_CALL_PLT f
|
||
|
# CHECKNORELAX-NEXT: R_RISCV_RELAX *ABS*
|
||
|
# CHECKNORELAX-NEXT: jalr ra, 0x8(ra)
|
||
|
# CHECKNORELAX-EMPTY:
|
||
|
# CHECKNORELAX-NEXT: <f>:
|
||
|
# CHECKNORELAX-NEXT: jalr zero, 0x0(ra)
|
||
|
# CHECKNORELAX-NEXT: R_RISCV_ALIGN *ABS*+0x4
|
||
|
|
||
|
.global _start
|
||
|
_start:
|
||
|
call f
|
||
|
call f
|
||
|
.balign 8
|
||
|
f:
|
||
|
ret
|