1 # RUN: llvm-mc --triple=loongarch64 %s | FileCheck --check-prefix=CHECK-ASM %s
2 # RUN: llvm-mc -filetype=obj --triple=loongarch64 %s \
3 # RUN: | llvm-readobj -r - | FileCheck -check-prefix=CHECK-RELOC %s
5 ## Check .option relax causes R_LARCH_RELAX to be emitted, and .option
6 ## norelax suppresses it.
8 # CHECK-ASM: .option relax
11 # CHECK-ASM: pcalau12i $a0, %pc_hi20(sym1)
12 # CHECK-ASM-NEXT: addi.d $a0, $a0, %pc_lo12(sym1)
14 # CHECK-RELOC: R_LARCH_PCALA_HI20 sym1 0x0
15 # CHECK-RELOC-NEXT: R_LARCH_RELAX - 0x0
16 # CHECK-RELOC-NEXT: R_LARCH_PCALA_LO12 sym1 0x0
17 # CHECK-RELOC-NEXT: R_LARCH_RELAX - 0x0
20 # CHECK-ASM: .option norelax
23 # CHECK-ASM: pcalau12i $a0, %pc_hi20(sym2)
24 # CHECK-ASM-NEXT: addi.d $a0, $a0, %pc_lo12(sym2)
26 # CHECK-RELOC-NEXT: R_LARCH_PCALA_HI20 sym2 0x0
27 # CHECK-RELOC-NOT: R_LARCH_RELAX - 0x0
28 # CHECK-RELOC-NEXT: R_LARCH_PCALA_LO12 sym2 0x0
29 # CHECK-RELOC-NOT: R_LARCH_RELAX - 0x0