]> granicus.if.org Git - clang/commitdiff
Initialize tracked local variables to undefined.
authorTed Kremenek <kremenek@apple.com>
Wed, 13 Aug 2008 03:28:04 +0000 (03:28 +0000)
committerTed Kremenek <kremenek@apple.com>
Wed, 13 Aug 2008 03:28:04 +0000 (03:28 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@54716 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/GRExprEngine.cpp
lib/Analysis/SymbolManager.cpp

index f0c0d8dd9e87bf764ecd4d8d68a69a727f813b5e..a31c435786a0148aa0a91e59e09accd5d8cc3384 100644 (file)
@@ -202,10 +202,15 @@ const ValueState* GRExprEngine::getInitialState() {
     
     ScopedDecl *SD = const_cast<ScopedDecl*>(I->first);
     if (VarDecl* VD = dyn_cast<VarDecl>(SD)) {
-      if (VD->hasGlobalStorage() || isa<ParmVarDecl>(VD)) {
-        RVal X = RVal::GetSymbolValue(SymMgr, VD);
-        StateMgr.SetRVal(StateImpl, lval::DeclVal(VD), X);
-      }
+      // Initialize globals and parameters to symbolic values.
+      // Initialize local variables to undefined.
+      RVal X = (VD->hasGlobalStorage() || isa<ParmVarDecl>(VD) ||
+                isa<ImplicitParamDecl>(VD))
+             ? RVal::GetSymbolValue(SymMgr, VD)
+             : UndefinedVal();
+      
+      StateMgr.SetRVal(StateImpl, lval::DeclVal(VD), X);
+      
     } else if (ImplicitParamDecl *IPD = dyn_cast<ImplicitParamDecl>(SD)) {
         RVal X = RVal::GetSymbolValue(SymMgr, IPD);
       StateMgr.SetRVal(StateImpl, lval::DeclVal(IPD), X);
index f243fa667b33bbe0dbb477785d6b852b6d0252e5..beb4379f99a44eb4a95555f6126a1b646ec6df57 100644 (file)
@@ -18,7 +18,8 @@ using namespace clang;
 
 SymbolID SymbolManager::getSymbol(VarDecl* D) {
 
-  assert (isa<ParmVarDecl>(D) || D->hasGlobalStorage());
+  assert (isa<ParmVarDecl>(D) || isa<ImplicitParamDecl>(D) || 
+          D->hasGlobalStorage());
   
   llvm::FoldingSetNodeID profile;