diff options
Diffstat (limited to 'llvm/lib/Target/X86/X86ISelDAGToDAG.cpp')
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelDAGToDAG.cpp | 12 |
1 files changed, 4 insertions, 8 deletions
diff --git a/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp b/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp index f72392df836..9fe19ab67d3 100644 --- a/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp +++ b/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp @@ -819,25 +819,21 @@ DOUT << "AlreadySelected " << AlreadySelected << "\n"; GlobalValue *GV = G->getGlobal(); AM.GV = GV; AM.Disp += G->getOffset(); - AM.isRIPRel = TM.getRelocationModel() != Reloc::Static && - Subtarget->isPICStyleRIPRel(); + AM.isRIPRel = TM.symbolicAddressesAreRIPRel(); return false; } else if (ConstantPoolSDNode *CP = dyn_cast<ConstantPoolSDNode>(N0)) { AM.CP = CP->getConstVal(); AM.Align = CP->getAlignment(); AM.Disp += CP->getOffset(); - AM.isRIPRel = TM.getRelocationModel() != Reloc::Static && - Subtarget->isPICStyleRIPRel(); + AM.isRIPRel = TM.symbolicAddressesAreRIPRel(); return false; } else if (ExternalSymbolSDNode *S =dyn_cast<ExternalSymbolSDNode>(N0)) { AM.ES = S->getSymbol(); - AM.isRIPRel = TM.getRelocationModel() != Reloc::Static && - Subtarget->isPICStyleRIPRel(); + AM.isRIPRel = TM.symbolicAddressesAreRIPRel(); return false; } else if (JumpTableSDNode *J = dyn_cast<JumpTableSDNode>(N0)) { AM.JT = J->getIndex(); - AM.isRIPRel = TM.getRelocationModel() != Reloc::Static && - Subtarget->isPICStyleRIPRel(); + AM.isRIPRel = TM.symbolicAddressesAreRIPRel(); return false; } } |

