diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2016-06-26 22:24:01 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2016-06-26 22:24:01 +0000 |
commit | 608ab75c0b7845163d1c965b2e522c5d1a8b2624 (patch) | |
tree | 797d77889ddd4b74e2691b8dcaff1ec39e06dc4f | |
parent | 73b2bb0c65a69efe10930d227025005b8c819642 (diff) |
Use isPositionIndependent predicate. NFC.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@273827 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/Hexagon/HexagonISelLowering.cpp | 17 |
1 files changed, 8 insertions, 9 deletions
diff --git a/lib/Target/Hexagon/HexagonISelLowering.cpp b/lib/Target/Hexagon/HexagonISelLowering.cpp index bd36978c436..2fa0bfd5765 100644 --- a/lib/Target/Hexagon/HexagonISelLowering.cpp +++ b/lib/Target/Hexagon/HexagonISelLowering.cpp @@ -1408,15 +1408,15 @@ HexagonTargetLowering::LowerConstantPool(SDValue Op, SelectionDAG &DAG) const { EVT ValTy = Op.getValueType(); ConstantPoolSDNode *CPN = cast<ConstantPoolSDNode>(Op); unsigned Align = CPN->getAlignment(); - Reloc::Model RM = HTM.getRelocationModel(); - unsigned char TF = (RM == Reloc::PIC_) ? HexagonII::MO_PCREL : 0; + bool IsPositionIndependent = isPositionIndependent(); + unsigned char TF = IsPositionIndependent ? HexagonII::MO_PCREL : 0; SDValue T; if (CPN->isMachineConstantPoolEntry()) T = DAG.getTargetConstantPool(CPN->getMachineCPVal(), ValTy, Align, TF); else T = DAG.getTargetConstantPool(CPN->getConstVal(), ValTy, Align, TF); - if (RM == Reloc::PIC_) + if (IsPositionIndependent) return DAG.getNode(HexagonISD::AT_PCREL, SDLoc(Op), ValTy, T); return DAG.getNode(HexagonISD::CP, SDLoc(Op), ValTy, T); } @@ -1425,8 +1425,7 @@ SDValue HexagonTargetLowering::LowerJumpTable(SDValue Op, SelectionDAG &DAG) const { EVT VT = Op.getValueType(); int Idx = cast<JumpTableSDNode>(Op)->getIndex(); - Reloc::Model RM = HTM.getRelocationModel(); - if (RM == Reloc::PIC_) { + if (isPositionIndependent()) { SDValue T = DAG.getTargetJumpTable(Idx, VT, HexagonII::MO_PCREL); return DAG.getNode(HexagonISD::AT_PCREL, SDLoc(Op), VT, T); } @@ -1593,9 +1592,9 @@ HexagonTargetLowering::LowerToTLSInitialExecModel(GlobalAddressSDNode *GA, // Get the thread pointer. SDValue TP = DAG.getCopyFromReg(DAG.getEntryNode(), dl, Hexagon::UGP, PtrVT); - Reloc::Model RM = HTM.getRelocationModel(); - unsigned char TF = (RM == Reloc::PIC_) ? HexagonII::MO_IEGOT - : HexagonII::MO_IE; + bool IsPositionIndependent = isPositionIndependent(); + unsigned char TF = + IsPositionIndependent ? HexagonII::MO_IEGOT : HexagonII::MO_IE; // First generate the TLS symbol address SDValue TGA = DAG.getTargetGlobalAddress(GA->getGlobal(), dl, PtrVT, @@ -1603,7 +1602,7 @@ HexagonTargetLowering::LowerToTLSInitialExecModel(GlobalAddressSDNode *GA, SDValue Sym = DAG.getNode(HexagonISD::CONST32, dl, PtrVT, TGA); - if (RM == Reloc::PIC_) { + if (IsPositionIndependent) { // Generate the GOT pointer in case of position independent code SDValue GOT = LowerGLOBAL_OFFSET_TABLE(Sym, DAG); |