[llvm] r311541 - [gold] Test we don't strip globals when producing relocatables.

Davide Italiano via llvm-commits llvm-commits at lists.llvm.org
Wed Aug 23 02:43:41 PDT 2017


Author: davide
Date: Wed Aug 23 02:43:41 2017
New Revision: 311541

URL: http://llvm.org/viewvc/llvm-project?rev=311541&view=rev
Log:
[gold] Test we don't strip globals when producing relocatables.

lld was broken in this regard (PR33097). The gold plugin gets this
right so, no changes needed, but better adding a test.

Added:
    llvm/trunk/test/tools/gold/X86/relocatable.ll

Added: llvm/trunk/test/tools/gold/X86/relocatable.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/tools/gold/X86/relocatable.ll?rev=311541&view=auto
==============================================================================
--- llvm/trunk/test/tools/gold/X86/relocatable.ll (added)
+++ llvm/trunk/test/tools/gold/X86/relocatable.ll Wed Aug 23 02:43:41 2017
@@ -0,0 +1,26 @@
+; RUN: llvm-as %s -o %t1.o
+; RUN: %gold -plugin %llvmshlibdir/LLVMgold.so \
+; RUN:    -r %t1.o -o %t
+; RUN: llvm-readobj -symbols %t | FileCheck %s
+
+; CHECK: Symbol {
+; CHECK:   Name: foo
+; CHECK-NEXT:   Value: 0x0
+; CHECK-NEXT:   Size: 1
+; CHECK-NEXT:   Binding: Global
+; CHECK-NEXT:   Type: Function
+; CHECK-NEXT:   Other: 0
+; CHECK-NEXT:   Section: .text.foo
+; CHECK-NEXT: }
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+define void @foo() {
+  call void @bar()
+  ret void
+}
+
+define internal void @bar() {
+  ret void
+}




More information about the llvm-commits mailing list