From: Teresa Johnson Date: Mon, 15 May 2017 18:28:29 +0000 (+0000) Subject: Add support for handling ifuncs to GlobalValue::getBaseObject X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=34e726e44a08d669d7dc110dc709bf99d61cead4;p=llvm Add support for handling ifuncs to GlobalValue::getBaseObject 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 --- diff --git a/lib/IR/Globals.cpp b/lib/IR/Globals.cpp index 10ba1a64ad0..17d27b016cf 100644 --- a/lib/IR/Globals.cpp +++ b/lib/IR/Globals.cpp @@ -255,7 +255,7 @@ bool GlobalValue::canIncreaseAlignment() const { const GlobalObject *GlobalValue::getBaseObject() const { if (auto *GO = dyn_cast(this)) return GO; - if (auto *GA = dyn_cast(this)) + if (auto *GA = dyn_cast(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 index 00000000000..63723763430 --- /dev/null +++ b/test/LTO/Resolution/X86/ifunc.ll @@ -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 +} diff --git a/test/Object/X86/nm-ir.ll b/test/Object/X86/nm-ir.ll index 29f7a5c7018..c90f67b1516 100644 --- a/test/Object/X86/nm-ir.ll +++ b/test/Object/X86/nm-ir.ll @@ -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