From 70c2039b39506cc3277c909aeb2061bd95b0b2d0 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 27 Oct 2004 05:57:15 +0000 Subject: [PATCH] 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? :) llvm-svn: 17276 --- llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 61acad04f328..f8f0573395df 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/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()); } }