invoke.texi (ssa-name-def-chain-limit): Document new --param.
authorMartin Sebor <msebor@redhat.com>
Fri, 12 Jul 2019 17:36:45 +0000 (17:36 +0000)
committerMartin Sebor <msebor@gcc.gnu.org>
Fri, 12 Jul 2019 17:36:45 +0000 (11:36 -0600)
gcc/ChangeLog:

* doc/invoke.texi (ssa-name-def-chain-limit): Document new --param.
* params.def (PARAM_SSA_NAME_DEF_CHAIN_LIMIT): Add new --param.
* tree-vrp.c (vrp_prop::check_mem_ref): Use
PARAM_SSA_NAME_DEF_CHAIN_LIMIT.

gcc/testsuite/ChangeLog:

* gcc.dg/Warray-bounds-43.c: New test.

From-SVN: r273454

gcc/ChangeLog
gcc/doc/invoke.texi
gcc/params.def
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/Warray-bounds-43.c [new file with mode: 0644]
gcc/tree-vrp.c

index 37b5eafa598064aa18ae3d4a46e47590a08781a1..685c7793f0e0fa25fa23881d91fe4acb56f38de8 100644 (file)
@@ -1,3 +1,10 @@
+2019-07-12  Martin Sebor  <msebor@redhat.com>
+
+       * doc/invoke.texi (ssa-name-def-chain-limit): Document new --param.
+       * params.def (PARAM_SSA_NAME_DEF_CHAIN_LIMIT): Add new --param.
+       * tree-vrp.c (vrp_prop::check_mem_ref): Use
+       PARAM_SSA_NAME_DEF_CHAIN_LIMIT.
+
 2019-07-12  Jan Hubicka  <jh@suse.cz>
 
        * tree-ssa-alias.c (same_tmr_indexing_p): Break out from ...
@@ -28,7 +35,6 @@
        rather than this_state as the lowering context for the ELSE
        seq in a GIMPLE_EH_ELSE.
 
->>>>>>> .r273450
 2019-07-12  Richard Sandiford  <richard.sandiford@arm.com>
 
        * vector-builder.h (vector_builder::elt): Allow already-supplied
index 0c20cb6814eeeeae513cef0586029312342bea3b..b4e71f2c8fd87c0392c31b21b1c7a54f67c2b73f 100644 (file)
@@ -12225,6 +12225,13 @@ before the loop versioning pass considers it too big to copy,
 discounting any instructions in inner loops that directly benefit
 from versioning.
 
+@item ssa-name-def-chain-limit
+The maximum number of SSA_NAME assignments to follow in determining
+a property of a variable such as its value.  This limits the number
+of iterations or recursive calls GCC performs when optimizing certain
+statements or when determining their validity prior to issuing
+diagnostics.
+
 @end table
 @end table
 
index 4567c17ba60335ee2eb4ad25f4d6bd96d0bf5435..c56055da9d94f98695f938c5a600f0646028fa4b 100644 (file)
@@ -1437,6 +1437,12 @@ DEFPARAM(PARAM_HASH_TABLE_VERIFICATION_LIMIT,
         "each searched element.",
         10, 0, 0)
 
