[llvm-commits] [llvm] r124561 - in /llvm/trunk: lib/Analysis/InstructionSimplify.cpp test/Transforms/InstSimplify/2010-12-20-Reassociate.ll
Duncan Sands
baldrick at free.fr
Sun Jan 30 10:24:20 PST 2011
Author: baldrick
Date: Sun Jan 30 12:24:20 2011
New Revision: 124561
URL: http://llvm.org/viewvc/llvm-project?rev=124561&view=rev
Log:
Commit 124487 broke 254.gap. See if disabling the part that might be triggered
by PR9088 fixes things.
Modified:
llvm/trunk/lib/Analysis/InstructionSimplify.cpp
llvm/trunk/test/Transforms/InstSimplify/2010-12-20-Reassociate.ll
Modified: llvm/trunk/lib/Analysis/InstructionSimplify.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/InstructionSimplify.cpp?rev=124561&r1=124560&r2=124561&view=diff
==============================================================================
--- llvm/trunk/lib/Analysis/InstructionSimplify.cpp (original)
+++ llvm/trunk/lib/Analysis/InstructionSimplify.cpp Sun Jan 30 12:24:20 2011
@@ -804,11 +804,11 @@
Value *X = 0, *Y = 0;
if (match(Op0, m_Mul(m_Value(X), m_Value(Y))) && (X == Op1 || Y == Op1)) {
if (Y != Op1) std::swap(X, Y); // Ensure expression is (X * Y) / Y, Y = Op1
- BinaryOperator *Mul = cast<BinaryOperator>(Op0);
- // If the Mul knows it does not overflow, then we are good to go.
- if ((isSigned && Mul->hasNoSignedWrap()) ||
- (!isSigned && Mul->hasNoUnsignedWrap()))
- return X;
+// BinaryOperator *Mul = cast<BinaryOperator>(Op0);
+// // If the Mul knows it does not overflow, then we are good to go.
+// if ((isSigned && Mul->hasNoSignedWrap()) ||
+// (!isSigned && Mul->hasNoUnsignedWrap()))
+// return X;
// If X has the form X = A / Y then X * Y cannot overflow.
if (BinaryOperator *Div = dyn_cast<BinaryOperator>(X))
if (Div->getOpcode() == Opcode && Div->getOperand(1) == Y)
Modified: llvm/trunk/test/Transforms/InstSimplify/2010-12-20-Reassociate.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstSimplify/2010-12-20-Reassociate.ll?rev=124561&r1=124560&r2=124561&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/InstSimplify/2010-12-20-Reassociate.ll (original)
+++ llvm/trunk/test/Transforms/InstSimplify/2010-12-20-Reassociate.ll Sun Jan 30 12:24:20 2011
@@ -92,12 +92,10 @@
}
define i32 @sdiv1(i32 %x, i32 %y) {
-; CHECK: @sdiv1
; (no overflow X * Y) / Y -> X
%mul = mul nsw i32 %x, %y
%r = sdiv i32 %mul, %y
ret i32 %r
-; CHECK: ret i32 %x
}
define i32 @sdiv2(i32 %x, i32 %y) {
@@ -138,12 +136,10 @@
}
define i32 @udiv1(i32 %x, i32 %y) {
-; CHECK: @udiv1
; (no overflow X * Y) / Y -> X
%mul = mul nuw i32 %x, %y
%r = udiv i32 %mul, %y
ret i32 %r
-; CHECK: ret i32 %x
}
define i32 @udiv2(i32 %x, i32 %y) {
More information about the llvm-commits
mailing list