[cfe-commits] r156941 - in /cfe/trunk/test/Analysis: additive-folding.cpp comparison-implicit-casts.cpp string.c

Jordy Rose jediknil at belkadan.com
Wed May 16 13:29:44 PDT 2012


Author: jrose
Date: Wed May 16 15:29:44 2012
New Revision: 156941

URL: http://llvm.org/viewvc/llvm-project?rev=156941&view=rev
Log:
[analyzer] Fix test for PR12206, which was failing on i386.

Added:
    cfe/trunk/test/Analysis/comparison-implicit-casts.cpp
Modified:
    cfe/trunk/test/Analysis/additive-folding.cpp
    cfe/trunk/test/Analysis/string.c

Modified: cfe/trunk/test/Analysis/additive-folding.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Analysis/additive-folding.cpp?rev=156941&r1=156940&r2=156941&view=diff
==============================================================================
--- cfe/trunk/test/Analysis/additive-folding.cpp (original)
+++ cfe/trunk/test/Analysis/additive-folding.cpp Wed May 16 15:29:44 2012
@@ -186,64 +186,6 @@
 }
 
 
-// PR12206/12510 - When SimpleSValBuilder figures out that a symbol is fully
-// constrained, it should cast the value to the result type in a binary
-// operation...unless the binary operation is a comparison, in which case the
-// two arguments should be the same type, but won't match the result type.
-//
-// This is easier to trigger in C++ mode, where the comparison result type is
-// 'bool' and is thus differently sized from int on pretty much every system.
-//
-// This is not directly related to additive folding, but we use SValBuilder's
-// additive folding to tickle the bug. ExprEngine will simplify fully-constrained
-// symbols, so SValBuilder will only see them if they are (a) part of an evaluated
-// SymExpr (e.g. with additive folding) or (b) generated by a checker (e.g.
-// unix.cstring's strlen() modelling).
-void PR12206(int x) {
-  // Build a SymIntExpr, dependent on x.
-  int local = x - 1;
-
-  // Constrain the value of x.
-  int value = 1 + (1 << (8 * sizeof(1 == 1))); // not representable by bool
-  if (x != value) return;
-
-  // Constant-folding will turn (local+1) back into the symbol for x.
-  // The point of this dance is to make SValBuilder be responsible for
-  // turning the symbol into a ConcreteInt, rather than ExprEngine.
-
-  // Test relational operators.
-  clang_analyzer_eval((local + 1) >= 2); // expected-warning{{TRUE}}
-  clang_analyzer_eval(2 <= (local + 1)); // expected-warning{{TRUE}}
-
-  // Test equality operators.
-  clang_analyzer_eval((local + 1) != 1); // expected-warning{{TRUE}}
-  clang_analyzer_eval(1 != (local + 1)); // expected-warning{{TRUE}}
-}
-
-void PR12206_truncation(signed char x) {
-  // Build a SymIntExpr, dependent on x.
-  signed char local = x - 1;
-
-  // Constrain the value of x.
-  if (x != 1) return;
-
-  // Constant-folding will turn (local+1) back into the symbol for x.
-  // The point of this dance is to make SValBuilder be responsible for
-  // turning the symbol into a ConcreteInt, rather than ExprEngine.
-
-  // Construct a value that cannot be represented by 'char',
-  // but that has the same lower bits as x.
-  signed int value = 1 + (1 << 8);
-
-  // Test relational operators.
-  clang_analyzer_eval((local + 1) < value); // expected-warning{{TRUE}}
-  clang_analyzer_eval(value > (local + 1)); // expected-warning{{TRUE}}
-
-  // Test equality operators.
-  clang_analyzer_eval((local + 1) != value); // expected-warning{{TRUE}}
-  clang_analyzer_eval(value != (local + 1)); // expected-warning{{TRUE}}
-}
-
 void multiplicativeSanityTest(int x) {
   // At one point we were ignoring the *4 completely -- the constraint manager
   // would see x < 8 and then declare the assertion to be known false.

Added: cfe/trunk/test/Analysis/comparison-implicit-casts.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Analysis/comparison-implicit-casts.cpp?rev=156941&view=auto
==============================================================================
--- cfe/trunk/test/Analysis/comparison-implicit-casts.cpp (added)
+++ cfe/trunk/test/Analysis/comparison-implicit-casts.cpp Wed May 16 15:29:44 2012
@@ -0,0 +1,96 @@
+// RUN: %clang_cc1 -analyze -analyzer-checker=core,unix.cstring,debug.ExprInspection -analyzer-constraints=basic -verify %s
+// RUN: %clang_cc1 -analyze -analyzer-checker=core,unix.cstring,debug.ExprInspection -analyzer-constraints=range -verify %s
+
+// This file runs in C++ mode so that the comparison type is 'bool', not 'int'.
+void clang_analyzer_eval(int);
+typedef typeof(sizeof(int)) size_t;
+
+// PR12206/12510 - When SimpleSValBuilder figures out that a symbol is fully
+// constrained, it should cast the value to the result type in a binary
+// operation...unless the binary operation is a comparison, in which case the
+// two arguments should be the same type, but won't match the result type.
+//
+// This is not directly related to additive folding, but we use SValBuilder's
+// additive folding to tickle the bug. ExprEngine will simplify fully-constrained
+// symbols, so SValBuilder will only see them if they are (a) part of an evaluated
+// SymExpr (e.g. with additive folding) or (b) generated by a checker (e.g.
+// unix.cstring's strlen() modelling).
+void PR12206(int x) {
+  size_t comparisonSize = sizeof(1 == 1);
+
+  // Sanity check. This test is useless if size_t isn't bigger than bool.
+  clang_analyzer_eval(sizeof(size_t) > comparisonSize); // expected-warning{{TRUE}}
+
+  // Build a SymIntExpr, dependent on x.
+  int local = x - 1;
+
+  // Create a value that requires more bits to store than a comparison result.
+  int value = 1;
+  value <<= 8 * comparisonSize;
+  value += 1;
+
+  // Constrain the value of x.
+  if (x != value) return;
+
+  // Constant-folding will turn (local+1) back into the symbol for x.
+  // The point of this dance is to make SValBuilder be responsible for
+  // turning the symbol into a ConcreteInt, rather than ExprEngine.
+
+  // Test relational operators.
+  clang_analyzer_eval((local + 1) >= 2); // expected-warning{{TRUE}}
+  clang_analyzer_eval(2 <= (local + 1)); // expected-warning{{TRUE}}
+
+  // Test equality operators.
+  clang_analyzer_eval((local + 1) != 1); // expected-warning{{TRUE}}
+  clang_analyzer_eval(1 != (local + 1)); // expected-warning{{TRUE}}
+}
+
+void PR12206_truncation(signed char x) {
+  // Build a SymIntExpr, dependent on x.
+  signed char local = x - 1;
+
+  // Constrain the value of x.
+  if (x != 1) return;
+
+  // Constant-folding will turn (local+1) back into the symbol for x.
+  // The point of this dance is to make SValBuilder be responsible for
+  // turning the symbol into a ConcreteInt, rather than ExprEngine.
+
+  // Construct a value that cannot be represented by 'char',
+  // but that has the same lower bits as x.
+  signed int value = 1 + (1 << 8);
+
+  // Test relational operators.
+  clang_analyzer_eval((local + 1) < value); // expected-warning{{TRUE}}
+  clang_analyzer_eval(value > (local + 1)); // expected-warning{{TRUE}}
+
+  // Test equality operators.
+  clang_analyzer_eval((local + 1) != value); // expected-warning{{TRUE}}
+  clang_analyzer_eval(value != (local + 1)); // expected-warning{{TRUE}}
+}
+
+// This test is insurance in case we significantly change how SymExprs are
+// evaluated.
+size_t strlen(const char *s);
+void PR12206_strlen(const char *x) {
+  size_t comparisonSize = sizeof(1 == 1);
+
+  // Sanity check. This test is useless if size_t isn't bigger than bool.
+  clang_analyzer_eval(sizeof(size_t) > comparisonSize); // expected-warning{{TRUE}}
+
+  // Create a value that requires more bits to store than a comparison result.
+  size_t value = 1UL;
+  value <<= 8 * comparisonSize;
+  value += 1;
+
+  // Constrain the length of x.
+  if (strlen(x) != value) return;
+
+  // Test relational operators.
+  clang_analyzer_eval(strlen(x) >= 2); // expected-warning{{TRUE}}
+  clang_analyzer_eval(2 <= strlen(x)); // expected-warning{{TRUE}}
+
+  // Test equality operators.
+  clang_analyzer_eval(strlen(x) != 1); // expected-warning{{TRUE}}
+  clang_analyzer_eval(1 != strlen(x)); // expected-warning{{TRUE}}
+}

Modified: cfe/trunk/test/Analysis/string.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Analysis/string.c?rev=156941&r1=156940&r2=156941&view=diff
==============================================================================
--- cfe/trunk/test/Analysis/string.c (original)
+++ cfe/trunk/test/Analysis/string.c Wed May 16 15:29:44 2012
@@ -1039,34 +1039,3 @@
 void strncasecmp_embedded_null () {
 	clang_analyzer_eval(strncasecmp("ab\0zz", "ab\0yy", 4) == 0); // expected-warning{{TRUE}}
 }
-
-//===----------------------------------------------------------------------===
-// Miscellaneous extras.
-//===----------------------------------------------------------------------===
-
-// See additive-folding.cpp for a description of this bug.
-// This test is insurance in case we significantly change how SymExprs are
-// evaluated. It isn't as good as additive-folding.cpp's version
-// because it will only actually be a test on systems where
-//   sizeof(1 == 1) < sizeof(size_t).
-// We could add a triple if it becomes necessary.
-void PR12206(const char *x) {
-  // This test is only useful under these conditions.
-  size_t comparisonSize = sizeof(1 == 1);
-  if (sizeof(size_t) <= comparisonSize) return;
-
-  // Create a value that requires more bits to store than a comparison result.
-  size_t value = 1UL;
-  value <<= 8 * comparisonSize;
-  value += 1;
-
-  // Constrain the length of x.
-  if (strlen(x) != value) return;
-  // Test relational operators.
-  if (strlen(x) < 2) { (void)*(char*)0; } // no-warning
-  if (2 > strlen(x)) { (void)*(char*)0; } // no-warning
-
-  // Test equality operators.
-  if (strlen(x) == 1) { (void)*(char*)0; } // no-warning
-  if (1 == strlen(x)) { (void)*(char*)0; } // no-warning
-}





More information about the cfe-commits mailing list