vabridgers updated this revision to Diff 481809. vabridgers added a comment.
update commit header Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D139759/new/ https://reviews.llvm.org/D139759 Files: clang/include/clang/StaticAnalyzer/Core/PathSensitive/BasicValueFactory.h clang/test/Analysis/fixed-point.c Index: clang/test/Analysis/fixed-point.c =================================================================== --- /dev/null +++ clang/test/Analysis/fixed-point.c @@ -0,0 +1,10 @@ +// RUN: %clang_analyze_cc1 -ffixed-point \ +// RUN: -analyzer-checker=core,debug.ExprInspection -Wno-unused -verify %s + +// expected-no-diagnostics + +long a(int c) { + (long _Accum) c >> 4; + return c; +} + Index: clang/include/clang/StaticAnalyzer/Core/PathSensitive/BasicValueFactory.h =================================================================== --- clang/include/clang/StaticAnalyzer/Core/PathSensitive/BasicValueFactory.h +++ clang/include/clang/StaticAnalyzer/Core/PathSensitive/BasicValueFactory.h @@ -152,7 +152,8 @@ T = AT->getValueType(); } - assert(T->isIntegralOrEnumerationType() || Loc::isLocType(T)); + assert(T->isIntegralOrEnumerationType() || T->isFixedPointType() || + Loc::isLocType(T)); return APSIntType(Ctx.getIntWidth(T), !T->isSignedIntegerOrEnumerationType()); }
Index: clang/test/Analysis/fixed-point.c =================================================================== --- /dev/null +++ clang/test/Analysis/fixed-point.c @@ -0,0 +1,10 @@ +// RUN: %clang_analyze_cc1 -ffixed-point \ +// RUN: -analyzer-checker=core,debug.ExprInspection -Wno-unused -verify %s + +// expected-no-diagnostics + +long a(int c) { + (long _Accum) c >> 4; + return c; +} + Index: clang/include/clang/StaticAnalyzer/Core/PathSensitive/BasicValueFactory.h =================================================================== --- clang/include/clang/StaticAnalyzer/Core/PathSensitive/BasicValueFactory.h +++ clang/include/clang/StaticAnalyzer/Core/PathSensitive/BasicValueFactory.h @@ -152,7 +152,8 @@ T = AT->getValueType(); } - assert(T->isIntegralOrEnumerationType() || Loc::isLocType(T)); + assert(T->isIntegralOrEnumerationType() || T->isFixedPointType() || + Loc::isLocType(T)); return APSIntType(Ctx.getIntWidth(T), !T->isSignedIntegerOrEnumerationType()); }
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits