# REQUIRES: x86 # RUN: split-file %s %t # RUN: llvm-mc -filetype=obj -triple=x86_64 %t/1.s -o %t/1.o # RUN: llvm-mc -filetype=obj -triple=x86_64 %t/2.s -o %t/2.o # RUN: llvm-mc -filetype=obj -triple=x86_64 %t/3.s -o %t/3.o # RUN: ld.lld -shared -soname=3 --version-script=%t/3.ver %t/3.o -o %t/3.so # RUN: ld.lld -Map=%t/1.map %t/1.o %t/2.o %t/3.so -o %t/1 # RUN: FileCheck %s --input-file=%t/1.map ## Both TUs reference func/copy which need a canonical PLT entry/copy relocation. ## Test we print func/copy just once. # CHECK: {{ }}.plt # CHECK-NEXT: :(.plt) # CHECK-NEXT: func@v1{{$}} # CHECK-NEXT: .dynamic # CHECK: .bss.rel.ro # CHECK-NEXT: :(.bss.rel.ro) ## Ideally this is displayed as copy@v2. # CHECK-NEXT: copy{{$}} # CHECK-NEXT: .relro_padding #--- 1.s .global _start _start: .symver func, func@@@v1 mov $copy, %eax mov $func - ., %eax #--- 2.s .symver func, func@@@v1 mov $copy, %eax mov $func - ., %eax #--- 3.s .globl func .symver func, func@v1, remove .type func, @function func: ret .section .rodata,"a" .globl copy .type copy, @object copy: .byte 1 .size copy, 1 #--- 3.ver v1 { func; }; v2 { copy; };