Compiler projects using llvm
// RUN: llvm-mc -triple=powerpc64le-pc-linux -filetype=obj %s -o - | \
// RUN: llvm-readobj -r - | FileCheck %s

// RUN: llvm-mc -triple=powerpc64-pc-linux -filetype=obj %s -o - | \
// RUN: llvm-readobj -r - | FileCheck %s

// Verify we can handle all the tprel symbol modifiers for local exec tls.
// Tests 16 bit offsets on both DS-form and D-form instructions, 32 bit
// adjusted and non-adjusted offsets and 64 bit adjusted and non-adjusted
// offsets.
        .text
        .abiversion 2

        .globl	short_offset_ds
        .p2align	4
        .type	short_offset_ds,@function
short_offset_ds:
        lwa 3, i@tprel(13)
        blr

        .globl short_offset
        .p2align        4
        .type   short_offset,@function
short_offset:
        addi 3, 13, i@tprel
        blr

        .globl	medium_offset
        .p2align	4
        .type	medium_offset,@function
medium_offset:
        addis 3, 13, i@tprel@ha
        lwa 3, i@tprel@l(3)
        blr

        .globl  medium_not_adjusted
        .p2align        4
        .type   medium_not_adjusted,@function
medium_not_adjusted:
        lis 3, i@tprel@h
        ori 3, 3, i@tprel@l
        lwax 3, 3, 13
        blr

        .globl	large_offset
        .p2align	4
        .type	large_offset,@function
large_offset:
        lis 3, i@tprel@highesta
        ori 3, 3, i@tprel@highera
        sldi 3, 3, 32
        oris 3, 3, i@tprel@higha
        addi  3, 3, i@tprel@l
        lwax 3, 3, 13
        blr

        .globl	not_adjusted
        .p2align	4
        .type	not_adjusted,@function
not_adjusted:
        lis 3, i@tprel@highest
        ori 3, 3, i@tprel@higher
        sldi 3, 3, 32
        oris 3, 3, i@tprel@high
        ori  3, 3, i@tprel@l
        lwax 3, 3, 13
        blr

        .type	i,@object
        .section	.tdata,"awT",@progbits
        .p2align	2
i:
        .long	55
        .size	i, 4

        .type j,@object
        .data
        .p2align        3
j:
        .quad i@tprel
        .size j, 8


# CHECK: Relocations [
# CHECK:   Section {{.*}} .rela.text {
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_DS i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16 i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_HA i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_LO_DS i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_HI i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_LO i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_HIGHESTA i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_HIGHERA i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_HIGHA i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_LO i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_HIGHEST i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_HIGHER i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_HIGH i
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL16_LO i
# CHECK:   }
# CHECK:  Section (6) .rela.data {
# CHECK: 0x{{[0-9A-F]+}}  R_PPC64_TPREL64 i
# CHECK:   }
# CHECK: ]