aboutsummaryrefslogtreecommitdiff
path: root/lib/Analysis/GRExprEngine.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2009-03-05 22:47:06 +0000
committerTed Kremenek <kremenek@apple.com>2009-03-05 22:47:06 +0000
commit5c42f9ba44094eb1a05f8d36c5479645ffbb3c7b (patch)
tree7b7805d9b7061c4053c8d80a1b8c48548e83e6b3 /lib/Analysis/GRExprEngine.cpp
parent247936605913c718f4141f845aec6cb6e169fb37 (diff)
Fix another GRExprEngine::VisitCast regression: handle casts of void* to function pointers.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@66211 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/GRExprEngine.cpp')
-rw-r--r--lib/Analysis/GRExprEngine.cpp17
1 files changed, 16 insertions, 1 deletions
diff --git a/lib/Analysis/GRExprEngine.cpp b/lib/Analysis/GRExprEngine.cpp
index c2e898abe3..a4163bdeaf 100644
--- a/lib/Analysis/GRExprEngine.cpp
+++ b/lib/Analysis/GRExprEngine.cpp
@@ -1818,7 +1818,14 @@ void GRExprEngine::VisitCast(Expr* CastE, Expr* Ex, NodeTy* Pred, NodeSet& Dst){
}
// Check for casts from a region to a specific type.
- if (loc::MemRegionVal *RV = dyn_cast<loc::MemRegionVal>(&V)) {
+ if (loc::MemRegionVal *RV = dyn_cast<loc::MemRegionVal>(&V)) {
+ // FIXME: For TypedViewRegions, we should handle the case where the
+ // underlying symbolic pointer is a function pointer or
+ // block pointer.
+
+ // FIXME: We should handle the case where we strip off view layers to get
+ // to a desugared type.
+
assert(Loc::IsLocType(T));
assert(Loc::IsLocType(ExTy));
@@ -1848,6 +1855,14 @@ void GRExprEngine::VisitCast(Expr* CastE, Expr* Ex, NodeTy* Pred, NodeSet& Dst){
// Just pass through symbols that are function or block pointers.
if (SymTy->isFunctionPointerType() || SymTy->isBlockPointerType())
goto PassThrough;
+
+ // Are we casting to a function or block pointer?
+ if (T->isFunctionPointerType() || T->isBlockPointerType()) {
+ // FIXME: We should verify that the underlying type of the symbolic
+ // pointer is a void* (or maybe char*). Other things are an abuse
+ // of the type system.
+ goto PassThrough;
+ }
StoreManager& StoreMgr = getStoreManager();
const MemRegion* R =