From 928a95d0b0ad71de454014c9eca348e82929eb13 Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Wed, 22 Jun 2016 22:09:17 +0000 Subject: Use shouldAssumeDSOLocal. With this it handle -fPIE. llvm-svn: 273499 --- llvm/lib/Target/PowerPC/PPCISelLowering.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) (limited to 'llvm/lib/Target/PowerPC/PPCISelLowering.cpp') diff --git a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp index 68d1a679e83..1df07071f8e 100644 --- a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp +++ b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp @@ -23,6 +23,7 @@ #include "llvm/ADT/Statistic.h" #include "llvm/ADT/StringSwitch.h" #include "llvm/ADT/Triple.h" +#include "llvm/CodeGen/Analysis.h" #include "llvm/CodeGen/CallingConvLower.h" #include "llvm/CodeGen/MachineFrameInfo.h" #include "llvm/CodeGen/MachineFunction.h" @@ -4287,11 +4288,10 @@ PrepareCall(SelectionDAG &DAG, SDValue &Callee, SDValue &InFlag, SDValue &Chain, Reloc::Model RM = DAG.getTarget().getRelocationModel(); const Triple &TargetTriple = Subtarget.getTargetTriple(); const GlobalValue *GV = G->getGlobal(); - if ((RM != Reloc::Static && - (TargetTriple.isMacOSX() && TargetTriple.isMacOSXVersionLT(10, 5)) && - !GV->isStrongDefinitionForLinker()) || - (Subtarget.isTargetELF() && !isPPC64 && !GV->hasLocalLinkage() && - RM == Reloc::PIC_)) { + bool OldMachOLinker = + TargetTriple.isMacOSX() && TargetTriple.isMacOSXVersionLT(10, 5); + if (!shouldAssumeDSOLocal(RM, TargetTriple, *GV->getParent(), GV) && + (OldMachOLinker || (Subtarget.isTargetELF() && !isPPC64))) { // PC-relative references to external symbols should go through $stub, // unless we're building with the leopard linker or later, which // automatically synthesizes these stubs. -- cgit v1.2.3