summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/PowerPC/PPCISelLowering.cpp
diff options
context:
space:
mode:
authorStrahinja Petrovic <strahinja.petrovic@rt-rk.com>2018-09-17 11:03:40 +0000
committerStrahinja Petrovic <strahinja.petrovic@rt-rk.com>2018-09-17 11:03:40 +0000
commit488fd4e6255d6216f2a678d9ac6a184f4e449695 (patch)
tree970961aa2ee6ac2b2b55d3bd6e53c618ef046be0 /llvm/lib/Target/PowerPC/PPCISelLowering.cpp
parent1a5623489b859ed435ba410c5f527e24613c30a7 (diff)
downloadbcm5719-llvm-488fd4e6255d6216f2a678d9ac6a184f4e449695.tar.gz
bcm5719-llvm-488fd4e6255d6216f2a678d9ac6a184f4e449695.zip
[PowerPC] Fix label address calculation for ppc64
This patch fixes calculating address of label for non-pic ppc64. Differential Revision: https://reviews.llvm.org/D50965 llvm-svn: 342368
Diffstat (limited to 'llvm/lib/Target/PowerPC/PPCISelLowering.cpp')
-rw-r--r--llvm/lib/Target/PowerPC/PPCISelLowering.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp
index 5dee7b12a21..dba69a160d4 100644
--- a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp
+++ b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp
@@ -2705,7 +2705,8 @@ SDValue PPCTargetLowering::LowerBlockAddress(SDValue Op,
// 64-bit SVR4 ABI code is always position-independent.
// The actual BlockAddress is stored in the TOC.
- if (Subtarget.isSVR4ABI() && isPositionIndependent()) {
+ if (Subtarget.isSVR4ABI() &&
+ (Subtarget.isPPC64() || isPositionIndependent())) {
if (Subtarget.isPPC64())
setUsesTOCBasePtr(DAG);
SDValue GA = DAG.getTargetBlockAddress(BA, PtrVT, BASDN->getOffset());
OpenPOWER on IntegriCloud