[PATCH] D43193: [ELF] - Added testcase for testing visibility of weak_odr symbols.

Rafael Avila de Espindola via llvm-commits llvm-commits at lists.llvm.org
Thu Feb 22 10:50:52 PST 2018


LGTM

Thanks,
Rafael

George Rimar via Phabricator <reviews at reviews.llvm.org> writes:

> grimar created this revision.
> grimar added reviewers: ruiu, espindola.
> Herald added subscribers: arichardson, emaste.
>
> This is relative to "Bug 36166 - tools/gold/X86/comdat.ll is failing only on Debian Unstable" (PR36166).
> Something changed in newer versions of gold and now together with gold-plugin
> there is an issue shown in PR, symbol may get wrong visibility.
>
> LLD works fine, but we have no testcase for the same use case, and I
> suggest to add it just in case to explicitly document the behavior.
>
>
> https://reviews.llvm.org/D43193
>
> Files:
>   test/ELF/lto/Inputs/weakodr-visibility.ll
>   test/ELF/lto/weakodr-visibility.ll
>
>
> Index: test/ELF/lto/weakodr-visibility.ll
> ===================================================================
> --- test/ELF/lto/weakodr-visibility.ll
> +++ test/ELF/lto/weakodr-visibility.ll
> @@ -0,0 +1,40 @@
> +; REQUIRES: x86
> +; RUN: llvm-as %s -o %t1.o
> +; RUN: llvm-as %p/Inputs/weakodr-visibility.ll -o %t2.o
> +
> +; Testcase checks we keep desired visibility of weak 
> +; symbol in a library even if select different definition.
> +; We change the order of input files in command line and
> +; check that linker selects different symbol definitions,
> +; but keeps `protected` visibility.
> +
> +; RUN: ld.lld %t1.o %t2.o -o %t.so -shared
> +; RUN: llvm-readobj -t %t.so | FileCheck %s
> +; RUN: llvm-objdump -d %t.so | FileCheck %s --check-prefix=FIRST
> +; CHECK:       Symbol {
> +; CHECK:        Name: foo
> +; CHECK-NEXT:   Value:
> +; CHECK-NEXT:   Size:
> +; CHECK-NEXT:   Binding: Weak
> +; CHECK-NEXT:   Type: Function
> +; CHECK-NEXT:   Other [
> +; CHECK-NEXT:     STV_PROTECTED
> +; CHECK-NEXT:   ]
> +; CHECK-NEXT:   Section:
> +; CHECK-NEXT: }
> +; FIRST:      foo:
> +; FIRST-NEXT:   movl    $41, %eax
> +
> +; Now swap the files order.
> +; RUN: ld.lld %t2.o %t1.o -o %t.so -shared
> +; RUN: llvm-readobj -t %t.so | FileCheck %s
> +; RUN: llvm-objdump -d %t.so | FileCheck %s --check-prefix=SECOND
> +; SECOND:      foo:
> +; SECOND-NEXT:   movl    $42, %eax
> +
> +target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
> +target triple = "x86_64-unknown-linux-gnu"
> +
> +define weak_odr i32 @foo(i8* %this) {
> +  ret i32 41
> +}
> Index: test/ELF/lto/Inputs/weakodr-visibility.ll
> ===================================================================
> --- test/ELF/lto/Inputs/weakodr-visibility.ll
> +++ test/ELF/lto/Inputs/weakodr-visibility.ll
> @@ -0,0 +1,6 @@
> +target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
> +target triple = "x86_64-unknown-linux-gnu"
> +
> +define weak_odr protected i32 @foo(i8* %this) {
> +  ret i32 42
> +}
>
>
> Index: test/ELF/lto/weakodr-visibility.ll
> ===================================================================
> --- test/ELF/lto/weakodr-visibility.ll
> +++ test/ELF/lto/weakodr-visibility.ll
> @@ -0,0 +1,40 @@
> +; REQUIRES: x86
> +; RUN: llvm-as %s -o %t1.o
> +; RUN: llvm-as %p/Inputs/weakodr-visibility.ll -o %t2.o
> +
> +; Testcase checks we keep desired visibility of weak 
> +; symbol in a library even if select different definition.
> +; We change the order of input files in command line and
> +; check that linker selects different symbol definitions,
> +; but keeps `protected` visibility.
> +
> +; RUN: ld.lld %t1.o %t2.o -o %t.so -shared
> +; RUN: llvm-readobj -t %t.so | FileCheck %s
> +; RUN: llvm-objdump -d %t.so | FileCheck %s --check-prefix=FIRST
> +; CHECK:       Symbol {
> +; CHECK:        Name: foo
> +; CHECK-NEXT:   Value:
> +; CHECK-NEXT:   Size:
> +; CHECK-NEXT:   Binding: Weak
> +; CHECK-NEXT:   Type: Function
> +; CHECK-NEXT:   Other [
> +; CHECK-NEXT:     STV_PROTECTED
> +; CHECK-NEXT:   ]
> +; CHECK-NEXT:   Section:
> +; CHECK-NEXT: }
> +; FIRST:      foo:
> +; FIRST-NEXT:   movl    $41, %eax
> +
> +; Now swap the files order.
> +; RUN: ld.lld %t2.o %t1.o -o %t.so -shared
> +; RUN: llvm-readobj -t %t.so | FileCheck %s
> +; RUN: llvm-objdump -d %t.so | FileCheck %s --check-prefix=SECOND
> +; SECOND:      foo:
> +; SECOND-NEXT:   movl    $42, %eax
> +
> +target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
> +target triple = "x86_64-unknown-linux-gnu"
> +
> +define weak_odr i32 @foo(i8* %this) {
> +  ret i32 41
> +}
> Index: test/ELF/lto/Inputs/weakodr-visibility.ll
> ===================================================================
> --- test/ELF/lto/Inputs/weakodr-visibility.ll
> +++ test/ELF/lto/Inputs/weakodr-visibility.ll
> @@ -0,0 +1,6 @@
> +target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
> +target triple = "x86_64-unknown-linux-gnu"
> +
> +define weak_odr protected i32 @foo(i8* %this) {
> +  ret i32 42
> +}


More information about the llvm-commits mailing list