forked from OSchip/llvm-project
41 lines
948 B
ArmAsm
41 lines
948 B
ArmAsm
// REQUIRES: x86
|
|
// Test that relocation of local symbols is working.
|
|
// RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t
|
|
// RUN: ld.lld %t -o %t2
|
|
// RUN: llvm-objdump -s -d %t2 | FileCheck %s
|
|
|
|
|
|
.global _start
|
|
_start:
|
|
call lulz
|
|
|
|
.zero 4
|
|
lulz:
|
|
|
|
.section .text2,"ax",@progbits
|
|
R_X86_64_32:
|
|
movl $R_X86_64_32, %edx
|
|
|
|
// FIXME: this would be far more self evident if llvm-objdump printed
|
|
// constants in hex.
|
|
// CHECK: Disassembly of section .text2:
|
|
// CHECK-EMPTY:
|
|
// CHECK-NEXT: R_X86_64_32:
|
|
// CHECK-NEXT: 201009: {{.*}} movl $2101257, %edx
|
|
|
|
.section .R_X86_64_32S,"ax",@progbits
|
|
R_X86_64_32S:
|
|
movq lulz - 0x100000, %rdx
|
|
|
|
// CHECK: Disassembly of section .R_X86_64_32S:
|
|
// CHECK-EMPTY:
|
|
// CHECK-NEXT: R_X86_64_32S:
|
|
// CHECK-NEXT: {{.*}}: {{.*}} movq 1052681, %rdx
|
|
|
|
.section .R_X86_64_64,"a",@progbits
|
|
R_X86_64_64:
|
|
.quad R_X86_64_64
|
|
|
|
// CHECK: Contents of section .R_X86_64_64:
|
|
// CHECK-NEXT: 200120 20012000 00000000
|