forked from OSchip/llvm-project
35 lines
1.0 KiB
ArmAsm
35 lines
1.0 KiB
ArmAsm
# REQUIRES: ppc
|
|
# RUN: llvm-mc -filetype=obj -triple=powerpc %s -o %t.o
|
|
# RUN: ld.lld --noinhibit-exec %t.o --defsym=a=0x1234 --defsym=b=0xbcdef -o %t 2>&1 | \
|
|
# RUN: FileCheck --check-prefix=WARN %s
|
|
# RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s
|
|
# RUN: llvm-objdump -s --no-show-raw-insn %t | FileCheck --check-prefix=HEX %s
|
|
|
|
.section .R_PPC_ADDR16,"ax",@progbits
|
|
lis 4, a
|
|
lis 4, b
|
|
# CHECK-LABEL: section .R_PPC_ADDR16:
|
|
# CHECK: lis 4, 4660
|
|
# WARN: warning: {{.*}}.o:(.R_PPC_ADDR16+0x6): relocation R_PPC_ADDR16 out of range: 773615 is not in [-32768, 32767]
|
|
|
|
.section .R_PPC_ADDR16_HA,"ax",@progbits
|
|
lis 4, a@ha
|
|
# CHECK-LABEL: section .R_PPC_ADDR16_HA:
|
|
# CHECK: lis 4, 0
|
|
|
|
.section .R_PPC_ADDR16_HI,"ax",@progbits
|
|
lis 4, a@h
|
|
# CHECK-LABEL: section .R_PPC_ADDR16_HI:
|
|
# CHECK: lis 4, 0
|
|
|
|
.section .R_PPC_ADDR16_LO,"ax",@progbits
|
|
addi 4, 4, a@l
|
|
# CHECK-LABEL: section .R_PPC_ADDR16_LO:
|
|
# CHECK: addi 4, 4, 4660
|
|
|
|
.section .R_PPC_ADDR32,"a",@progbits
|
|
.long a
|
|
.long b
|
|
# HEX-LABEL: section .R_PPC_ADDR32:
|
|
# HEX-NEXT: 100000b4 00001234 000bcdef
|