From f6bd07c7fe954f7676751d06a420995d2ab5b136 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 16 Sep 2006 03:14:10 +0000 Subject: [PATCH] Fix Transforms/InstCombine/2006-09-15-CastToBool.ll and PR913 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30405 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Scalar/InstructionCombining.cpp | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index 6961806bcb7..c803a18a358 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -1011,6 +1011,11 @@ bool InstCombiner::SimplifyDemandedBits(Value *V, uint64_t DemandedMask, // If this is an integer truncate or noop, just look in the input. if (SrcTy->getPrimitiveSizeInBits() >= I->getType()->getPrimitiveSizeInBits()) { + // Cast to bool is a comparison against 0, which demands all bits. We + // can't propagate anything useful up. + if (I->getType() == Type::BoolTy) + break; + if (SimplifyDemandedBits(I->getOperand(0), DemandedMask, KnownZero, KnownOne, Depth+1)) return true;