diff options
author | Zhongxing Xu <xuzhongxing@gmail.com> | 2009-05-20 09:18:48 +0000 |
---|---|---|
committer | Zhongxing Xu <xuzhongxing@gmail.com> | 2009-05-20 09:18:48 +0000 |
commit | 918441255162c1a1c77c13752aaa1a3c43ac2ab9 (patch) | |
tree | f1274af71224d46b41689afc680f587b75309840 | |
parent | 2acc3992b61e71d30653bf19be2479a78e4cd7a1 (diff) |
Treat AllocaRegion as SymbolicRegion in RegionStore::Retrieve().
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@72166 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Analysis/RegionStore.cpp | 7 | ||||
-rw-r--r-- | test/Analysis/array-struct.c | 5 |
2 files changed, 9 insertions, 3 deletions
diff --git a/lib/Analysis/RegionStore.cpp b/lib/Analysis/RegionStore.cpp index be34bd57b8..02d3d1f885 100644 --- a/lib/Analysis/RegionStore.cpp +++ b/lib/Analysis/RegionStore.cpp @@ -705,10 +705,13 @@ SVal RegionStoreManager::Retrieve(const GRState* St, Loc L, QualType T) { const MemRegion* MR = cast<loc::MemRegionVal>(L).getRegion(); - // We return unknown for symbolic region for now. This might be improved. + // FIXME: return symbolic value for these cases. // Example: // void f(int* p) { int x = *p; } - if (isa<SymbolicRegion>(MR)) + // char* p = alloca(); + // read(p); + // c = *p; + if (isa<SymbolicRegion>(MR) || isa<AllocaRegion>(MR)) return UnknownVal(); // FIXME: Perhaps this method should just take a 'const MemRegion*' argument diff --git a/test/Analysis/array-struct.c b/test/Analysis/array-struct.c index e602d5f527..c0e1d8b7e3 100644 --- a/test/Analysis/array-struct.c +++ b/test/Analysis/array-struct.c @@ -15,6 +15,7 @@ typedef struct { int data; } STYPE; +void g(char *p); void g1(struct s* p); // Array to pointer conversion. Array in the struct field. @@ -62,6 +63,8 @@ void f5() { void f6() { char *p; p = __builtin_alloca(10); + g(p); + char c = *p; p[1] = 'a'; // Test if RegionStore::EvalBinOp converts the alloca region to element // region. @@ -98,7 +101,7 @@ void f10() { // Retrieve the default value of element/field region. void f11() { struct s a; - g(&a); + g1(&a); if (a.data == 0) // no-warning a.data = 1; } |