[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