| // RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t.o |
| // RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %p/Inputs/shared.s -o %t2.o |
| // RUN: ld.lld -shared %t2.o -o %t2.so |
| // RUN: ld.lld %t.o %t2.so -o %t |
| // RUN: llvm-readobj -r %t | FileCheck %s |
| // REQUIRES: x86 |
| |
| .globl _start |
| _start: |
| .type sym1,@function |
| .weak sym1 |
| .long sym1@gotpcrel |
| |
| .type sym2,@function |
| .weak sym2 |
| .long sym2@plt |
| |
| .type sym3,@function |
| .weak sym3 |
| .quad sym3 |
| |
| // Both gold and bfd ld will produce a relocation for sym1 and sym2 only. That |
| // That seems odd. If the dynamic linker must get a chance to resolve sym1 |
| // and sym2, that should also be the case for sym3. |
| |
| // CHECK: Relocations [ |
| // CHECK-NEXT: Section ({{.*}}) .rela.dyn { |
| // CHECK-NEXT: 0x{{.*}} R_X86_64_GLOB_DAT sym1 0x0 |
| // CHECK-NEXT: } |
| // CHECK-NEXT: Section ({{.*}}) .rela.plt { |
| // CHECK-NEXT: 0x{{.*}} R_X86_64_JUMP_SLOT sym2 0x0 |
| // CHECK-NEXT: } |
| // CHECK-NEXT: ] |