Add TODO_update_ssa for SLP BB vectorization (PR tree-optimization/91885).
authorMartin Liska <mliska@suse.cz>
Thu, 26 Sep 2019 07:40:09 +0000 (09:40 +0200)
committerMartin Liska <marxin@gcc.gnu.org>
Thu, 26 Sep 2019 07:40:09 +0000 (07:40 +0000)
2019-09-26  Martin Liska  <mliska@suse.cz>

PR tree-optimization/91885
* tree-vectorizer.c (try_vectorize_loop_1):
Add TODO_update_ssa_only_virtuals similarly to what slp
pass does.
2019-09-26  Martin Liska  <mliska@suse.cz>

PR tree-optimization/91885
* gcc.dg/pr91885.c: New test.

From-SVN: r276141

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/pr91885.c [new file with mode: 0644]
gcc/tree-vectorizer.c

index 838257145b3ed5bb1108306219749a04e3207b9d..f876c5b9ce0208ed4add97936d5251bbc45467f6 100644 (file)
@@ -1,3 +1,10 @@
+2019-09-26  Martin Liska  <mliska@suse.cz>
+
+       PR tree-optimization/91885
+       * tree-vectorizer.c (try_vectorize_loop_1):
+       Add TODO_update_ssa_only_virtuals similarly to what slp
+       pass does.
+
 2019-09-26  Richard Sandiford  <richard.sandiford@arm.com>
 
        * config/aarch64/aarch64.c (aarch64_rtx_costs): Use
index 8830baa3abaef06b8318eb67fd7c64d155600fd3..1f99dbd1c8e0df1605d0c4f4a340544f4dc44477 100644 (file)
@@ -1,3 +1,8 @@
+2019-09-26  Martin Liska  <mliska@suse.cz>
+
+       PR tree-optimization/91885
+       * gcc.dg/pr91885.c: New test.
+
 2019-09-25  Marek Polacek  <polacek@redhat.com>
 
        PR c++/91877 - ICE with converting member of packed struct.
diff --git a/gcc/testsuite/gcc.dg/pr91885.c b/gcc/testsuite/gcc.dg/pr91885.c
new file mode 100644 (file)
index 0000000..934e8d3
--- /dev/null
@@ -0,0 +1,47 @@
+/* { dg-do compile } */
+/* { dg-options "-O3 -fprofile-generate" } */
+/* { dg-require-profiling "-fprofile-generate" } */
+
+typedef signed long int __int64_t;
+typedef unsigned long int __uint64_t;
+typedef __int64_t int64_t;
+typedef __uint64_t uint64_t;
+inline void
+BLI_endian_switch_int64 (int64_t *val)
+{
+  uint64_t tval = *val;
+  *val = ((tval >> 56)) | ((tval << 40) & 0x00ff000000000000ll)
+        | ((tval << 24) & 0x0000ff0000000000ll)
+        | ((tval << 8) & 0x000000ff00000000ll)
+        | ((tval >> 8) & 0x00000000ff000000ll)
+        | ((tval >> 24) & 0x0000000000ff0000ll)
+        | ((tval >> 40) & 0x000000000000ff00ll) | ((tval << 56));
+}
+typedef struct anim_index_entry
+{
+  unsigned long long seek_pos_dts;
+  unsigned long long pts;
+} anim_index_entry;
+extern struct anim_index_entry *
+MEM_callocN (int);
+struct anim_index
+{
+  int num_entries;
+  struct anim_index_entry *entries;
+};
+struct anim_index *
+IMB_indexer_open (const char *name)
+{
+  char header[13];
+  struct anim_index *idx;
+  int i;
+  idx->entries = MEM_callocN (8);
+  if (((1 == 0) != (header[8] == 'V')))
+    {
+      for (i = 0; i < idx->num_entries; i++)
+       {
+         BLI_endian_switch_int64 ((int64_t *) &idx->entries[i].seek_pos_dts);
+         BLI_endian_switch_int64 ((int64_t *) &idx->entries[i].pts);
+       }
+    }
+}
index c3004f6f3a2a9dfe4b9291396b08e47af983e5ec..8fb70b751daf97b94206f208d999b61f137313ee 100644 (file)
@@ -943,7 +943,7 @@ try_vectorize_loop_1 (hash_table<simduid_to_vf> *&simduid_to_vf_htab,
              fold_loop_internal_call (loop_vectorized_call,
                                       boolean_true_node);
              loop_vectorized_call = NULL;
-             ret |= TODO_cleanup_cfg;
+             ret |= TODO_cleanup_cfg | TODO_update_ssa_only_virtuals;
            }
        }
       /* If outer loop vectorization fails for LOOP_VECTORIZED guarded