r187132 - [analyzer] Weaken assertion to account for pointer-to-integer casts.
Jordan Rose
jordan_rose at apple.com
Thu Jul 25 10:22:02 PDT 2013
Author: jrose
Date: Thu Jul 25 12:22:02 2013
New Revision: 187132
URL: http://llvm.org/viewvc/llvm-project?rev=187132&view=rev
Log:
[analyzer] Weaken assertion to account for pointer-to-integer casts.
PR16690
Modified:
cfe/trunk/lib/StaticAnalyzer/Core/SValBuilder.cpp
cfe/trunk/test/Analysis/casts.m
Modified: cfe/trunk/lib/StaticAnalyzer/Core/SValBuilder.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/StaticAnalyzer/Core/SValBuilder.cpp?rev=187132&r1=187131&r2=187132&view=diff
==============================================================================
--- cfe/trunk/lib/StaticAnalyzer/Core/SValBuilder.cpp (original)
+++ cfe/trunk/lib/StaticAnalyzer/Core/SValBuilder.cpp Thu Jul 25 12:22:02 2013
@@ -412,7 +412,7 @@ SVal SValBuilder::evalCast(SVal val, Qua
return makeNonLoc(Sym, BO_NE, BVF.getValue(0, Sym->getType()), castTy);
}
- assert(val.getAs<Loc>());
+ assert(val.getAs<Loc>() || val.getAs<nonloc::LocAsInteger>());
return makeTruthVal(true, castTy);
}
Modified: cfe/trunk/test/Analysis/casts.m
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Analysis/casts.m?rev=187132&r1=187131&r2=187132&view=diff
==============================================================================
--- cfe/trunk/test/Analysis/casts.m (original)
+++ cfe/trunk/test/Analysis/casts.m Thu Jul 25 12:22:02 2013
@@ -1,9 +1,7 @@
// RUN: %clang_cc1 -analyze -analyzer-checker=core,alpha.core -analyzer-store=region -verify %s
// expected-no-diagnostics
-// Test function pointer casts. Currently we track function addresses using
-// loc::FunctionVal. Because casts can be arbitrary, do we need to model
-// functions with regions?
+// Test function pointer casts.
typedef void* (*MyFuncTest1)(void);
MyFuncTest1 test1_aux(void);
@@ -14,8 +12,7 @@ void test1(void) {
if (p != ((void*) 0)) x = (*p)();
}
-// Test casts from void* to function pointers. Same issue as above:
-// should we eventually model function pointers using regions?
+// Test casts from void* to function pointers.
void* test2(void *p) {
MyFuncTest1 fp = (MyFuncTest1) p;
return (*fp)();
@@ -41,3 +38,9 @@ adium_media_ready_cb(RDR10087620 *InObj)
{
InObj.elem |= EEOne;
}
+
+
+// PR16690
+_Bool testLocAsIntegerToBool() {
+ return (long long)&testLocAsIntegerToBool;
+}
More information about the cfe-commits
mailing list