aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2020-05-27 13:05:07 +0200
committerGiuliano Belinassi <giuliano.belinassi@usp.br>2020-08-17 13:09:07 -0300
commite9af3b9faae621c51052c317b4ce11cef0155f6a (patch)
treef612d272364d06defd1a894e948d70353a08adef
parent9196de6c3b5b6392340cccb42f28e27eb1ec5942 (diff)
downloadgcc-e9af3b9faae621c51052c317b4ce11cef0155f6a.zip
gcc-e9af3b9faae621c51052c317b4ce11cef0155f6a.tar.gz
gcc-e9af3b9faae621c51052c317b4ce11cef0155f6a.tar.bz2
tree-optimization/95295 - fix sinking after path merging in new SM code
This fixes a missed sinking of remat stores across unrelated stores after merging from different paths. 2020-05-27 Richard Biener <rguenther@suse.de> PR tree-optimization/95295 * tree-ssa-loop-im.c (sm_seq_valid_bb): Fix sinking after merging stores from paths. * gcc.dg/torture/pr95295-3.c: New testcase.
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr95295-3.c16
-rw-r--r--gcc/tree-ssa-loop-im.c8
2 files changed, 22 insertions, 2 deletions
diff --git a/gcc/testsuite/gcc.dg/torture/pr95295-3.c b/gcc/testsuite/gcc.dg/torture/pr95295-3.c
new file mode 100644
index 0000000..a506af9
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr95295-3.c
@@ -0,0 +1,16 @@
+/* { dg-do compile } */
+
+extern short var_15, var_20;
+extern int var_18, var_21, var_23;
+extern _Bool arr_2[];
+extern long arr_3[];
+void test()
+{
+ var_20 = 1;
+ for (int a = 0; a < 12; a += 2)
+ for (short b = 0; b < 8; b += 2) {
+ arr_2[b] = var_21 = var_18 ? var_15 : 0;
+ arr_3[b] = 8569;
+ }
+ var_23 = -1096835496;
+}
diff --git a/gcc/tree-ssa-loop-im.c b/gcc/tree-ssa-loop-im.c
index b399bd0..d33f533 100644
--- a/gcc/tree-ssa-loop-im.c
+++ b/gcc/tree-ssa-loop-im.c
@@ -2447,12 +2447,16 @@ sm_seq_valid_bb (class loop *loop, basic_block bb, tree vdef,
unsigned id = first_edge_seq[i].first;
seq.safe_push (first_edge_seq[i]);
unsigned new_idx;
- if (first_edge_seq[i].second == sm_ord
+ if ((first_edge_seq[i].second == sm_ord
+ || (first_edge_seq[i].second == sm_other
+ && first_edge_seq[i].from != NULL_TREE))
&& !sm_seq_push_down (seq, seq.length () - 1, &new_idx))
{
- bitmap_set_bit (refs_not_supported, id);
+ if (first_edge_seq[i].second == sm_ord)
+ bitmap_set_bit (refs_not_supported, id);
/* Mark it sm_other. */
seq[new_idx].second = sm_other;
+ seq[new_idx].from = NULL_TREE;
}
}
return 1;