From: Zhongxing Xu Date: Tue, 16 Jun 2009 06:18:21 +0000 (+0000) Subject: Do not invalidate unboundable regions in GRSimpleVals::EvalCall(). X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=78d5b5e738c81b596f20205437120d5f3d7c5d9e;p=clang Do not invalidate unboundable regions in GRSimpleVals::EvalCall(). git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@73474 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/GRSimpleVals.cpp b/lib/Analysis/GRSimpleVals.cpp index e1c4848f45..d8d312f23f 100644 --- a/lib/Analysis/GRSimpleVals.cpp +++ b/lib/Analysis/GRSimpleVals.cpp @@ -365,9 +365,11 @@ void GRSimpleVals::EvalCall(ExplodedNodeSet& Dst, SVal V = StateMgr.GetSVal(St, *I); - if (isa(V)) - St = StateMgr.BindLoc(St, cast(V), UnknownVal()); - else if (isa(V)) + if (isa(V)) { + const MemRegion *R = cast(V).getRegion(); + if (R->isBoundable(Eng.getContext())) + St = StateMgr.BindLoc(St, cast(V), UnknownVal()); + } else if (isa(V)) St = StateMgr.BindLoc(St, cast(V).getLoc(), UnknownVal()); diff --git a/test/Analysis/func.c b/test/Analysis/func.c index ac067a9810..a018d0afc1 100644 --- a/test/Analysis/func.c +++ b/test/Analysis/func.c @@ -1,4 +1,5 @@ // RUN: clang-cc -analyze -checker-simple -verify %s && +// RUN: clang-cc -analyze -checker-simple -analyzer-store=region -verify %s && // RUN: clang-cc -analyze -checker-cfref -analyzer-store=basic -verify %s && // RUN: clang-cc -analyze -checker-cfref -analyzer-store=region -verify %s