llvm-project/lld/test/MachO/subsections-section-relocs.s

50 lines
1.5 KiB
ArmAsm

# REQUIRES: x86
# RUN: rm -rf %t; split-file %s %t
# RUN: llvm-mc -filetype=obj -triple=x86_64-apple-darwin %t/test.s -o %t/test.o
# RUN: %lld -o %t/test %t/test.o -order_file %t/order-file
# RUN: llvm-objdump --section-headers -d --no-show-raw-insn %t/test | FileCheck %s
# CHECK-LABEL: Sections:
# CHECK: __cstring {{[^ ]*}} {{0*}}[[#%x, CSTRING_ADDR:]]
# CHECK-LABEL: Disassembly of section __TEXT,__text:
## L._str should end up at CSTRING_ADDR + 4, and leaq is 7 bytes long so we
## have RIP = ADDR + 7
# CHECK: [[#%x, ADDR:]]: leaq
# CHECK-SAME: [[#%u, CSTRING_ADDR + 4 - ADDR - 7]](%rip), %rsi {{.*}} <_bar_str+0x4>
# RUN: llvm-readobj --string-dump=__cstring %t/test | FileCheck %s --check-prefix=STRINGS
# STRINGS: bar
# STRINGS: Private symbol
# STRINGS: foo
#--- order-file
_bar_str
_foo_str
#--- test.s
.text
.globl _main, _foo_str, _bar_str
_main:
leaq L_.str(%rip), %rsi
mov $0, %rax
ret
.section __TEXT,__cstring
_foo_str:
.asciz "foo"
_bar_str:
.asciz "bar"
## References to this generate a section relocation
## N.B.: ld64 doesn't actually reorder symbols in __cstring based on the order
## file. Only our implementation does. However, I'm not sure how else to
## test section relocations that target an address inside a relocated
## symbol: using a non-__cstring section would cause llvm-mc to emit a
## symbol relocation instead using the nearest symbol.
L_.str:
.asciz "Private symbol"
.subsections_via_symbols