]> granicus.if.org Git - clang/commitdiff
Enhance RegionStore to lazily symbolicate fields and array elements for
authorTed Kremenek <kremenek@apple.com>
Thu, 2 Jul 2009 22:02:15 +0000 (22:02 +0000)
committerTed Kremenek <kremenek@apple.com>
Thu, 2 Jul 2009 22:02:15 +0000 (22:02 +0000)
structures passed-by-value as function arguments.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@74729 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/MemRegion.cpp
lib/Analysis/RegionStore.cpp
test/Analysis/stack-addr-ps.c

index 52e26238d9574d8804655d18d224750087ad55e3..45305403585a886c0f9647709e15dc1e4feb43f9 100644 (file)
@@ -368,6 +368,13 @@ bool MemRegion::hasGlobalsStorage() const {
   return false;
 }
 
+bool MemRegion::hasParametersStorage() const {
+  if (const MemSpaceRegion *MS = getMemorySpace())
+    return MS == getMemRegionManager()->getStackArgumentsRegion();
+  
+  return false;
+}
+
 bool MemRegion::hasGlobalsOrParametersStorage() const {
   if (const MemSpaceRegion *MS = getMemorySpace()) {
     MemRegionManager *Mgr = getMemRegionManager();
index 9c76265fa392334269720124319fb4ff39d809ba..5729103fd3ac31c5a69503c82815481cfc0fc075 100644 (file)
@@ -959,7 +959,7 @@ SVal RegionStoreManager::RetrieveElement(const GRState* state,
     return UndefinedVal();
   }
 
-  if (R->hasStackStorage()) {
+  if (R->hasStackStorage() && !R->hasParametersStorage()) {
     // Currently we don't reason specially about Clang-style vectors.  Check
     // if superR is a vector and if so return Unknown.
     if (const TypedRegion *typedSuperR = dyn_cast<TypedRegion>(superR)) {
@@ -1006,7 +1006,11 @@ SVal RegionStoreManager::RetrieveField(const GRState* state,
     assert(0 && "Unknown default value");
   }
 
-  if (R->hasHeapOrStackStorage())
+  // FIXME: Is this correct?  Should it be UnknownVal?
+  if (R->hasHeapStorage())
+    return UndefinedVal();
+  
+  if (R->hasStackStorage() && !R->hasParametersStorage())
     return UndefinedVal();
 
   // If the region is already cast to another type, use that type to create the
index 848adc8d9feec1bcb37389fe17221f7995a8f3a1..0d7a70373c9a5edcc4ae5c7d8009485b6e288fea 100644 (file)
@@ -1,6 +1,5 @@
-// RUN: clang-cc -analyze -checker-cfref -analyzer-store=basic -verify %s
-
-// NOWORK: clang-cc -analyze -checker-cfref -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
 
 #include <stdlib.h>
 
@@ -46,9 +45,15 @@ int array_test(int x[2]) {
   return x[0]; // no-warning
 }
 
-struct baz { int x; };
-
-int struct_test(struct baz byVal) {
-  return byVal.x; // no-warning;
+struct baz {
+  int x;
+  int y[2];
+};
+
+int struct_test(struct baz byVal, int flag) {
+  if (flag)  
+    return byVal.x; // no-warning
+  else {
+    return byVal.y[0]; // no-warning
+  }
 }
-