aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2020-06-29 13:53:51 +0200
committerRichard Biener <rguenther@suse.de>2020-06-29 14:40:52 +0200
commit9a4a52e359ba16a2516a735dca838af512b19336 (patch)
tree42b59546c5d5299ac508614e13bf09dbfc02af98 /gcc
parent008842d741e5a88b8f46c692cf09e83d1f51252c (diff)
downloadgcc-9a4a52e359ba16a2516a735dca838af512b19336.zip
gcc-9a4a52e359ba16a2516a735dca838af512b19336.tar.gz
gcc-9a4a52e359ba16a2516a735dca838af512b19336.tar.bz2
tree-optimization/95916 - treat scalar ops explicitely
This explicitely treats the case of scalar operands for SLP when computing insert locations. 2020-06-29 Richard Biener <rguenther@suse.de> PR tree-optimization/95916 * tree-vect-slp.c (vect_schedule_slp_instance): Explicitely handle the case of not vectorized externals. * gcc.dg/vect/pr95916.c: New testcase.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/gcc.dg/vect/pr95916.c13
-rw-r--r--gcc/tree-vect-slp.c15
2 files changed, 28 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.dg/vect/pr95916.c b/gcc/testsuite/gcc.dg/vect/pr95916.c
new file mode 100644
index 0000000..61b8ca3
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/vect/pr95916.c
@@ -0,0 +1,13 @@
+/* { dg-do compile } */
+/* { dg-additional-options "-O3" } */
+
+extern short var_3, var_8;
+extern int var_5;
+extern char var_10;
+extern int arr_99[][16];
+void test()
+{
+ for (; 0 < var_10;)
+ for (long a = var_8;; a++)
+ arr_99[4][a] = var_3 << var_5;
+}
diff --git a/gcc/tree-vect-slp.c b/gcc/tree-vect-slp.c
index b223956..1ffbf6f 100644
--- a/gcc/tree-vect-slp.c
+++ b/gcc/tree-vect-slp.c
@@ -4293,6 +4293,21 @@ vect_schedule_slp_instance (vec_info *vinfo,
|| vect_stmt_dominates_stmt_p (last_stmt, vstmt))
last_stmt = vstmt;
}
+ else if (!SLP_TREE_VECTYPE (child))
+ {
+ /* For externals we use unvectorized at all scalar defs. */
+ unsigned j;
+ tree def;
+ FOR_EACH_VEC_ELT (SLP_TREE_SCALAR_OPS (child), j, def)
+ if (TREE_CODE (def) == SSA_NAME
+ && !SSA_NAME_IS_DEFAULT_DEF (def))
+ {
+ gimple *stmt = SSA_NAME_DEF_STMT (def);
+ if (!last_stmt
+ || vect_stmt_dominates_stmt_p (last_stmt, stmt))
+ last_stmt = stmt;
+ }
+ }
else
{
/* For externals we have to look at all defs since their