From: Zhongxing Xu Date: Sat, 9 May 2009 15:34:29 +0000 (+0000) Subject: When casting VarRegion, if the var type is aggregate type and the cast-to X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=5bf3287765d14b5c6666bd00d0a141b0a6c97a20;p=clang When casting VarRegion, if the var type is aggregate type and the cast-to pointee type is scalar type, create element region regardless with the sizes of types. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71360 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/RegionStore.cpp b/lib/Analysis/RegionStore.cpp index 0fc24a9a2b..a66e63c877 100644 --- a/lib/Analysis/RegionStore.cpp +++ b/lib/Analysis/RegionStore.cpp @@ -616,7 +616,8 @@ RegionStoreManager::CastRegion(const GRState* state, const MemRegion* R, uint64_t PointeeTySize = getContext().getTypeSize(PointeeTy); uint64_t ObjTySize = getContext().getTypeSize(ObjTy); - if (PointeeTySize > 0 && PointeeTySize < ObjTySize) { + if ((PointeeTySize > 0 && PointeeTySize < ObjTySize) || + (ObjTy->isAggregateType() && PointeeTy->isScalarType())) { // Record the cast type of the region. state = setCastType(state, R, ToTy); diff --git a/test/Analysis/fields.c b/test/Analysis/fields.c index 8b88578a0e..c012a9da7b 100644 --- a/test/Analysis/fields.c +++ b/test/Analysis/fields.c @@ -1,6 +1,5 @@ // RUN: clang-cc -analyze -checker-cfref %s --analyzer-store=basic -verify && // RUN: clang-cc -analyze -checker-cfref %s --analyzer-store=region -verify -// XFAIL unsigned foo(); typedef struct bf { unsigned x:2; } bf;