aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog8
-rw-r--r--gcc/tree-ssa-loop-im.c4
2 files changed, 10 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index d4d2c11..9706455 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,6 +1,12 @@
+2017-06-09 Richard Biener <rguenther@suse.de>
+
+ * tree-ssa-loop-im.c (execute_sm): Do not force multi-threaded
+ model if the ref is always written to.
+
2017-06-09 Tamar Christina <tamar.christina@arm.com>
- * config/arm/arm.c (arm_rtx_costs_internal): Make sdiv more expensive than udiv.
+ * config/arm/arm.c (arm_rtx_costs_internal): Make sdiv more expensive
+ than udiv.
2017-06-09 Tom de Vries <tom@codesourcery.com>
diff --git a/gcc/tree-ssa-loop-im.c b/gcc/tree-ssa-loop-im.c
index 2dcb85d..e92eaa6 100644
--- a/gcc/tree-ssa-loop-im.c
+++ b/gcc/tree-ssa-loop-im.c
@@ -198,6 +198,7 @@ static bitmap_obstack lim_bitmap_obstack;
static obstack mem_ref_obstack;
static bool ref_indep_loop_p (struct loop *, im_mem_ref *, struct loop *);
+static bool ref_always_accessed_p (struct loop *, im_mem_ref *, bool);
/* Minimum cost of an expensive expression. */
#define LIM_EXPENSIVE ((unsigned) PARAM_VALUE (PARAM_LIM_EXPENSIVE))
@@ -2025,7 +2026,8 @@ execute_sm (struct loop *loop, vec<edge> exits, im_mem_ref *ref)
for_each_index (&ref->mem.ref, force_move_till, &fmt_data);
if (bb_in_transaction (loop_preheader_edge (loop)->src)
- || !PARAM_VALUE (PARAM_ALLOW_STORE_DATA_RACES))
+ || (! PARAM_VALUE (PARAM_ALLOW_STORE_DATA_RACES)
+ && ! ref_always_accessed_p (loop, ref, true)))
multi_threaded_model_p = true;
if (multi_threaded_model_p)