summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms
diff options
context:
space:
mode:
authorDavid Majnemer <david.majnemer@gmail.com>2014-11-18 21:30:02 +0000
committerDavid Majnemer <david.majnemer@gmail.com>2014-11-18 21:30:02 +0000
commitb32eaddf11a65d52b41935207d69d6ba1564228d (patch)
tree2b9828d1f72039c0539934011b4e0be761ba277d /llvm/lib/Transforms
parentef2ad33e8a17c0b5db2d9eda4848c2773b5500a7 (diff)
downloadbcm5719-llvm-b32eaddf11a65d52b41935207d69d6ba1564228d.tar.gz
bcm5719-llvm-b32eaddf11a65d52b41935207d69d6ba1564228d.zip
Revert "Revert r222040 because of bot failure."
This reverts commit r222203, reverting r222040 didn't end up turning the bot green. llvm-svn: 222261
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r--llvm/lib/Transforms/InstCombine/InstCombineCasts.cpp15
1 files changed, 9 insertions, 6 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineCasts.cpp b/llvm/lib/Transforms/InstCombine/InstCombineCasts.cpp
index b41cdc65202..a0570f7ebd4 100644
--- a/llvm/lib/Transforms/InstCombine/InstCombineCasts.cpp
+++ b/llvm/lib/Transforms/InstCombine/InstCombineCasts.cpp
@@ -1269,14 +1269,17 @@ Instruction *InstCombiner::visitFPTrunc(FPTruncInst &CI) {
// type of OpI doesn't enter into things at all. We simply evaluate
// in whichever source type is larger, then convert to the
// destination type.
+ Value *NewLHS = LHSOrig, *NewRHS = RHSOrig;
if (LHSWidth < SrcWidth)
- LHSOrig = Builder->CreateFPExt(LHSOrig, RHSOrig->getType());
+ NewLHS = Builder->CreateFPExt(NewLHS, RHSOrig->getType());
else if (RHSWidth <= SrcWidth)
- RHSOrig = Builder->CreateFPExt(RHSOrig, LHSOrig->getType());
- Value *ExactResult = Builder->CreateFRem(LHSOrig, RHSOrig);
- if (Instruction *RI = dyn_cast<Instruction>(ExactResult))
- RI->copyFastMathFlags(OpI);
- return CastInst::CreateFPCast(ExactResult, CI.getType());
+ NewRHS = Builder->CreateFPExt(NewRHS, LHSOrig->getType());
+ if (NewLHS != LHSOrig || NewRHS != RHSOrig) {
+ Value *ExactResult = Builder->CreateFRem(NewLHS, NewRHS);
+ if (Instruction *RI = dyn_cast<Instruction>(ExactResult))
+ RI->copyFastMathFlags(OpI);
+ return CastInst::CreateFPCast(ExactResult, CI.getType());
+ }
}
// (fptrunc (fneg x)) -> (fneg (fptrunc x))
OpenPOWER on IntegriCloud