aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorRoman Tereshin <rtereshin@apple.com>2019-01-19 01:53:26 +0000
committerRoman Tereshin <rtereshin@apple.com>2019-01-19 01:53:26 +0000
commit022bf3e8e7b06daf01fbacad224d2bf0c1919a3e (patch)
tree1b96966f101c59a31b9e1e883ecabc4f58311f0e /llvm/lib/CodeGen
parentdd6f9f68bb55696b7335f44941291cb3fe1e1b31 (diff)
downloadllvm-022bf3e8e7b06daf01fbacad224d2bf0c1919a3e.zip
llvm-022bf3e8e7b06daf01fbacad224d2bf0c1919a3e.tar.gz
llvm-022bf3e8e7b06daf01fbacad224d2bf0c1919a3e.tar.bz2
Revert "Reapply "[CGP] Check for existing inttotpr before creating new one""
This reverts commit r351618. Compiler RT + ASAN tests are failing for PowerPC. Not sure how would I reproduce these on macOS, so reverting (again) until I do. llvm-svn: 351619
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r--llvm/lib/CodeGen/CodeGenPrepare.cpp21
1 files changed, 4 insertions, 17 deletions
diff --git a/llvm/lib/CodeGen/CodeGenPrepare.cpp b/llvm/lib/CodeGen/CodeGenPrepare.cpp
index e33178c..c35f866 100644
--- a/llvm/lib/CodeGen/CodeGenPrepare.cpp
+++ b/llvm/lib/CodeGen/CodeGenPrepare.cpp
@@ -4664,26 +4664,13 @@ bool CodeGenPrepare::optimizeMemoryInst(Instruction *MemoryInst, Value *Addr,
// will look through it and provide only the integer value. In that case,
// use it here.
if (!DL->isNonIntegralPointerType(Addr->getType())) {
- const auto getResultPtr = [MemoryInst, Addr,
- &Builder](Value *Reg) -> Value * {
- BasicBlock *BB = MemoryInst->getParent();
- for (User *U : Reg->users())
- if (auto *I2P = dyn_cast<IntToPtrInst>(U))
- if (I2P->getType() == Addr->getType() && I2P->getParent() == BB) {
- if (isa<Instruction>(Reg) &&
- cast<Instruction>(Reg)->getParent() == BB)
- I2P->moveAfter(cast<Instruction>(Reg));
- else
- I2P->moveBefore(BB->getFirstNonPHI());
- return I2P;
- }
- return Builder.CreateIntToPtr(Reg, Addr->getType(), "sunkaddr");
- };
if (!ResultPtr && AddrMode.BaseReg) {
- ResultPtr = getResultPtr(AddrMode.BaseReg);
+ ResultPtr = Builder.CreateIntToPtr(AddrMode.BaseReg, Addr->getType(),
+ "sunkaddr");
AddrMode.BaseReg = nullptr;
} else if (!ResultPtr && AddrMode.Scale == 1) {
- ResultPtr = getResultPtr(AddrMode.ScaledReg);
+ ResultPtr = Builder.CreateIntToPtr(AddrMode.ScaledReg, Addr->getType(),
+ "sunkaddr");
AddrMode.Scale = 0;
}
}