diff options
| author | Bill Schmidt <wschmidt@linux.vnet.ibm.com> | 2012-12-13 18:45:54 +0000 |
|---|---|---|
| committer | Bill Schmidt <wschmidt@linux.vnet.ibm.com> | 2012-12-13 18:45:54 +0000 |
| commit | 732eb91f0589bcbb0832ac359fd8d01dd19877c8 (patch) | |
| tree | c9946b3eae74287ba563dde79c4840157d1263d9 /llvm/lib/Target/PowerPC/PPCISelLowering.cpp | |
| parent | 05394352c019da94e9ece722492ced494b2bedb1 (diff) | |
| download | bcm5719-llvm-732eb91f0589bcbb0832ac359fd8d01dd19877c8.tar.gz bcm5719-llvm-732eb91f0589bcbb0832ac359fd8d01dd19877c8.zip | |
This is just a clean-up patch that simplifies the initial-exec TLS logic by
avoiding use of machine operand flags. No change in observable behavior, so
no new test cases.
llvm-svn: 170141
Diffstat (limited to 'llvm/lib/Target/PowerPC/PPCISelLowering.cpp')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCISelLowering.cpp | 14 |
1 files changed, 5 insertions, 9 deletions
diff --git a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp index 68f1bc6eaea..0748bd53a8c 100644 --- a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp +++ b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp @@ -1351,15 +1351,11 @@ SDValue PPCTargetLowering::LowerGlobalTLSAddress(SDValue Op, llvm_unreachable("only local-exec is currently supported for ppc32"); if (Model == TLSModel::InitialExec) { - SDValue GOTOffset = DAG.getTargetGlobalAddress(GV, dl, PtrVT, 0, - PPCII::MO_GOT_TPREL16_DS); - SDValue TPReg = DAG.getTargetGlobalAddress(GV, dl, PtrVT, 0, - PPCII::MO_TLS); - SDValue GOTReg = DAG.getRegister(is64bit ? PPC::X2 : PPC::R2, - is64bit ? MVT::i64 : MVT::i32); - SDValue TPOffset = DAG.getNode(PPCISD::LD_GOT_TPREL, dl, PtrVT, - GOTOffset, GOTReg); - return DAG.getNode(PPCISD::ADD_TLS, dl, PtrVT, TPOffset, TPReg); + SDValue TGA = DAG.getTargetGlobalAddress(GV, dl, PtrVT, 0, 0); + SDValue GOTReg = DAG.getRegister(PPC::X2, MVT::i64); + SDValue TPOffset = DAG.getNode(PPCISD::LD_GOT_TPREL, dl, + PtrVT, TGA, GOTReg); + return DAG.getNode(PPCISD::ADD_TLS, dl, PtrVT, TPOffset, TGA); } if (Model == TLSModel::GeneralDynamic) { |

