From: Ted Kremenek Date: Wed, 18 Mar 2009 23:49:26 +0000 (+0000) Subject: Fix PR 3836 by eagerly assuming symbolic constraints returned by unary '!'. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=72374594c5d9ade02451bc85cf9dfa5b0ea106e7;p=clang Fix PR 3836 by eagerly assuming symbolic constraints returned by unary '!'. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67260 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/GRExprEngine.cpp b/lib/Analysis/GRExprEngine.cpp index 6d360ed503..1f47bc7f33 100644 --- a/lib/Analysis/GRExprEngine.cpp +++ b/lib/Analysis/GRExprEngine.cpp @@ -394,9 +394,17 @@ void GRExprEngine::Visit(Stmt* S, NodeTy* Pred, NodeSet& Dst) { VisitLValue(cast(S), Pred, Dst); break; - case Stmt::UnaryOperatorClass: - VisitUnaryOperator(cast(S), Pred, Dst, false); + case Stmt::UnaryOperatorClass: { + UnaryOperator *U = cast(S); + if (EagerlyAssume && (U->getOpcode() == UnaryOperator::LNot)) { + NodeSet Tmp; + VisitUnaryOperator(U, Pred, Tmp, false); + EvalEagerlyAssume(Dst, Tmp, U); + } + else + VisitUnaryOperator(U, Pred, Dst, false); break; + } } } diff --git a/test/Analysis/misc-ps-eager-assume.m b/test/Analysis/misc-ps-eager-assume.m index c36ae8f4d6..4dd8f2536c 100644 --- a/test/Analysis/misc-ps-eager-assume.m +++ b/test/Analysis/misc-ps-eager-assume.m @@ -61,3 +61,19 @@ void handle_symbolic_cast_in_condition(void) { [pool drain]; } + +// From PR 3836 (http://llvm.org/bugs/show_bug.cgi?id=3836) +// +// In this test case, the double '!' works fine with our symbolic constraints, +// but we don't support comparing SymConstraint != SymConstraint. By eagerly +// assuming the truth of !!a or !!b, we can compare these values directly. +// +void pr3836(int *a, int *b) { + if (!!a != !!b) /* one of them is NULL */ + return; + if (!a && !b) /* both are NULL */ + return; + + *a = 1; // no-warning + *b = 1; // no-warning +}