+DEFPARAM(PARAM_SSA_NAME_DEF_CHAIN_LIMIT,
+        "ssa-name-def-chain-limit",
+        "The maximum number of SSA_NAME assignments to follow in determining "
+        "a value.",
+        512, 0, 0)
+
 /*
 
 Local variables:
index 4d6eb0ff648574ed46576e9f76159012ee48d733..73fe73933b0d9023c0ea23b33e2c9769345a6ef6 100644 (file)
@@ -1,3 +1,7 @@
+2019-07-12  Martin Sebor  <msebor@redhat.com>
+
+       * gcc.dg/Warray-bounds-43.c: New test.
+
 2019-07-12  Jan Hubicka  <jh@suse.cz>
 
        * gcc.dg/tree-ssa/alias-access-path-9.c: New testcase.
diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-43.c b/gcc/testsuite/gcc.dg/Warray-bounds-43.c
new file mode 100644 (file)
index 0000000..8892921
--- /dev/null
@@ -0,0 +1,133 @@
+/* Test to verify that --param ssa_name_def_chain_limit can be used to
+   limit the maximum number of SSA_NAME assignments the warning follows.
+   { dg-do compile }
+   { dg-options "-O2 -Wall --param ssa-name-def-chain-limit=4" }  */
+
+#define NOIPA __attribute__ ((noipa))
+
+const char a0[] = "";
+const char a1[] = "1";
+const char a2[] = "12";
+const char a3[] = "123";
+const char a4[] = "1234";
+const char a5[] = "12345";
+const char a6[] = "123456";
+const char a7[] = "1234567";
+const char a8[] = "12345678";
+const char a9[] = "123456789";
+
+void f (const char*, ...);
+
+int i0, i1, i2, i3, i4, i5, i6, i7, i8;
+
+NOIPA int g2 (int i)
+{
+  if (i < 1) i = 1;
+
+  const char *p0 = a9;
+  const char *p1 = p0 + i;
+  const char *p2 = p1 + i;
+
+  f (p0, p1, p2);
+
+  return p2[8];     // { dg-warning "\\\[-Warray-bounds]" }
+}
+
+NOIPA int g3 (int i)
+{
+  if (i < 1) i = 1;
+
+  const char *p0 = a9;
+  const char *p1 = p0 + i;
+  const char *p2 = p1 + i;
+  const char *p3 = p2 + i;
+
+  f (p0, p1, p2, p3);
+
+  return p3[7];     // { dg-warning "\\\[-Warray-bounds]" }
+}
+
+NOIPA int g4 (int i)
+{
+  if (i < 1) i = 1;
+
+  const char *p0 = a9;
+  const char *p1 = p0 + i;
+  const char *p2 = p1 + i;
+  const char *p3 = p2 + i;
+  const char *p4 = p3 + i;
+
+  f (p0, p1, p2, p3, p4);
+
+  return p4[6];     // { dg-warning "\\\[-Warray-bounds]" }
+}
+
+NOIPA int g5 (int i)
+{
+  if (i < 1) i = 1;
+
+  const char *p0 = a9;
+  const char *p1 = p0 + i;
+  const char *p2 = p1 + i;
+  const char *p3 = p2 + i;
+  const char *p4 = p3 + i;
+  const char *p5 = p4 + i;
+
+  f (p0, p1, p2, p3, p4, p5);
+
+  return p5[5];
+}
+
+NOIPA int g6 (int i)
+{
+  if (i < 1) i = 1;
+
+  const char *p0 = a9;
+  const char *p1 = p0 + i;
+  const char *p2 = p1 + i;
+  const char *p3 = p2 + i;
+  const char *p4 = p3 + i;
+  const char *p5 = p4 + i;
+  const char *p6 = p5 + i;
+
+  f (p0, p1, p2, p3, p4, p5, p6);
+
+  return p6[4];
+}
+
+NOIPA int g7 (int i)
+{
+  if (i < 1) i = 1;
+
+  const char *p0 = a9;
+  const char *p1 = p0 + i;
+  const char *p2 = p1 + i;
+  const char *p3 = p2 + i;
+  const char *p4 = p3 + i;
+  const char *p5 = p4 + i;
+  const char *p6 = p5 + i;
+  const char *p7 = p6 + i;
+
+  f (p0, p1, p2, p3, p4, p5, p6, p7);
+
+  return p7[3];
+}
+
+NOIPA int g8 (int i)
+{
+  if (i < 1) i = 1;
+
+  const char *p0 = a9;
+  const char *p1 = p0 + i;
+  const char *p2 = p1 + i;
+  const char *p3 = p2 + i;
+  const char *p4 = p3 + i;
+  const char *p5 = p4 + i;
+  const char *p6 = p5 + i;
+  const char *p7 = p6 + i;
+  const char *p8 = p7 + i;
+
+  f (p0, p1, p2, p3, p4, p5, p6, p7, p8);
+
+  return p8[2];
+}
index 594ee9adc17d6a904bc44a4bcecb909aa8f524c7..b79dfb261ae6813ba42b455b0b461bc8edae66e2 100644 (file)
@@ -4492,7 +4492,8 @@ vrp_prop::check_mem_ref (location_t location, tree ref,
      The loop computes the range of the final offset for expressions such
      as (A + i0 + ... + iN)[CSTOFF] where i0 through iN are SSA_NAMEs in
      some range.  */
-  while (TREE_CODE (arg) == SSA_NAME)
+  const unsigned limit = PARAM_VALUE (PARAM_SSA_NAME_DEF_CHAIN_LIMIT);
+  for (unsigned n = 0; TREE_CODE (arg) == SSA_NAME && n < limit; ++n)
     {
       gimple *def = SSA_NAME_DEF_STMT (arg);
       if (!is_gimple_assign (def))