bolt/deps/llvm-18.1.8/llvm/test/MC/RISCV/scoped-relaxation.s
2025-02-14 19:21:04 +01:00

34 lines
915 B
ArmAsm

# RUN: llvm-mc -mattr -relax -triple riscv64 -filetype obj %s -o - | llvm-readobj -d -r - | FileCheck %s
.global function
# CHECK: .rela.text {
# Unrelaxed reference, this would normally fail, but the subsequent scoped
# relaxation forces relaxation on the file.
.dword function - .
# CHECK: 0x0 R_RISCV_ADD64 function 0x0
# CHECK-NEXT: 0x0 R_RISCV_SUB64 <null> 0x0
# Relaxed reference, this will resolve to a pair of `RISCV_ADD64` and
# `RISCV_SUB64` relocation.
.option push
.option relax
.dword function - .
.option pop
# CHECK: 0x8 R_RISCV_ADD64 function 0x0
# CHECK-NEXT: 0x8 R_RISCV_SUB64 <null> 0x0
# Unrelaxed reference, this will resolve to a pair of `RISCV_ADD64` and
# `RISCV_SUB64` relocation due to relaxation being sticky to the file.
.option push
.option norelax
.dword function - .
.option pop
# CHECK: 0x10 R_RISCV_ADD64 function 0x0
# CHECK-NEXT: 0x10 R_RISCV_SUB64 <null> 0x0
# CHECK: }