diff options
author | Strahinja Petrovic <strahinja.petrovic@rt-rk.com> | 2018-09-17 11:03:40 +0000 |
---|---|---|
committer | Strahinja Petrovic <strahinja.petrovic@rt-rk.com> | 2018-09-17 11:03:40 +0000 |
commit | 488fd4e6255d6216f2a678d9ac6a184f4e449695 (patch) | |
tree | 970961aa2ee6ac2b2b55d3bd6e53c618ef046be0 /llvm/lib/Target/PowerPC/PPCISelLowering.cpp | |
parent | 1a5623489b859ed435ba410c5f527e24613c30a7 (diff) | |
download | bcm5719-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.cpp | 3 |
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()); |