; RUN: llc --mtriple=loongarch64 --filetype=obj -mattr=-relax \ ; RUN: --relocation-model=pic --code-model=medium < %s \ ; RUN: | llvm-readobj -r - | FileCheck --check-prefix=CHECK-RELOC %s ; RUN: llc --mtriple=loongarch64 --filetype=obj -mattr=+relax \ ; RUN: --relocation-model=pic --code-model=medium < %s \ ; RUN: | llvm-readobj -r - | FileCheck --check-prefixes=CHECK-RELOC,RELAX %s ; RUN: llc --mtriple=loongarch64 --filetype=obj -mattr=-relax --enable-tlsdesc \ ; RUN: --relocation-model=pic --code-model=medium < %s \ ; RUN: | llvm-readobj -r - | FileCheck --check-prefix=DESC-RELOC %s ; RUN: llc --mtriple=loongarch64 --filetype=obj -mattr=+relax --enable-tlsdesc \ ; RUN: --relocation-model=pic --code-model=medium < %s \ ; RUN: | llvm-readobj -r - | FileCheck --check-prefixes=DESC-RELOC,DESC-RELAX %s ;; Check relocations when disable or enable linker relaxation. ;; This tests are also able to test for removing relax mask flags ;; after loongarch-merge-base-offset pass because no relax relocs ;; are emitted after being optimized by it. @g_e = external global i32 @g_i = internal global i32 0 @g_i1 = internal global i32 1 @t_un = external thread_local global i32 @t_ld = external thread_local(localdynamic) global i32 @t_ie = external thread_local(initialexec) global i32 @t_le = external thread_local(localexec) global i32 declare void @callee1() nounwind declare dso_local void @callee2() nounwind declare dso_local void @callee3() nounwind ; CHECK-RELOC: R_LARCH_GOT_PC_HI20 g_e 0x0 ; RELAX: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_GOT_PC_LO12 g_e 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_PCALA_HI20 g_i 0x0 ; CHECK-RELOC-NEXT: R_LARCH_PCALA_LO12 g_i 0x0 ; CHECK-RELOC: R_LARCH_TLS_GD_PC_HI20 t_un 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_GOT_PC_LO12 t_un 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_CALL36 __tls_get_addr 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; DESC-RELOC: R_LARCH_TLS_DESC_PC_HI20 t_un 0x0 ; DESC-RELAX: R_LARCH_RELAX - 0x0 ; DESC-RELOC-NEXT: R_LARCH_TLS_DESC_PC_LO12 t_un 0x0 ; DESC-RELAX-NEXT: R_LARCH_RELAX - 0x0 ; DESC-RELOC-NEXT: R_LARCH_TLS_DESC_LD t_un 0x0 ; DESC-RELAX-NEXT: R_LARCH_RELAX - 0x0 ; DESC-RELOC-NEXT: R_LARCH_TLS_DESC_CALL t_un 0x0 ; DESC-RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_TLS_LD_PC_HI20 t_ld 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_GOT_PC_LO12 t_ld 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_CALL36 __tls_get_addr 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; DESC-RELOC-NEXT: R_LARCH_TLS_DESC_PC_HI20 t_ld 0x0 ; DESC-RELAX-NEXT: R_LARCH_RELAX - 0x0 ; DESC-RELOC-NEXT: R_LARCH_TLS_DESC_PC_LO12 t_ld 0x0 ; DESC-RELAX-NEXT: R_LARCH_RELAX - 0x0 ; DESC-RELOC-NEXT: R_LARCH_TLS_DESC_LD t_ld 0x0 ; DESC-RELAX-NEXT: R_LARCH_RELAX - 0x0 ; DESC-RELOC-NEXT: R_LARCH_TLS_DESC_CALL t_ld 0x0 ; DESC-RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_TLS_IE_PC_HI20 t_ie 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_TLS_IE_PC_LO12 t_ie 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_TLS_LE_HI20_R t_le 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_TLS_LE_ADD_R t_le 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_TLS_LE_LO12_R t_le 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_PCALA_HI20 g_i1 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_PCALA_LO12 g_i1 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; RELAX-NEXT: R_LARCH_ALIGN - 0x1C ; CHECK-RELOC-NEXT: R_LARCH_CALL36 callee1 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_CALL36 callee2 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ; CHECK-RELOC-NEXT: R_LARCH_CALL36 callee3 0x0 ; RELAX-NEXT: R_LARCH_RELAX - 0x0 ;; No ALIGN reloc will emit before the first linker-relaxable instruction. define ptr @loader() nounwind { %a = load volatile i32, ptr @g_e %b = load volatile i32, ptr @g_i %c = load volatile i32, ptr @t_un %d = load volatile i32, ptr @t_ld %e = load volatile i32, ptr @t_ie %f = load volatile i32, ptr @t_le ret ptr @g_i1 } ;; ALIGN reloc will be emitted here. define void @caller() nounwind { call i32 @callee1() call i32 @callee2() tail call i32 @callee3() ret void }