From: Chris Lattner Date: Wed, 27 Oct 2004 05:57:15 +0000 (+0000) Subject: Hrm, this code was severely botched. As it turns out, this patch: X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=dc781222425c688e2c75a871f6abecaa30392b88;p=oota-llvm.git Hrm, this code was severely botched. As it turns out, this patch: http://mail.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20041018/019708.html exposed ANOTHER latent bug in this xform, which caused Prolangs-C/bison to fill the zion nightly tester disk up and make the tester barf. This is obviously not a good thing, so lets fix this bug shall we? :) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17276 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index 61acad04f32..f8f0573395d 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -1294,6 +1294,10 @@ Instruction *InstCombiner::OptAndOp(Instruction *Op, ShVal = InsertNewInstBefore(new ShiftInst(Instruction::Shr, ShVal, OpRHS, Op->getName()), TheAnd); + Value *AndRHS2 = ConstantExpr::getCast(AndRHS, ShVal->getType()); + ShVal = InsertNewInstBefore(BinaryOperator::createAnd(ShVal, AndRHS2, + TheAnd.getName()), + TheAnd); return new CastInst(ShVal, Op->getType()); } }