[SLP]Reduce number of alternate instruction, where possible
[llvm-project.git] / llvm / test / MC / LoongArch / Directives / option-relax.s
blob587e1833085622a620f9b5f4fb401d0b2b199de7
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
9 .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
18 la.pcrel $a0, sym1
20 # CHECK-ASM: .option norelax
21 .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
30 la.pcrel $a0, sym2