]> granicus.if.org Git - llvm/commitdiff
Add support for handling ifuncs to GlobalValue::getBaseObject
authorTeresa Johnson <tejohnson@google.com>
Mon, 15 May 2017 18:28:29 +0000 (18:28 +0000)
committerTeresa Johnson <tejohnson@google.com>
Mon, 15 May 2017 18:28:29 +0000 (18:28 +0000)
Summary:
All GlobalIndirectSymbol types (not just GlobalAlias) should return
their base object.

Without this patch LTO would warn "Unable to determine comdat of
alias!" for an ifunc.

Reviewers: pcc

Subscribers: mehdi_amini, inglorion, llvm-commits

Differential Revision: https://reviews.llvm.org/D33202

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@303096 91177308-0d34-0410-b5e6-96231b3b80d8

lib/IR/Globals.cpp
test/LTO/Resolution/X86/ifunc.ll [new file with mode: 0644]
test/Object/X86/nm-ir.ll

index 10ba1a64ad0c6ba21801601d7edb9acb10251bbf..17d27b016cf2aef847ce2cd713d4667d400f3c4f 100644 (file)
@@ -255,7 +255,7 @@ bool GlobalValue::canIncreaseAlignment() const {
 const GlobalObject *GlobalValue::getBaseObject() const {
   if (auto *GO = dyn_cast<GlobalObject>(this))
     return GO;
-  if (auto *GA = dyn_cast<GlobalAlias>(this))
+  if (auto *GA = dyn_cast<GlobalIndirectSymbol>(this))
     return GA->getBaseObject();
   return nullptr;
 }
diff --git a/test/LTO/Resolution/X86/ifunc.ll b/test/LTO/Resolution/X86/ifunc.ll
new file mode 100644 (file)
index 0000000..6372376
--- /dev/null
@@ -0,0 +1,15 @@
+; RUN: opt -module-summary -o %t.bc %s
+; RUN: llvm-lto2 run %t.bc -r %t.bc,foo,pl -o %t2
+; RUN: llvm-nm %t2.0 | FileCheck %s
+; CHECK: T foo
+; CHECK: t foo_ifunc
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+@foo = ifunc i32 (i32), i64 ()* @foo_ifunc
+
+define internal i64 @foo_ifunc() {
+entry:
+  ret i64 0
+}
index 29f7a5c7018c8a87ec73d5644433b35fde2e4957..c90f67b15160d3bc0b8012c988ccc6da26872534 100644 (file)
@@ -12,7 +12,7 @@
 ; CHECK-NEXT: C g3
 ; CHECK-NOT: g4
 ; CHECK-NEXT: T global_asm_sym
-; CHECK-NEXT: D ifunc_f1
+; CHECK-NEXT: T ifunc_f1
 ; CHECK-NEXT: t local_asm_sym
 ; CHECK-NEXT: U undef_asm_sy