diff mbox series

Enable auto-vectorization at O2 with very-cheap cost model.

Message ID 20210916043305.1674303-1-hongtao.liu@intel.com
State New
Headers show
Series Enable auto-vectorization at O2 with very-cheap cost model. | expand

Commit Message

liuhongt Sept. 16, 2021, 4:33 a.m. UTC
Ping
rebased on latest trunk.

gcc/ChangeLog:

	* common.opt (ftree-vectorize): Add Var(flag_tree_vectorize).
	* doc/invoke.texi (Options That Control Optimization): Update
	documents.
	* opts.c (default_options_table): Enable auto-vectorization at
	O2 with very-cheap cost model.
	(finish_options): Use cheap cost model for
	explicit -ftree{,-loop}-vectorize.

gcc/testsuite/ChangeLog:

	* c-c++-common/Wstringop-overflow-2.c: Adjust testcase.
	* g++.dg/tree-ssa/pr81408.C: Ditto.
	* g++.dg/warn/Wuninitialized-13.C: Ditto.
	* gcc.dg/Warray-bounds-51.c: Ditto.
	* gcc.dg/Warray-parameter-3.c: Ditto.
	* gcc.dg/Wstringop-overflow-13.c: Ditto.
	* gcc.dg/Wstringop-overflow-14.c: Ditto.
	* gcc.dg/Wstringop-overflow-21.c: Ditto.
	* gcc.dg/Wstringop-overflow-68.c: Ditto.
	* gcc.dg/gomp/pr46032-2.c: Ditto.
	* gcc.dg/gomp/pr46032-3.c: Ditto.
	* gcc.dg/gomp/simd-2.c: Ditto.
	* gcc.dg/gomp/simd-3.c: Ditto.
	* gcc.dg/graphite/fuse-1.c: Ditto.
	* gcc.dg/pr67089-6.c: Ditto.
	* gcc.dg/pr82929-2.c: Ditto.
	* gcc.dg/pr82929.c: Ditto.
	* gcc.dg/store_merging_1.c: Ditto.
	* gcc.dg/store_merging_11.c: Ditto.
	* gcc.dg/store_merging_15.c: Ditto.
	* gcc.dg/store_merging_16.c: Ditto.
	* gcc.dg/store_merging_19.c: Ditto.
	* gcc.dg/store_merging_24.c: Ditto.
	* gcc.dg/store_merging_25.c: Ditto.
	* gcc.dg/store_merging_28.c: Ditto.
	* gcc.dg/store_merging_30.c: Ditto.
	* gcc.dg/store_merging_5.c: Ditto.
	* gcc.dg/store_merging_7.c: Ditto.
	* gcc.dg/store_merging_8.c: Ditto.
	* gcc.dg/strlenopt-85.c: Ditto.
	* gcc.dg/tree-ssa/dump-6.c: Ditto.
	* gcc.dg/tree-ssa/pr19210-1.c: Ditto.
	* gcc.dg/tree-ssa/pr47059.c: Ditto.
	* gcc.dg/tree-ssa/pr86017.c: Ditto.
	* gcc.dg/tree-ssa/pr91482.c: Ditto.
	* gcc.dg/tree-ssa/predcom-1.c: Ditto.
	* gcc.dg/tree-ssa/predcom-dse-3.c: Ditto.
	* gcc.dg/tree-ssa/prefetch-3.c: Ditto.
	* gcc.dg/tree-ssa/prefetch-6.c: Ditto.
	* gcc.dg/tree-ssa/prefetch-8.c: Ditto.
	* gcc.dg/tree-ssa/prefetch-9.c: Ditto.
	* gcc.dg/tree-ssa/ssa-dse-18.c: Ditto.
	* gcc.dg/tree-ssa/ssa-dse-19.c: Ditto.
	* gcc.dg/uninit-40.c: Ditto.
	* gcc.dg/unroll-7.c: Ditto.
	* gcc.misc-tests/help.exp: Ditto.
	* gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c: Ditto.
	* gcc.target/i386/pr22141.c: Ditto.
	* gcc.target/i386/pr34012.c: Ditto.
	* gcc.target/i386/pr49781-1.c: Ditto.
	* gcc.target/i386/pr95798-1.c: Ditto.
	* gcc.target/i386/pr95798-2.c: Ditto.
	* gfortran.dg/pr77498.f: Ditto.
---
 gcc/common.opt                                 |  2 +-
 gcc/doc/invoke.texi                            |  8 +++++---
 gcc/opts.c                                     | 18 +++++++++++++++---
 .../c-c++-common/Wstringop-overflow-2.c        |  2 +-
 gcc/testsuite/g++.dg/tree-ssa/pr81408.C        |  2 +-
 gcc/testsuite/g++.dg/warn/Wuninitialized-13.C  |  2 +-
 gcc/testsuite/gcc.dg/Warray-bounds-51.c        |  2 +-
 gcc/testsuite/gcc.dg/Warray-parameter-3.c      |  2 +-
 gcc/testsuite/gcc.dg/Wstringop-overflow-13.c   |  2 +-
 gcc/testsuite/gcc.dg/Wstringop-overflow-14.c   |  2 +-
 gcc/testsuite/gcc.dg/Wstringop-overflow-21.c   |  2 +-
 gcc/testsuite/gcc.dg/Wstringop-overflow-68.c   |  2 +-
 gcc/testsuite/gcc.dg/gomp/pr46032-2.c          |  2 +-
 gcc/testsuite/gcc.dg/gomp/pr46032-3.c          |  2 +-
 gcc/testsuite/gcc.dg/gomp/simd-2.c             |  2 +-
 gcc/testsuite/gcc.dg/gomp/simd-3.c             |  2 +-
 gcc/testsuite/gcc.dg/graphite/fuse-1.c         |  2 +-
 gcc/testsuite/gcc.dg/pr67089-6.c               |  2 +-
 gcc/testsuite/gcc.dg/pr82929-2.c               |  2 +-
 gcc/testsuite/gcc.dg/pr82929.c                 |  2 +-
 gcc/testsuite/gcc.dg/store_merging_1.c         |  2 +-
 gcc/testsuite/gcc.dg/store_merging_11.c        |  2 +-
 gcc/testsuite/gcc.dg/store_merging_15.c        |  2 +-
 gcc/testsuite/gcc.dg/store_merging_16.c        |  2 +-
 gcc/testsuite/gcc.dg/store_merging_19.c        |  2 +-
 gcc/testsuite/gcc.dg/store_merging_24.c        |  2 +-
 gcc/testsuite/gcc.dg/store_merging_25.c        |  2 +-
 gcc/testsuite/gcc.dg/store_merging_28.c        |  2 +-
 gcc/testsuite/gcc.dg/store_merging_30.c        |  2 +-
 gcc/testsuite/gcc.dg/store_merging_5.c         |  2 +-
 gcc/testsuite/gcc.dg/store_merging_7.c         |  2 +-
 gcc/testsuite/gcc.dg/store_merging_8.c         |  2 +-
 gcc/testsuite/gcc.dg/strlenopt-85.c            |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/dump-6.c         |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c      |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/pr47059.c        |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/pr86017.c        |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/pr91482.c        |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c      |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c  |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c     |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c     |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c     |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c     |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c     |  2 +-
 gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c     |  2 +-
 gcc/testsuite/gcc.dg/uninit-40.c               |  2 +-
 gcc/testsuite/gcc.dg/unroll-7.c                |  2 +-
 gcc/testsuite/gcc.misc-tests/help.exp          |  2 +-
 .../i386/avx512vpopcntdqvl-vpopcntd-1.c        |  2 +-
 gcc/testsuite/gcc.target/i386/pr22141.c        |  2 +-
 gcc/testsuite/gcc.target/i386/pr34012.c        |  2 +-
 gcc/testsuite/gcc.target/i386/pr49781-1.c      |  2 +-
 gcc/testsuite/gcc.target/i386/pr95798-1.c      |  2 +-
 gcc/testsuite/gcc.target/i386/pr95798-2.c      |  2 +-
 gcc/testsuite/gfortran.dg/pr77498.f            |  2 +-
 56 files changed, 74 insertions(+), 60 deletions(-)

Comments

Richard Biener Sept. 16, 2021, 8:22 a.m. UTC | #1
On Thu, 16 Sep 2021, liuhongt wrote:

> Ping
> rebased on latest trunk.
> 
> gcc/ChangeLog:
> 
> 	* common.opt (ftree-vectorize): Add Var(flag_tree_vectorize).
> 	* doc/invoke.texi (Options That Control Optimization): Update
> 	documents.
> 	* opts.c (default_options_table): Enable auto-vectorization at
> 	O2 with very-cheap cost model.
> 	(finish_options): Use cheap cost model for
> 	explicit -ftree{,-loop}-vectorize.
> 
> gcc/testsuite/ChangeLog:
> 
> 	* c-c++-common/Wstringop-overflow-2.c: Adjust testcase.
> 	* g++.dg/tree-ssa/pr81408.C: Ditto.
> 	* g++.dg/warn/Wuninitialized-13.C: Ditto.
> 	* gcc.dg/Warray-bounds-51.c: Ditto.
> 	* gcc.dg/Warray-parameter-3.c: Ditto.
> 	* gcc.dg/Wstringop-overflow-13.c: Ditto.
> 	* gcc.dg/Wstringop-overflow-14.c: Ditto.
> 	* gcc.dg/Wstringop-overflow-21.c: Ditto.
> 	* gcc.dg/Wstringop-overflow-68.c: Ditto.
> 	* gcc.dg/gomp/pr46032-2.c: Ditto.
> 	* gcc.dg/gomp/pr46032-3.c: Ditto.
> 	* gcc.dg/gomp/simd-2.c: Ditto.
> 	* gcc.dg/gomp/simd-3.c: Ditto.
> 	* gcc.dg/graphite/fuse-1.c: Ditto.
> 	* gcc.dg/pr67089-6.c: Ditto.
> 	* gcc.dg/pr82929-2.c: Ditto.
> 	* gcc.dg/pr82929.c: Ditto.
> 	* gcc.dg/store_merging_1.c: Ditto.
> 	* gcc.dg/store_merging_11.c: Ditto.
> 	* gcc.dg/store_merging_15.c: Ditto.
> 	* gcc.dg/store_merging_16.c: Ditto.
> 	* gcc.dg/store_merging_19.c: Ditto.
> 	* gcc.dg/store_merging_24.c: Ditto.
> 	* gcc.dg/store_merging_25.c: Ditto.
> 	* gcc.dg/store_merging_28.c: Ditto.
> 	* gcc.dg/store_merging_30.c: Ditto.
> 	* gcc.dg/store_merging_5.c: Ditto.
> 	* gcc.dg/store_merging_7.c: Ditto.
> 	* gcc.dg/store_merging_8.c: Ditto.
> 	* gcc.dg/strlenopt-85.c: Ditto.
> 	* gcc.dg/tree-ssa/dump-6.c: Ditto.
> 	* gcc.dg/tree-ssa/pr19210-1.c: Ditto.
> 	* gcc.dg/tree-ssa/pr47059.c: Ditto.
> 	* gcc.dg/tree-ssa/pr86017.c: Ditto.
> 	* gcc.dg/tree-ssa/pr91482.c: Ditto.
> 	* gcc.dg/tree-ssa/predcom-1.c: Ditto.
> 	* gcc.dg/tree-ssa/predcom-dse-3.c: Ditto.
> 	* gcc.dg/tree-ssa/prefetch-3.c: Ditto.
> 	* gcc.dg/tree-ssa/prefetch-6.c: Ditto.
> 	* gcc.dg/tree-ssa/prefetch-8.c: Ditto.
> 	* gcc.dg/tree-ssa/prefetch-9.c: Ditto.
> 	* gcc.dg/tree-ssa/ssa-dse-18.c: Ditto.
> 	* gcc.dg/tree-ssa/ssa-dse-19.c: Ditto.
> 	* gcc.dg/uninit-40.c: Ditto.
> 	* gcc.dg/unroll-7.c: Ditto.
> 	* gcc.misc-tests/help.exp: Ditto.
> 	* gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c: Ditto.
> 	* gcc.target/i386/pr22141.c: Ditto.
> 	* gcc.target/i386/pr34012.c: Ditto.
> 	* gcc.target/i386/pr49781-1.c: Ditto.
> 	* gcc.target/i386/pr95798-1.c: Ditto.
> 	* gcc.target/i386/pr95798-2.c: Ditto.
> 	* gfortran.dg/pr77498.f: Ditto.
> ---
>  gcc/common.opt                                 |  2 +-
>  gcc/doc/invoke.texi                            |  8 +++++---
>  gcc/opts.c                                     | 18 +++++++++++++++---
>  .../c-c++-common/Wstringop-overflow-2.c        |  2 +-
>  gcc/testsuite/g++.dg/tree-ssa/pr81408.C        |  2 +-
>  gcc/testsuite/g++.dg/warn/Wuninitialized-13.C  |  2 +-
>  gcc/testsuite/gcc.dg/Warray-bounds-51.c        |  2 +-
>  gcc/testsuite/gcc.dg/Warray-parameter-3.c      |  2 +-
>  gcc/testsuite/gcc.dg/Wstringop-overflow-13.c   |  2 +-
>  gcc/testsuite/gcc.dg/Wstringop-overflow-14.c   |  2 +-
>  gcc/testsuite/gcc.dg/Wstringop-overflow-21.c   |  2 +-
>  gcc/testsuite/gcc.dg/Wstringop-overflow-68.c   |  2 +-
>  gcc/testsuite/gcc.dg/gomp/pr46032-2.c          |  2 +-
>  gcc/testsuite/gcc.dg/gomp/pr46032-3.c          |  2 +-
>  gcc/testsuite/gcc.dg/gomp/simd-2.c             |  2 +-
>  gcc/testsuite/gcc.dg/gomp/simd-3.c             |  2 +-
>  gcc/testsuite/gcc.dg/graphite/fuse-1.c         |  2 +-
>  gcc/testsuite/gcc.dg/pr67089-6.c               |  2 +-
>  gcc/testsuite/gcc.dg/pr82929-2.c               |  2 +-
>  gcc/testsuite/gcc.dg/pr82929.c                 |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_1.c         |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_11.c        |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_15.c        |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_16.c        |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_19.c        |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_24.c        |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_25.c        |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_28.c        |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_30.c        |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_5.c         |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_7.c         |  2 +-
>  gcc/testsuite/gcc.dg/store_merging_8.c         |  2 +-
>  gcc/testsuite/gcc.dg/strlenopt-85.c            |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/dump-6.c         |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c      |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/pr47059.c        |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/pr86017.c        |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/pr91482.c        |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c      |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c  |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c     |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c     |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c     |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c     |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c     |  2 +-
>  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c     |  2 +-
>  gcc/testsuite/gcc.dg/uninit-40.c               |  2 +-
>  gcc/testsuite/gcc.dg/unroll-7.c                |  2 +-
>  gcc/testsuite/gcc.misc-tests/help.exp          |  2 +-
>  .../i386/avx512vpopcntdqvl-vpopcntd-1.c        |  2 +-
>  gcc/testsuite/gcc.target/i386/pr22141.c        |  2 +-
>  gcc/testsuite/gcc.target/i386/pr34012.c        |  2 +-
>  gcc/testsuite/gcc.target/i386/pr49781-1.c      |  2 +-
>  gcc/testsuite/gcc.target/i386/pr95798-1.c      |  2 +-
>  gcc/testsuite/gcc.target/i386/pr95798-2.c      |  2 +-
>  gcc/testsuite/gfortran.dg/pr77498.f            |  2 +-
>  56 files changed, 74 insertions(+), 60 deletions(-)
> 
> diff --git a/gcc/common.opt b/gcc/common.opt
> index b921f5e3b25..4f2c0294c29 100644
> --- a/gcc/common.opt
> +++ b/gcc/common.opt
> @@ -3031,7 +3031,7 @@ Perform variable tracking and also tag variables that are uninitialized.
>  
>  ; Alias to enable both -ftree-loop-vectorize and -ftree-slp-vectorize.
>  ftree-vectorize
> -Common Optimization
> +Common Var(flag_tree_vectorize) Optimization
>  Enable vectorization on trees.
>  
>  ftree-vectorizer-verbose=
> diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
> index 78cfc100ac2..be022ef8024 100644
> --- a/gcc/doc/invoke.texi
> +++ b/gcc/doc/invoke.texi
> @@ -10409,9 +10409,13 @@ also turns on the following optimization flags:
>  -fstrict-aliasing @gol
>  -fthread-jumps @gol
>  -ftree-builtin-call-dce @gol
> +-ftree-loop-vectorize @gol
>  -ftree-pre @gol
> +-ftree-slp-vectorize @gol
>  -ftree-switch-conversion  -ftree-tail-merge @gol
> --ftree-vrp}
> +-ftree-vrp @gol
> +-fvect-cost-model @gol

the above is redundant

> +-fvect-cost-model=very-cheap}
>  
>  Please note the warning under @option{-fgcse} about
>  invoking @option{-O2} on programs that use computed gotos.
> @@ -10431,9 +10435,7 @@ by @option{-O2} and also turns on the following optimization flags:
>  -fsplit-loops @gol
>  -fsplit-paths @gol
>  -ftree-loop-distribution @gol
> --ftree-loop-vectorize @gol
>  -ftree-partial-pre @gol
> --ftree-slp-vectorize @gol
>  -funswitch-loops @gol
>  -fvect-cost-model @gol

likewise - so just remove it here as you are around

>  -fvect-cost-model=dynamic @gol
> diff --git a/gcc/opts.c b/gcc/opts.c
> index 1d2d22d7a3f..cee372a3235 100644
> --- a/gcc/opts.c
> +++ b/gcc/opts.c
> @@ -634,7 +634,8 @@ static const struct default_options default_options_table[] =
>      { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
>      { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
>      { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
> -    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
> +    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL,
> +      VECT_COST_MODEL_VERY_CHEAP },
>      { OPT_LEVELS_2_PLUS, OPT_finline_functions, NULL, 1 },
>      { OPT_LEVELS_2_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
>  
> @@ -646,6 +647,9 @@ static const struct default_options default_options_table[] =
>      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
>      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
>        REORDER_BLOCKS_ALGORITHM_STC },
> +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_loop_vectorize, NULL, 1 },
> +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_slp_vectorize, NULL, 1 },
> +
>  #ifdef INSN_SCHEDULING
>    /* Only run the pre-regalloc scheduling pass if optimizing for speed.  */
>      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
> @@ -663,9 +667,7 @@ static const struct default_options default_options_table[] =
>      { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
>      { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
>      { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
> -    { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
>      { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
> -    { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
>      { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
>      { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
>      { OPT_LEVELS_3_PLUS, OPT_fversion_loops_for_strides, NULL, 1 },
> @@ -1331,6 +1333,16 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
>        = (opts->x_flag_unroll_loops
>           || opts->x_flag_peel_loops
>           || opts->x_optimize >= 3);
> +
> +  /* Use -fvect-cost-model=cheap instead of -fvect-cost-mode=very-cheap
> +     by default with explicit -ftree-{loop,slp}-vectorize.  */
> +  if (opts->x_optimize == 2
> +      && (opts_set->x_flag_tree_loop_vectorize
> +	  || opts_set->x_flag_tree_vectorize))
> +    SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
> +			 VECT_COST_MODEL_CHEAP);
> +
> +

please avoid adding excessive vertical space at the end of the function

>  }
>  
>  #define LEFT_COLUMN	27
> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> index 1d79930cd58..9351f7e7a1a 100644
> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> @@ -1,7 +1,7 @@
>  /* PR middle-end/91458 - inconsistent warning for writing past the end
>     of an array member
>     { dg-do compile }
> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */

The testcase is large - what part requires this change?  Given the
testcase was added for inconsistent warnings do they now become
inconsistent again as we enable vectorization at -O2?

That said, the testcase adjustments need some explaining - I suppose
you didn't just slap -fno-tree-vectorize to all of those changing
behavior?

Thanks,
Richard.

>  void sink (void*);
>  
> diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> index 39e32fd4bc9..bc14309480c 100644
> --- a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> +++ b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed" } */
> +/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed -fno-tree-vectorize" } */
>  struct p
>  {
>    char *ay;
> diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> index 49ee878806a..60e8dd4f0e2 100644
> --- a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> +++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> @@ -1,6 +1,6 @@
>  /* PR c/98597 - ICE in -Wuninitialized printing a MEM_REF
>     { dg-do compile }
> -   { dg-options "-O2 -Wall" } */
> +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
>  
>  struct shared_count {
>    shared_count () { }
> diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-51.c b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> index 6028b11637c..8b81a0ccfa7 100644
> --- a/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> +++ b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> @@ -1,7 +1,7 @@
>  /* PR middle-end/92333 - missing variable name referencing VLA in warnings
>     PR middle-end/82608 - missing -Warray-bounds on an out-of-bounds VLA index
>     { dg-do compile }
> -   { dg-options "-O2 -Wall" } */
> +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
>  
>  void sink (void*);
>  
> diff --git a/gcc/testsuite/gcc.dg/Warray-parameter-3.c b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> index cbf3e9339f5..fbef715aa99 100644
> --- a/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> +++ b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> @@ -59,7 +59,7 @@ void fas1 (int[static 2]);    // { dg-warning "\\\[-Warray-parameter=" }
>  
>  /* Also verify that -Warray-bounds doesn't trigger for ordinary array
>     parameters...  */
> -#pragma GCC optimize "2"
> +#pragma GCC optimize ("2,-fno-tree-vectorize")
>  
>  __attribute__ ((noipa)) void
>  gca3 (char a[3])
> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> index bd513151cea..a78242bf26e 100644
> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> @@ -3,7 +3,7 @@
>     PR middle-end/89911 - ICE on a call with no arguments to strnlen
>     declared with no prototype
>     { dg-do compile }
> -   { dg-options "-O2 -Wall" } */
> +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
>  
>  typedef __SIZE_TYPE__ size_t;
>  
> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> index d6201b068b6..808bf87c386 100644
> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> @@ -2,7 +2,7 @@
>     types than char are diagnosed.
>     { dg-do compile }
>     { dg-require-effective-target int32plus }
> -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> +   { dg-options "-O2 -fno-tree-vectorize -Wall -Wno-array-bounds" } */
>  
>  typedef __INT16_TYPE__  int16_t;
>  typedef __INT32_TYPE__  int32_t;
> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> index 3a27460220c..f418a17ca93 100644
> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> @@ -1,7 +1,7 @@
>  /* PR middle-end/92312 - bogus -Wstringop-overflow storing into a trailing
>     array backed by larger buffer
>     { dg-do compile }
> -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-tree-vectorize" } */
>  
>  struct S0 { char a, b[0]; };
>  
> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> index 6bcba274541..7cc1012130c 100644
> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> @@ -2,7 +2,7 @@
>     a larger scalar into a smaller array
>     Verify overflow by aggregate stores.
>     { dg-do compile }
> -   { dg-options "-O2" } */
> +   { dg-options "-O2 -fno-tree-vectorize" } */
>  
>  #define A(N) (A ## N)
>  #define Ac1 (AC1){ 0 }
> diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> index e110880bd8e..2e562618489 100644
> --- a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
>  
>  #define N 2
>  
> diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> index a4af7ec4a8a..da1ab487385 100644
> --- a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
>  
>  #define N 2
>  
> diff --git a/gcc/testsuite/gcc.dg/gomp/simd-2.c b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> index 85acb980f10..f4912127b81 100644
> --- a/gcc/testsuite/gcc.dg/gomp/simd-2.c
> +++ b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
>  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
>  /* { dg-additional-options "-mavx" { target avx } } */
>  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> diff --git a/gcc/testsuite/gcc.dg/gomp/simd-3.c b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> index 86fee858673..c75060c07ae 100644
> --- a/gcc/testsuite/gcc.dg/gomp/simd-3.c
> +++ b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
>  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
>  /* { dg-additional-options "-mavx" { target avx } } */
>  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> diff --git a/gcc/testsuite/gcc.dg/graphite/fuse-1.c b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> index 527b6e5c415..61289d312c2 100644
> --- a/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> +++ b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> @@ -1,6 +1,6 @@
>  /* Check that the two loops are fused and that we manage to fold the two xor
>     operations.  */
> -/* { dg-options "-O2 -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
>  
>  /* Make sure we fuse the loops like this:
>  AST generated by isl:
> diff --git a/gcc/testsuite/gcc.dg/pr67089-6.c b/gcc/testsuite/gcc.dg/pr67089-6.c
> index db2ffdfeca4..b59d75b2318 100644
> --- a/gcc/testsuite/gcc.dg/pr67089-6.c
> +++ b/gcc/testsuite/gcc.dg/pr67089-6.c
> @@ -1,6 +1,6 @@
>  /* PR target/67089 */
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -ftree-loop-if-convert -fdump-tree-widening_mul" } */
>  
>  extern void abort (void);
>  
> diff --git a/gcc/testsuite/gcc.dg/pr82929-2.c b/gcc/testsuite/gcc.dg/pr82929-2.c
> index 3442f91af02..b886f1cce76 100644
> --- a/gcc/testsuite/gcc.dg/pr82929-2.c
> +++ b/gcc/testsuite/gcc.dg/pr82929-2.c
> @@ -1,6 +1,6 @@
>  /* PR tree-optimization/82929 */
>  /* { dg-do compile { target store_merge } } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  void
>  foo (short *p, short *q, short *r)
> diff --git a/gcc/testsuite/gcc.dg/pr82929.c b/gcc/testsuite/gcc.dg/pr82929.c
> index bb84f2b21a3..123e1919cec 100644
> --- a/gcc/testsuite/gcc.dg/pr82929.c
> +++ b/gcc/testsuite/gcc.dg/pr82929.c
> @@ -1,6 +1,6 @@
>  /* PR tree-optimization/82929 */
>  /* { dg-do compile { target store_merge } } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  void
>  foo (short *p, short *q, short *r)
> diff --git a/gcc/testsuite/gcc.dg/store_merging_1.c b/gcc/testsuite/gcc.dg/store_merging_1.c
> index 4cc43dfd9e1..91ca925be0e 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_1.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_1.c
> @@ -1,6 +1,6 @@
>  /* { dg-do compile } */
>  /* { dg-require-effective-target store_merge } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  struct bar {
>    int a;
> diff --git a/gcc/testsuite/gcc.dg/store_merging_11.c b/gcc/testsuite/gcc.dg/store_merging_11.c
> index 2ec2394afb9..60ed5cd8bf9 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_11.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_11.c
> @@ -1,6 +1,6 @@
>  /* { dg-do run } */
>  /* { dg-require-effective-target store_merge } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  struct S { unsigned char b[2]; unsigned short c; unsigned char d[4]; unsigned long e; };
>  
> diff --git a/gcc/testsuite/gcc.dg/store_merging_15.c b/gcc/testsuite/gcc.dg/store_merging_15.c
> index acd7de571f8..13fcca4aa11 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_15.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_15.c
> @@ -1,6 +1,6 @@
>  /* { dg-do run } */
>  /* { dg-require-effective-target store_merge } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  struct S { unsigned char a, b; unsigned short c; unsigned char d, e, f, g; unsigned long long h; };
>  
> diff --git a/gcc/testsuite/gcc.dg/store_merging_16.c b/gcc/testsuite/gcc.dg/store_merging_16.c
> index 9545dcce3de..cd83f1c0fe5 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_16.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_16.c
> @@ -2,7 +2,7 @@
>     are either big or little endian (not pdp endian).  */
>  /* { dg-do run { target { lp64 && { i?86-*-* x86_64-*-* powerpc*-*-* aarch64*-*-* } } } } */
>  /* { dg-require-effective-target store_merge } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  __attribute__((noipa)) void
>  f1 (unsigned char *p, unsigned long long q)
> diff --git a/gcc/testsuite/gcc.dg/store_merging_19.c b/gcc/testsuite/gcc.dg/store_merging_19.c
> index 0841bb4deee..0a2bbc4bfde 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_19.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_19.c
> @@ -1,6 +1,6 @@
>  /* PR tree-optimization/83843 */
>  /* { dg-do run } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  /* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" { target store_merge } } } */
>  
>  __attribute__((noipa)) void
> diff --git a/gcc/testsuite/gcc.dg/store_merging_24.c b/gcc/testsuite/gcc.dg/store_merging_24.c
> index 744fe60e8e0..5291bb9e986 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_24.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_24.c
> @@ -1,6 +1,6 @@
>  /* PR tree-optimization/87859 */
>  /* { dg-do run } */
> -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
>  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 19 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
>  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
>  
> diff --git a/gcc/testsuite/gcc.dg/store_merging_25.c b/gcc/testsuite/gcc.dg/store_merging_25.c
> index cf182190e91..96611b5e57b 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_25.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_25.c
> @@ -1,6 +1,6 @@
>  /* PR tree-optimization/87859 */
>  /* { dg-do run } */
> -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
>  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 14 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
>  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
>  
> diff --git a/gcc/testsuite/gcc.dg/store_merging_28.c b/gcc/testsuite/gcc.dg/store_merging_28.c
> index 2d6cffc4694..fadb7fff993 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_28.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_28.c
> @@ -1,7 +1,7 @@
>  /* PR tree-optimization/88709 */
>  /* { dg-do compile } */
>  /* { dg-require-effective-target store_merge } */
> -/* { dg-options "-O2 -fno-ipa-icf -fdump-tree-store-merging-details" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fno-ipa-icf -fdump-tree-store-merging-details" } */
>  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 16 stores" 8 "store-merging" { target { i?86-*-* x86_64-*-* } } } } */
>  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 6 stores" 1 "store-merging" { target { ! arm*-*-* } } } } */
>  
> diff --git a/gcc/testsuite/gcc.dg/store_merging_30.c b/gcc/testsuite/gcc.dg/store_merging_30.c
> index 694d560a621..baf94efe733 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_30.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_30.c
> @@ -1,7 +1,7 @@
>  /* PR tree-optimization/94573 */
>  /* { dg-do compile } */
>  /* { dg-require-effective-target store_merge } */
> -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
>  /* { dg-final { scan-tree-dump "New sequence of 4 stores to replace old one of 8 stores" "store-merging" { target lp64 } } } */
>  
>  int var[43][12];
> diff --git a/gcc/testsuite/gcc.dg/store_merging_5.c b/gcc/testsuite/gcc.dg/store_merging_5.c
> index 6e7c72510ff..b0cb0da78e0 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_5.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_5.c
> @@ -1,6 +1,6 @@
>  /* { dg-do compile } */
>  /* { dg-require-effective-target store_merge } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  /* Make sure that non-aliasing non-constant interspersed stores do not
>     stop chains.  */
> diff --git a/gcc/testsuite/gcc.dg/store_merging_7.c b/gcc/testsuite/gcc.dg/store_merging_7.c
> index c744ece6407..dbe000a463e 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_7.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_7.c
> @@ -1,6 +1,6 @@
>  /* { dg-do compile } */
>  /* { dg-require-effective-target store_merge } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  /* Check that we can merge consecutive array members through the pointer.
>     PR rtl-optimization/23684.  */
> diff --git a/gcc/testsuite/gcc.dg/store_merging_8.c b/gcc/testsuite/gcc.dg/store_merging_8.c
> index e710a544ff0..d719e0a2257 100644
> --- a/gcc/testsuite/gcc.dg/store_merging_8.c
> +++ b/gcc/testsuite/gcc.dg/store_merging_8.c
> @@ -1,6 +1,6 @@
>  /* { dg-do compile } */
>  /* { dg-require-effective-target store_merge } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  struct baz {
>    struct bar {
> diff --git a/gcc/testsuite/gcc.dg/strlenopt-85.c b/gcc/testsuite/gcc.dg/strlenopt-85.c
> index e049e0c30e0..2ba1ee05700 100644
> --- a/gcc/testsuite/gcc.dg/strlenopt-85.c
> +++ b/gcc/testsuite/gcc.dg/strlenopt-85.c
> @@ -4,7 +4,7 @@
>     of memory allocated by calloc() even if one or more nul bytes are
>     written into it.
>     { dg-do compile }
> -   { dg-options "-O2 -fdump-tree-optimized" } */
> +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
>  
>  unsigned n0, n1;
>  
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> index 70659c00c0e..6c803908781 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> @@ -1,6 +1,6 @@
>  /* PR middle-end/90676 - default GIMPLE dumps lack information
>     { dg-do compile }
> -   { dg-options "-O2 -fdump-tree-store-merging" }
> +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" }
>     { dg-require-effective-target int32plus }
>     { dg-require-effective-target store_merge } */
>  
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> index 50d86a00485..b9e40e964c1 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fopt-info-loop-missed" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fopt-info-loop-missed" } */
>  extern void g(void);
>  
>  void
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> index 9f9c61aa213..860cde12c0f 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-Os -fdump-tree-optimized" } */
> +/* { dg-options "-Os -fno-tree-vectorize -fdump-tree-optimized" } */
>  
>  
>  struct struct1
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> index f216e83c7b3..c7ef73ad59e 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>  
>  void f (void*);
>  
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> index 7d6a724e4ad..0ddad573129 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-ccp1 -fdump-tree-store-merging" } */
>  
>  void write64 (void *p)
>  {
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> index f68be2b3379..8c3d9a4fc58 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> @@ -1,6 +1,6 @@
>  /* { dg-do compile } */
>  /* { dg-do run } */
> -/* { dg-options "-O2 -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
>  
>  void abort (void);
>  
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> index ec08d6c0318..1fc8f089345 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> @@ -1,5 +1,5 @@
>  /* { dg-do run } */
> -/* { dg-options "-O2 -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
>  
>  int arr1[105] = {2, 3, 5, 7, 11, 13, 0};
>  int arr2[105] = {2, 3, 5, 7, 11, 13, 0};
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> index 467903bf3fc..46f0d0c2317 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> @@ -1,7 +1,7 @@
>  /* Prefetching used to prefer nonsensical unroll factor of 5 in this testcase.  */
>  
>  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
>  
>  #define N 1000000
>  
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> index 12f09016943..3fa71685ace 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
>  
>  #define N 1000
>  #define K 900
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> index cbd6a80d345..00f41c3e4f4 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
>  
>  #define K 1000000
>  int a[K];
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> index da4847320b1..e8848c30acc 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
>  
>  #define K 1000000
>  int a[K], b[K];
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> index 92b2df80ec8..2e7b5b496ea 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fdump-tree-optimized" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
>  int g(_Complex int*);
>  int f(void)
>  {
> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> index 718b7466e50..7bb8d060631 100644
> --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fdump-tree-optimized" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
>  int g(_Complex int*);
>  int f(void)
>  {
> diff --git a/gcc/testsuite/gcc.dg/uninit-40.c b/gcc/testsuite/gcc.dg/uninit-40.c
> index c015191ca32..8708079d397 100644
> --- a/gcc/testsuite/gcc.dg/uninit-40.c
> +++ b/gcc/testsuite/gcc.dg/uninit-40.c
> @@ -1,6 +1,6 @@
>  /* PR tree-optimization/98597 */
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -Wuninitialized" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -Wuninitialized" } */
>  
>  union U { double d; int i; float f; };
>  struct S { char a; int b; char c; unsigned d; union U e; int f[3]; unsigned g[3]; };
> diff --git a/gcc/testsuite/gcc.dg/unroll-7.c b/gcc/testsuite/gcc.dg/unroll-7.c
> index 055369bf8b1..695af5757cc 100644
> --- a/gcc/testsuite/gcc.dg/unroll-7.c
> +++ b/gcc/testsuite/gcc.dg/unroll-7.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-rtl-loop2_unroll-details -funroll-loops" } */
>  /* { dg-require-effective-target int32plus } */
>  
>  extern int *a;
> diff --git a/gcc/testsuite/gcc.misc-tests/help.exp b/gcc/testsuite/gcc.misc-tests/help.exp
> index 5e034d26947..eb6d8686c6a 100644
> --- a/gcc/testsuite/gcc.misc-tests/help.exp
> +++ b/gcc/testsuite/gcc.misc-tests/help.exp
> @@ -79,7 +79,7 @@ check_for_options c "--help=target,optimizers" "" "" ""
>  check_for_options c "--help=warnings,^joined,^undocumented" "" "" ""
>  check_for_options c "-Q -O2 --help=optimizers" {
>  -O
> --ftree-loop-vectorize[^\n]*disabled
> +-ftree-loop-vectorize[^\n]*enabled
>  } "  -g  " ""
>  check_for_options c "-Q -O3 --help=optimizers" {
>  -O
> diff --git a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> index 709cd21e671..a732bc466db 100644
> --- a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> +++ b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> @@ -1,5 +1,5 @@
>  /* { dg-do run } */
> -/* { dg-options "-O2 -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
>  /* { dg-require-effective-target avx512vl } */
>  /* { dg-require-effective-target avx512vpopcntdqvl } */
>  /* { dg-require-effective-target avx512bw } */
> diff --git a/gcc/testsuite/gcc.target/i386/pr22141.c b/gcc/testsuite/gcc.target/i386/pr22141.c
> index 036422e8ccf..b68b97f3f72 100644
> --- a/gcc/testsuite/gcc.target/i386/pr22141.c
> +++ b/gcc/testsuite/gcc.target/i386/pr22141.c
> @@ -1,6 +1,6 @@
>  /* PR middle-end/22141 */
>  /* { dg-do compile } */
> -/* { dg-options "-Os" } */
> +/* { dg-options "-Os -fno-tree-vectorize" } */
>  
>  extern void abort (void);
>  
> diff --git a/gcc/testsuite/gcc.target/i386/pr34012.c b/gcc/testsuite/gcc.target/i386/pr34012.c
> index d0cffa05290..1c1f0eea52e 100644
> --- a/gcc/testsuite/gcc.target/i386/pr34012.c
> +++ b/gcc/testsuite/gcc.target/i386/pr34012.c
> @@ -1,7 +1,7 @@
>  /* PR rtl-optimization/34012 */
>  /* { dg-do compile } */
>  /* { dg-require-effective-target lp64 } */
> -/* { dg-options "-O2 -fno-store-merging" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fno-store-merging" } */
>  
>  void bar (long int *);
>  void
> diff --git a/gcc/testsuite/gcc.target/i386/pr49781-1.c b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> index 60f9d50d866..d5a2e32db97 100644
> --- a/gcc/testsuite/gcc.target/i386/pr49781-1.c
> +++ b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -fpic -mtune=generic" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -fpic -mtune=generic" } */
>  /* { dg-require-effective-target fpic } */
>  
>  static int heap[2*(256 +1+29)+1];
> diff --git a/gcc/testsuite/gcc.target/i386/pr95798-1.c b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> index 9a7e32d6f2f..526f48921fd 100644
> --- a/gcc/testsuite/gcc.target/i386/pr95798-1.c
> +++ b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> @@ -1,6 +1,6 @@
>  /* PR target/95798 */
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
>  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> diff --git a/gcc/testsuite/gcc.target/i386/pr95798-2.c b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> index c670d3780e8..6b5c5a73e96 100644
> --- a/gcc/testsuite/gcc.target/i386/pr95798-2.c
> +++ b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> @@ -1,6 +1,6 @@
>  /* PR target/95798 */
>  /* { dg-do compile } */
> -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
>  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> diff --git a/gcc/testsuite/gfortran.dg/pr77498.f b/gcc/testsuite/gfortran.dg/pr77498.f
> index f957b57bb00..a0fc8275a84 100644
> --- a/gcc/testsuite/gfortran.dg/pr77498.f
> +++ b/gcc/testsuite/gfortran.dg/pr77498.f
> @@ -1,5 +1,5 @@
>  ! { dg-do compile }
> -! { dg-options "-O2 -ffast-math -fdump-tree-pre" }
> +! { dg-options "-O2 -fno-tree-vectorize -ffast-math -fdump-tree-pre" }
>  
>        subroutine foo(U,V,R,N,A)
>        integer N
>
Hongtao Liu Sept. 16, 2021, 9:03 a.m. UTC | #2
On Thu, Sep 16, 2021 at 4:23 PM Richard Biener via Gcc-patches
<gcc-patches@gcc.gnu.org> wrote:
>
> On Thu, 16 Sep 2021, liuhongt wrote:
>
> > Ping
> > rebased on latest trunk.
> >
> > gcc/ChangeLog:
> >
> >       * common.opt (ftree-vectorize): Add Var(flag_tree_vectorize).
> >       * doc/invoke.texi (Options That Control Optimization): Update
> >       documents.
> >       * opts.c (default_options_table): Enable auto-vectorization at
> >       O2 with very-cheap cost model.
> >       (finish_options): Use cheap cost model for
> >       explicit -ftree{,-loop}-vectorize.
> >
> > gcc/testsuite/ChangeLog:
> >
> >       * c-c++-common/Wstringop-overflow-2.c: Adjust testcase.
> >       * g++.dg/tree-ssa/pr81408.C: Ditto.
> >       * g++.dg/warn/Wuninitialized-13.C: Ditto.
> >       * gcc.dg/Warray-bounds-51.c: Ditto.
> >       * gcc.dg/Warray-parameter-3.c: Ditto.
> >       * gcc.dg/Wstringop-overflow-13.c: Ditto.
> >       * gcc.dg/Wstringop-overflow-14.c: Ditto.
> >       * gcc.dg/Wstringop-overflow-21.c: Ditto.
> >       * gcc.dg/Wstringop-overflow-68.c: Ditto.
> >       * gcc.dg/gomp/pr46032-2.c: Ditto.
> >       * gcc.dg/gomp/pr46032-3.c: Ditto.
> >       * gcc.dg/gomp/simd-2.c: Ditto.
> >       * gcc.dg/gomp/simd-3.c: Ditto.
> >       * gcc.dg/graphite/fuse-1.c: Ditto.
> >       * gcc.dg/pr67089-6.c: Ditto.
> >       * gcc.dg/pr82929-2.c: Ditto.
> >       * gcc.dg/pr82929.c: Ditto.
> >       * gcc.dg/store_merging_1.c: Ditto.
> >       * gcc.dg/store_merging_11.c: Ditto.
> >       * gcc.dg/store_merging_15.c: Ditto.
> >       * gcc.dg/store_merging_16.c: Ditto.
> >       * gcc.dg/store_merging_19.c: Ditto.
> >       * gcc.dg/store_merging_24.c: Ditto.
> >       * gcc.dg/store_merging_25.c: Ditto.
> >       * gcc.dg/store_merging_28.c: Ditto.
> >       * gcc.dg/store_merging_30.c: Ditto.
> >       * gcc.dg/store_merging_5.c: Ditto.
> >       * gcc.dg/store_merging_7.c: Ditto.
> >       * gcc.dg/store_merging_8.c: Ditto.
> >       * gcc.dg/strlenopt-85.c: Ditto.
> >       * gcc.dg/tree-ssa/dump-6.c: Ditto.
> >       * gcc.dg/tree-ssa/pr19210-1.c: Ditto.
> >       * gcc.dg/tree-ssa/pr47059.c: Ditto.
> >       * gcc.dg/tree-ssa/pr86017.c: Ditto.
> >       * gcc.dg/tree-ssa/pr91482.c: Ditto.
> >       * gcc.dg/tree-ssa/predcom-1.c: Ditto.
> >       * gcc.dg/tree-ssa/predcom-dse-3.c: Ditto.
> >       * gcc.dg/tree-ssa/prefetch-3.c: Ditto.
> >       * gcc.dg/tree-ssa/prefetch-6.c: Ditto.
> >       * gcc.dg/tree-ssa/prefetch-8.c: Ditto.
> >       * gcc.dg/tree-ssa/prefetch-9.c: Ditto.
> >       * gcc.dg/tree-ssa/ssa-dse-18.c: Ditto.
> >       * gcc.dg/tree-ssa/ssa-dse-19.c: Ditto.
> >       * gcc.dg/uninit-40.c: Ditto.
> >       * gcc.dg/unroll-7.c: Ditto.
> >       * gcc.misc-tests/help.exp: Ditto.
> >       * gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c: Ditto.
> >       * gcc.target/i386/pr22141.c: Ditto.
> >       * gcc.target/i386/pr34012.c: Ditto.
> >       * gcc.target/i386/pr49781-1.c: Ditto.
> >       * gcc.target/i386/pr95798-1.c: Ditto.
> >       * gcc.target/i386/pr95798-2.c: Ditto.
> >       * gfortran.dg/pr77498.f: Ditto.
> > ---
> >  gcc/common.opt                                 |  2 +-
> >  gcc/doc/invoke.texi                            |  8 +++++---
> >  gcc/opts.c                                     | 18 +++++++++++++++---
> >  .../c-c++-common/Wstringop-overflow-2.c        |  2 +-
> >  gcc/testsuite/g++.dg/tree-ssa/pr81408.C        |  2 +-
> >  gcc/testsuite/g++.dg/warn/Wuninitialized-13.C  |  2 +-
> >  gcc/testsuite/gcc.dg/Warray-bounds-51.c        |  2 +-
> >  gcc/testsuite/gcc.dg/Warray-parameter-3.c      |  2 +-
> >  gcc/testsuite/gcc.dg/Wstringop-overflow-13.c   |  2 +-
> >  gcc/testsuite/gcc.dg/Wstringop-overflow-14.c   |  2 +-
> >  gcc/testsuite/gcc.dg/Wstringop-overflow-21.c   |  2 +-
> >  gcc/testsuite/gcc.dg/Wstringop-overflow-68.c   |  2 +-
> >  gcc/testsuite/gcc.dg/gomp/pr46032-2.c          |  2 +-
> >  gcc/testsuite/gcc.dg/gomp/pr46032-3.c          |  2 +-
> >  gcc/testsuite/gcc.dg/gomp/simd-2.c             |  2 +-
> >  gcc/testsuite/gcc.dg/gomp/simd-3.c             |  2 +-
> >  gcc/testsuite/gcc.dg/graphite/fuse-1.c         |  2 +-
> >  gcc/testsuite/gcc.dg/pr67089-6.c               |  2 +-
> >  gcc/testsuite/gcc.dg/pr82929-2.c               |  2 +-
> >  gcc/testsuite/gcc.dg/pr82929.c                 |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_1.c         |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_11.c        |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_15.c        |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_16.c        |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_19.c        |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_24.c        |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_25.c        |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_28.c        |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_30.c        |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_5.c         |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_7.c         |  2 +-
> >  gcc/testsuite/gcc.dg/store_merging_8.c         |  2 +-
> >  gcc/testsuite/gcc.dg/strlenopt-85.c            |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/dump-6.c         |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c      |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/pr47059.c        |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/pr86017.c        |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/pr91482.c        |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c      |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c  |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c     |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c     |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c     |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c     |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c     |  2 +-
> >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c     |  2 +-
> >  gcc/testsuite/gcc.dg/uninit-40.c               |  2 +-
> >  gcc/testsuite/gcc.dg/unroll-7.c                |  2 +-
> >  gcc/testsuite/gcc.misc-tests/help.exp          |  2 +-
> >  .../i386/avx512vpopcntdqvl-vpopcntd-1.c        |  2 +-
> >  gcc/testsuite/gcc.target/i386/pr22141.c        |  2 +-
> >  gcc/testsuite/gcc.target/i386/pr34012.c        |  2 +-
> >  gcc/testsuite/gcc.target/i386/pr49781-1.c      |  2 +-
> >  gcc/testsuite/gcc.target/i386/pr95798-1.c      |  2 +-
> >  gcc/testsuite/gcc.target/i386/pr95798-2.c      |  2 +-
> >  gcc/testsuite/gfortran.dg/pr77498.f            |  2 +-
> >  56 files changed, 74 insertions(+), 60 deletions(-)
> >
> > diff --git a/gcc/common.opt b/gcc/common.opt
> > index b921f5e3b25..4f2c0294c29 100644
> > --- a/gcc/common.opt
> > +++ b/gcc/common.opt
> > @@ -3031,7 +3031,7 @@ Perform variable tracking and also tag variables that are uninitialized.
> >
> >  ; Alias to enable both -ftree-loop-vectorize and -ftree-slp-vectorize.
> >  ftree-vectorize
> > -Common Optimization
> > +Common Var(flag_tree_vectorize) Optimization
> >  Enable vectorization on trees.
> >
> >  ftree-vectorizer-verbose=
> > diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
> > index 78cfc100ac2..be022ef8024 100644
> > --- a/gcc/doc/invoke.texi
> > +++ b/gcc/doc/invoke.texi
> > @@ -10409,9 +10409,13 @@ also turns on the following optimization flags:
> >  -fstrict-aliasing @gol
> >  -fthread-jumps @gol
> >  -ftree-builtin-call-dce @gol
> > +-ftree-loop-vectorize @gol
> >  -ftree-pre @gol
> > +-ftree-slp-vectorize @gol
> >  -ftree-switch-conversion  -ftree-tail-merge @gol
> > --ftree-vrp}
> > +-ftree-vrp @gol
> > +-fvect-cost-model @gol
>
> the above is redundant
>
> > +-fvect-cost-model=very-cheap}
> >
> >  Please note the warning under @option{-fgcse} about
> >  invoking @option{-O2} on programs that use computed gotos.
> > @@ -10431,9 +10435,7 @@ by @option{-O2} and also turns on the following optimization flags:
> >  -fsplit-loops @gol
> >  -fsplit-paths @gol
> >  -ftree-loop-distribution @gol
> > --ftree-loop-vectorize @gol
> >  -ftree-partial-pre @gol
> > --ftree-slp-vectorize @gol
> >  -funswitch-loops @gol
> >  -fvect-cost-model @gol
>
> likewise - so just remove it here as you are around
>
> >  -fvect-cost-model=dynamic @gol
> > diff --git a/gcc/opts.c b/gcc/opts.c
> > index 1d2d22d7a3f..cee372a3235 100644
> > --- a/gcc/opts.c
> > +++ b/gcc/opts.c
> > @@ -634,7 +634,8 @@ static const struct default_options default_options_table[] =
> >      { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
> >      { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
> >      { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
> > -    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
> > +    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL,
> > +      VECT_COST_MODEL_VERY_CHEAP },
> >      { OPT_LEVELS_2_PLUS, OPT_finline_functions, NULL, 1 },
> >      { OPT_LEVELS_2_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
> >
> > @@ -646,6 +647,9 @@ static const struct default_options default_options_table[] =
> >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
> >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
> >        REORDER_BLOCKS_ALGORITHM_STC },
> > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_loop_vectorize, NULL, 1 },
> > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_slp_vectorize, NULL, 1 },
> > +
> >  #ifdef INSN_SCHEDULING
> >    /* Only run the pre-regalloc scheduling pass if optimizing for speed.  */
> >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
> > @@ -663,9 +667,7 @@ static const struct default_options default_options_table[] =
> >      { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
> >      { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
> >      { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
> > -    { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
> >      { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
> > -    { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
> >      { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
> >      { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
> >      { OPT_LEVELS_3_PLUS, OPT_fversion_loops_for_strides, NULL, 1 },
> > @@ -1331,6 +1333,16 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
> >        = (opts->x_flag_unroll_loops
> >           || opts->x_flag_peel_loops
> >           || opts->x_optimize >= 3);
> > +
> > +  /* Use -fvect-cost-model=cheap instead of -fvect-cost-mode=very-cheap
> > +     by default with explicit -ftree-{loop,slp}-vectorize.  */
> > +  if (opts->x_optimize == 2
> > +      && (opts_set->x_flag_tree_loop_vectorize
> > +       || opts_set->x_flag_tree_vectorize))
> > +    SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
> > +                      VECT_COST_MODEL_CHEAP);
> > +
> > +
>
> please avoid adding excessive vertical space at the end of the function
>
> >  }
> >
> >  #define LEFT_COLUMN  27
> > diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > index 1d79930cd58..9351f7e7a1a 100644
> > --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > @@ -1,7 +1,7 @@
> >  /* PR middle-end/91458 - inconsistent warning for writing past the end
> >     of an array member
> >     { dg-do compile }
> > -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
>
> The testcase is large - what part requires this change?  Given the
> testcase was added for inconsistent warnings do they now become
> inconsistent again as we enable vectorization at -O2?
>
> That said, the testcase adjustments need some explaining - I suppose
> you didn't just slap -fno-tree-vectorize to all of those changing
> behavior?
>
void ga1_ (void)
{
  a1_.a[0] = 0;
  a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
  a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }

  struct A1 a;
  a.a[0] = 0;
  a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
  a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
  sink (&a);
}

It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
there are 2 accesses, but after enabling vectorization, there's only
one access, so one warning is missing which causes the failure.

   <bb 2> [local count: 1073741824]:
  a1__.a[0] = 0;
  a1__.a[1] = 1;
  a1__.a[2] = 2;
  MEM <char[1]> [(struct A1 *)&a + 1B] = {};
  a.n = 1;
  MEM <vector(2) char> [(char *)&a + 2B] = { 1, 2 };
  sink (&a);
  a ={v} {CLOBBER};
  return;


> Thanks,
> Richard.
>
> >  void sink (void*);
> >
> > diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > index 39e32fd4bc9..bc14309480c 100644
> > --- a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > +++ b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed" } */
> > +/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed -fno-tree-vectorize" } */
> >  struct p
> >  {
> >    char *ay;
> > diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > index 49ee878806a..60e8dd4f0e2 100644
> > --- a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > +++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > @@ -1,6 +1,6 @@
> >  /* PR c/98597 - ICE in -Wuninitialized printing a MEM_REF
> >     { dg-do compile }
> > -   { dg-options "-O2 -Wall" } */
> > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> >
> >  struct shared_count {
> >    shared_count () { }
> > diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-51.c b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > index 6028b11637c..8b81a0ccfa7 100644
> > --- a/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > +++ b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > @@ -1,7 +1,7 @@
> >  /* PR middle-end/92333 - missing variable name referencing VLA in warnings
> >     PR middle-end/82608 - missing -Warray-bounds on an out-of-bounds VLA index
> >     { dg-do compile }
> > -   { dg-options "-O2 -Wall" } */
> > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> >
> >  void sink (void*);
> >
> > diff --git a/gcc/testsuite/gcc.dg/Warray-parameter-3.c b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > index cbf3e9339f5..fbef715aa99 100644
> > --- a/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > +++ b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > @@ -59,7 +59,7 @@ void fas1 (int[static 2]);    // { dg-warning "\\\[-Warray-parameter=" }
> >
> >  /* Also verify that -Warray-bounds doesn't trigger for ordinary array
> >     parameters...  */
> > -#pragma GCC optimize "2"
> > +#pragma GCC optimize ("2,-fno-tree-vectorize")
> >
> >  __attribute__ ((noipa)) void
> >  gca3 (char a[3])
> > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > index bd513151cea..a78242bf26e 100644
> > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > @@ -3,7 +3,7 @@
> >     PR middle-end/89911 - ICE on a call with no arguments to strnlen
> >     declared with no prototype
> >     { dg-do compile }
> > -   { dg-options "-O2 -Wall" } */
> > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> >
> >  typedef __SIZE_TYPE__ size_t;
> >
> > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > index d6201b068b6..808bf87c386 100644
> > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > @@ -2,7 +2,7 @@
> >     types than char are diagnosed.
> >     { dg-do compile }
> >     { dg-require-effective-target int32plus }
> > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > +   { dg-options "-O2 -fno-tree-vectorize -Wall -Wno-array-bounds" } */
> >
> >  typedef __INT16_TYPE__  int16_t;
> >  typedef __INT32_TYPE__  int32_t;
> > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > index 3a27460220c..f418a17ca93 100644
> > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > @@ -1,7 +1,7 @@
> >  /* PR middle-end/92312 - bogus -Wstringop-overflow storing into a trailing
> >     array backed by larger buffer
> >     { dg-do compile }
> > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-tree-vectorize" } */
> >
> >  struct S0 { char a, b[0]; };
> >
> > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > index 6bcba274541..7cc1012130c 100644
> > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > @@ -2,7 +2,7 @@
> >     a larger scalar into a smaller array
> >     Verify overflow by aggregate stores.
> >     { dg-do compile }
> > -   { dg-options "-O2" } */
> > +   { dg-options "-O2 -fno-tree-vectorize" } */
> >
> >  #define A(N) (A ## N)
> >  #define Ac1 (AC1){ 0 }
> > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > index e110880bd8e..2e562618489 100644
> > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> >
> >  #define N 2
> >
> > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > index a4af7ec4a8a..da1ab487385 100644
> > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> >
> >  #define N 2
> >
> > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-2.c b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > index 85acb980f10..f4912127b81 100644
> > --- a/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > +++ b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> >  /* { dg-additional-options "-mavx" { target avx } } */
> >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-3.c b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > index 86fee858673..c75060c07ae 100644
> > --- a/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > +++ b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> >  /* { dg-additional-options "-mavx" { target avx } } */
> >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > diff --git a/gcc/testsuite/gcc.dg/graphite/fuse-1.c b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > index 527b6e5c415..61289d312c2 100644
> > --- a/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > +++ b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > @@ -1,6 +1,6 @@
> >  /* Check that the two loops are fused and that we manage to fold the two xor
> >     operations.  */
> > -/* { dg-options "-O2 -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> >
> >  /* Make sure we fuse the loops like this:
> >  AST generated by isl:
> > diff --git a/gcc/testsuite/gcc.dg/pr67089-6.c b/gcc/testsuite/gcc.dg/pr67089-6.c
> > index db2ffdfeca4..b59d75b2318 100644
> > --- a/gcc/testsuite/gcc.dg/pr67089-6.c
> > +++ b/gcc/testsuite/gcc.dg/pr67089-6.c
> > @@ -1,6 +1,6 @@
> >  /* PR target/67089 */
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> >
> >  extern void abort (void);
> >
> > diff --git a/gcc/testsuite/gcc.dg/pr82929-2.c b/gcc/testsuite/gcc.dg/pr82929-2.c
> > index 3442f91af02..b886f1cce76 100644
> > --- a/gcc/testsuite/gcc.dg/pr82929-2.c
> > +++ b/gcc/testsuite/gcc.dg/pr82929-2.c
> > @@ -1,6 +1,6 @@
> >  /* PR tree-optimization/82929 */
> >  /* { dg-do compile { target store_merge } } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  void
> >  foo (short *p, short *q, short *r)
> > diff --git a/gcc/testsuite/gcc.dg/pr82929.c b/gcc/testsuite/gcc.dg/pr82929.c
> > index bb84f2b21a3..123e1919cec 100644
> > --- a/gcc/testsuite/gcc.dg/pr82929.c
> > +++ b/gcc/testsuite/gcc.dg/pr82929.c
> > @@ -1,6 +1,6 @@
> >  /* PR tree-optimization/82929 */
> >  /* { dg-do compile { target store_merge } } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  void
> >  foo (short *p, short *q, short *r)
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_1.c b/gcc/testsuite/gcc.dg/store_merging_1.c
> > index 4cc43dfd9e1..91ca925be0e 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_1.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_1.c
> > @@ -1,6 +1,6 @@
> >  /* { dg-do compile } */
> >  /* { dg-require-effective-target store_merge } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  struct bar {
> >    int a;
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_11.c b/gcc/testsuite/gcc.dg/store_merging_11.c
> > index 2ec2394afb9..60ed5cd8bf9 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_11.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_11.c
> > @@ -1,6 +1,6 @@
> >  /* { dg-do run } */
> >  /* { dg-require-effective-target store_merge } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  struct S { unsigned char b[2]; unsigned short c; unsigned char d[4]; unsigned long e; };
> >
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_15.c b/gcc/testsuite/gcc.dg/store_merging_15.c
> > index acd7de571f8..13fcca4aa11 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_15.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_15.c
> > @@ -1,6 +1,6 @@
> >  /* { dg-do run } */
> >  /* { dg-require-effective-target store_merge } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  struct S { unsigned char a, b; unsigned short c; unsigned char d, e, f, g; unsigned long long h; };
> >
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_16.c b/gcc/testsuite/gcc.dg/store_merging_16.c
> > index 9545dcce3de..cd83f1c0fe5 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_16.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_16.c
> > @@ -2,7 +2,7 @@
> >     are either big or little endian (not pdp endian).  */
> >  /* { dg-do run { target { lp64 && { i?86-*-* x86_64-*-* powerpc*-*-* aarch64*-*-* } } } } */
> >  /* { dg-require-effective-target store_merge } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  __attribute__((noipa)) void
> >  f1 (unsigned char *p, unsigned long long q)
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_19.c b/gcc/testsuite/gcc.dg/store_merging_19.c
> > index 0841bb4deee..0a2bbc4bfde 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_19.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_19.c
> > @@ -1,6 +1,6 @@
> >  /* PR tree-optimization/83843 */
> >  /* { dg-do run } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >  /* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" { target store_merge } } } */
> >
> >  __attribute__((noipa)) void
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_24.c b/gcc/testsuite/gcc.dg/store_merging_24.c
> > index 744fe60e8e0..5291bb9e986 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_24.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_24.c
> > @@ -1,6 +1,6 @@
> >  /* PR tree-optimization/87859 */
> >  /* { dg-do run } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 19 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> >
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_25.c b/gcc/testsuite/gcc.dg/store_merging_25.c
> > index cf182190e91..96611b5e57b 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_25.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_25.c
> > @@ -1,6 +1,6 @@
> >  /* PR tree-optimization/87859 */
> >  /* { dg-do run } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 14 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> >
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_28.c b/gcc/testsuite/gcc.dg/store_merging_28.c
> > index 2d6cffc4694..fadb7fff993 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_28.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_28.c
> > @@ -1,7 +1,7 @@
> >  /* PR tree-optimization/88709 */
> >  /* { dg-do compile } */
> >  /* { dg-require-effective-target store_merge } */
> > -/* { dg-options "-O2 -fno-ipa-icf -fdump-tree-store-merging-details" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fno-ipa-icf -fdump-tree-store-merging-details" } */
> >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 16 stores" 8 "store-merging" { target { i?86-*-* x86_64-*-* } } } } */
> >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 6 stores" 1 "store-merging" { target { ! arm*-*-* } } } } */
> >
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_30.c b/gcc/testsuite/gcc.dg/store_merging_30.c
> > index 694d560a621..baf94efe733 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_30.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_30.c
> > @@ -1,7 +1,7 @@
> >  /* PR tree-optimization/94573 */
> >  /* { dg-do compile } */
> >  /* { dg-require-effective-target store_merge } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> >  /* { dg-final { scan-tree-dump "New sequence of 4 stores to replace old one of 8 stores" "store-merging" { target lp64 } } } */
> >
> >  int var[43][12];
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_5.c b/gcc/testsuite/gcc.dg/store_merging_5.c
> > index 6e7c72510ff..b0cb0da78e0 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_5.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_5.c
> > @@ -1,6 +1,6 @@
> >  /* { dg-do compile } */
> >  /* { dg-require-effective-target store_merge } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  /* Make sure that non-aliasing non-constant interspersed stores do not
> >     stop chains.  */
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_7.c b/gcc/testsuite/gcc.dg/store_merging_7.c
> > index c744ece6407..dbe000a463e 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_7.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_7.c
> > @@ -1,6 +1,6 @@
> >  /* { dg-do compile } */
> >  /* { dg-require-effective-target store_merge } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  /* Check that we can merge consecutive array members through the pointer.
> >     PR rtl-optimization/23684.  */
> > diff --git a/gcc/testsuite/gcc.dg/store_merging_8.c b/gcc/testsuite/gcc.dg/store_merging_8.c
> > index e710a544ff0..d719e0a2257 100644
> > --- a/gcc/testsuite/gcc.dg/store_merging_8.c
> > +++ b/gcc/testsuite/gcc.dg/store_merging_8.c
> > @@ -1,6 +1,6 @@
> >  /* { dg-do compile } */
> >  /* { dg-require-effective-target store_merge } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  struct baz {
> >    struct bar {
> > diff --git a/gcc/testsuite/gcc.dg/strlenopt-85.c b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > index e049e0c30e0..2ba1ee05700 100644
> > --- a/gcc/testsuite/gcc.dg/strlenopt-85.c
> > +++ b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > @@ -4,7 +4,7 @@
> >     of memory allocated by calloc() even if one or more nul bytes are
> >     written into it.
> >     { dg-do compile }
> > -   { dg-options "-O2 -fdump-tree-optimized" } */
> > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> >
> >  unsigned n0, n1;
> >
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > index 70659c00c0e..6c803908781 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > @@ -1,6 +1,6 @@
> >  /* PR middle-end/90676 - default GIMPLE dumps lack information
> >     { dg-do compile }
> > -   { dg-options "-O2 -fdump-tree-store-merging" }
> > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" }
> >     { dg-require-effective-target int32plus }
> >     { dg-require-effective-target store_merge } */
> >
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > index 50d86a00485..b9e40e964c1 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fopt-info-loop-missed" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fopt-info-loop-missed" } */
> >  extern void g(void);
> >
> >  void
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > index 9f9c61aa213..860cde12c0f 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-Os -fdump-tree-optimized" } */
> > +/* { dg-options "-Os -fno-tree-vectorize -fdump-tree-optimized" } */
> >
> >
> >  struct struct1
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > index f216e83c7b3..c7ef73ad59e 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >
> >  void f (void*);
> >
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > index 7d6a724e4ad..0ddad573129 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> >
> >  void write64 (void *p)
> >  {
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > index f68be2b3379..8c3d9a4fc58 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > @@ -1,6 +1,6 @@
> >  /* { dg-do compile } */
> >  /* { dg-do run } */
> > -/* { dg-options "-O2 -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> >
> >  void abort (void);
> >
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > index ec08d6c0318..1fc8f089345 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do run } */
> > -/* { dg-options "-O2 -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> >
> >  int arr1[105] = {2, 3, 5, 7, 11, 13, 0};
> >  int arr2[105] = {2, 3, 5, 7, 11, 13, 0};
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > index 467903bf3fc..46f0d0c2317 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > @@ -1,7 +1,7 @@
> >  /* Prefetching used to prefer nonsensical unroll factor of 5 in this testcase.  */
> >
> >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> >
> >  #define N 1000000
> >
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > index 12f09016943..3fa71685ace 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> >
> >  #define N 1000
> >  #define K 900
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > index cbd6a80d345..00f41c3e4f4 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> >
> >  #define K 1000000
> >  int a[K];
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > index da4847320b1..e8848c30acc 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> >
> >  #define K 1000000
> >  int a[K], b[K];
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > index 92b2df80ec8..2e7b5b496ea 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> >  int g(_Complex int*);
> >  int f(void)
> >  {
> > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > index 718b7466e50..7bb8d060631 100644
> > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> >  int g(_Complex int*);
> >  int f(void)
> >  {
> > diff --git a/gcc/testsuite/gcc.dg/uninit-40.c b/gcc/testsuite/gcc.dg/uninit-40.c
> > index c015191ca32..8708079d397 100644
> > --- a/gcc/testsuite/gcc.dg/uninit-40.c
> > +++ b/gcc/testsuite/gcc.dg/uninit-40.c
> > @@ -1,6 +1,6 @@
> >  /* PR tree-optimization/98597 */
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -Wuninitialized" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -Wuninitialized" } */
> >
> >  union U { double d; int i; float f; };
> >  struct S { char a; int b; char c; unsigned d; union U e; int f[3]; unsigned g[3]; };
> > diff --git a/gcc/testsuite/gcc.dg/unroll-7.c b/gcc/testsuite/gcc.dg/unroll-7.c
> > index 055369bf8b1..695af5757cc 100644
> > --- a/gcc/testsuite/gcc.dg/unroll-7.c
> > +++ b/gcc/testsuite/gcc.dg/unroll-7.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> >  /* { dg-require-effective-target int32plus } */
> >
> >  extern int *a;
> > diff --git a/gcc/testsuite/gcc.misc-tests/help.exp b/gcc/testsuite/gcc.misc-tests/help.exp
> > index 5e034d26947..eb6d8686c6a 100644
> > --- a/gcc/testsuite/gcc.misc-tests/help.exp
> > +++ b/gcc/testsuite/gcc.misc-tests/help.exp
> > @@ -79,7 +79,7 @@ check_for_options c "--help=target,optimizers" "" "" ""
> >  check_for_options c "--help=warnings,^joined,^undocumented" "" "" ""
> >  check_for_options c "-Q -O2 --help=optimizers" {
> >  -O
> > --ftree-loop-vectorize[^\n]*disabled
> > +-ftree-loop-vectorize[^\n]*enabled
> >  } "  -g  " ""
> >  check_for_options c "-Q -O3 --help=optimizers" {
> >  -O
> > diff --git a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > index 709cd21e671..a732bc466db 100644
> > --- a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > +++ b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do run } */
> > -/* { dg-options "-O2 -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> >  /* { dg-require-effective-target avx512vl } */
> >  /* { dg-require-effective-target avx512vpopcntdqvl } */
> >  /* { dg-require-effective-target avx512bw } */
> > diff --git a/gcc/testsuite/gcc.target/i386/pr22141.c b/gcc/testsuite/gcc.target/i386/pr22141.c
> > index 036422e8ccf..b68b97f3f72 100644
> > --- a/gcc/testsuite/gcc.target/i386/pr22141.c
> > +++ b/gcc/testsuite/gcc.target/i386/pr22141.c
> > @@ -1,6 +1,6 @@
> >  /* PR middle-end/22141 */
> >  /* { dg-do compile } */
> > -/* { dg-options "-Os" } */
> > +/* { dg-options "-Os -fno-tree-vectorize" } */
> >
> >  extern void abort (void);
> >
> > diff --git a/gcc/testsuite/gcc.target/i386/pr34012.c b/gcc/testsuite/gcc.target/i386/pr34012.c
> > index d0cffa05290..1c1f0eea52e 100644
> > --- a/gcc/testsuite/gcc.target/i386/pr34012.c
> > +++ b/gcc/testsuite/gcc.target/i386/pr34012.c
> > @@ -1,7 +1,7 @@
> >  /* PR rtl-optimization/34012 */
> >  /* { dg-do compile } */
> >  /* { dg-require-effective-target lp64 } */
> > -/* { dg-options "-O2 -fno-store-merging" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fno-store-merging" } */
> >
> >  void bar (long int *);
> >  void
> > diff --git a/gcc/testsuite/gcc.target/i386/pr49781-1.c b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > index 60f9d50d866..d5a2e32db97 100644
> > --- a/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > +++ b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > @@ -1,5 +1,5 @@
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -fpic -mtune=generic" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -fpic -mtune=generic" } */
> >  /* { dg-require-effective-target fpic } */
> >
> >  static int heap[2*(256 +1+29)+1];
> > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-1.c b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > index 9a7e32d6f2f..526f48921fd 100644
> > --- a/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > +++ b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > @@ -1,6 +1,6 @@
> >  /* PR target/95798 */
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-2.c b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > index c670d3780e8..6b5c5a73e96 100644
> > --- a/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > +++ b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > @@ -1,6 +1,6 @@
> >  /* PR target/95798 */
> >  /* { dg-do compile } */
> > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > diff --git a/gcc/testsuite/gfortran.dg/pr77498.f b/gcc/testsuite/gfortran.dg/pr77498.f
> > index f957b57bb00..a0fc8275a84 100644
> > --- a/gcc/testsuite/gfortran.dg/pr77498.f
> > +++ b/gcc/testsuite/gfortran.dg/pr77498.f
> > @@ -1,5 +1,5 @@
> >  ! { dg-do compile }
> > -! { dg-options "-O2 -ffast-math -fdump-tree-pre" }
> > +! { dg-options "-O2 -fno-tree-vectorize -ffast-math -fdump-tree-pre" }
> >
> >        subroutine foo(U,V,R,N,A)
> >        integer N
> >
>
> --
> Richard Biener <rguenther@suse.de>
> SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
Richard Biener Sept. 16, 2021, 12:31 p.m. UTC | #3
On Thu, 16 Sep 2021, Hongtao Liu wrote:

> On Thu, Sep 16, 2021 at 4:23 PM Richard Biener via Gcc-patches
> <gcc-patches@gcc.gnu.org> wrote:
> >
> > On Thu, 16 Sep 2021, liuhongt wrote:
> >
> > > Ping
> > > rebased on latest trunk.
> > >
> > > gcc/ChangeLog:
> > >
> > >       * common.opt (ftree-vectorize): Add Var(flag_tree_vectorize).
> > >       * doc/invoke.texi (Options That Control Optimization): Update
> > >       documents.
> > >       * opts.c (default_options_table): Enable auto-vectorization at
> > >       O2 with very-cheap cost model.
> > >       (finish_options): Use cheap cost model for
> > >       explicit -ftree{,-loop}-vectorize.
> > >
> > > gcc/testsuite/ChangeLog:
> > >
> > >       * c-c++-common/Wstringop-overflow-2.c: Adjust testcase.
> > >       * g++.dg/tree-ssa/pr81408.C: Ditto.
> > >       * g++.dg/warn/Wuninitialized-13.C: Ditto.
> > >       * gcc.dg/Warray-bounds-51.c: Ditto.
> > >       * gcc.dg/Warray-parameter-3.c: Ditto.
> > >       * gcc.dg/Wstringop-overflow-13.c: Ditto.
> > >       * gcc.dg/Wstringop-overflow-14.c: Ditto.
> > >       * gcc.dg/Wstringop-overflow-21.c: Ditto.
> > >       * gcc.dg/Wstringop-overflow-68.c: Ditto.
> > >       * gcc.dg/gomp/pr46032-2.c: Ditto.
> > >       * gcc.dg/gomp/pr46032-3.c: Ditto.
> > >       * gcc.dg/gomp/simd-2.c: Ditto.
> > >       * gcc.dg/gomp/simd-3.c: Ditto.
> > >       * gcc.dg/graphite/fuse-1.c: Ditto.
> > >       * gcc.dg/pr67089-6.c: Ditto.
> > >       * gcc.dg/pr82929-2.c: Ditto.
> > >       * gcc.dg/pr82929.c: Ditto.
> > >       * gcc.dg/store_merging_1.c: Ditto.
> > >       * gcc.dg/store_merging_11.c: Ditto.
> > >       * gcc.dg/store_merging_15.c: Ditto.
> > >       * gcc.dg/store_merging_16.c: Ditto.
> > >       * gcc.dg/store_merging_19.c: Ditto.
> > >       * gcc.dg/store_merging_24.c: Ditto.
> > >       * gcc.dg/store_merging_25.c: Ditto.
> > >       * gcc.dg/store_merging_28.c: Ditto.
> > >       * gcc.dg/store_merging_30.c: Ditto.
> > >       * gcc.dg/store_merging_5.c: Ditto.
> > >       * gcc.dg/store_merging_7.c: Ditto.
> > >       * gcc.dg/store_merging_8.c: Ditto.
> > >       * gcc.dg/strlenopt-85.c: Ditto.
> > >       * gcc.dg/tree-ssa/dump-6.c: Ditto.
> > >       * gcc.dg/tree-ssa/pr19210-1.c: Ditto.
> > >       * gcc.dg/tree-ssa/pr47059.c: Ditto.
> > >       * gcc.dg/tree-ssa/pr86017.c: Ditto.
> > >       * gcc.dg/tree-ssa/pr91482.c: Ditto.
> > >       * gcc.dg/tree-ssa/predcom-1.c: Ditto.
> > >       * gcc.dg/tree-ssa/predcom-dse-3.c: Ditto.
> > >       * gcc.dg/tree-ssa/prefetch-3.c: Ditto.
> > >       * gcc.dg/tree-ssa/prefetch-6.c: Ditto.
> > >       * gcc.dg/tree-ssa/prefetch-8.c: Ditto.
> > >       * gcc.dg/tree-ssa/prefetch-9.c: Ditto.
> > >       * gcc.dg/tree-ssa/ssa-dse-18.c: Ditto.
> > >       * gcc.dg/tree-ssa/ssa-dse-19.c: Ditto.
> > >       * gcc.dg/uninit-40.c: Ditto.
> > >       * gcc.dg/unroll-7.c: Ditto.
> > >       * gcc.misc-tests/help.exp: Ditto.
> > >       * gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c: Ditto.
> > >       * gcc.target/i386/pr22141.c: Ditto.
> > >       * gcc.target/i386/pr34012.c: Ditto.
> > >       * gcc.target/i386/pr49781-1.c: Ditto.
> > >       * gcc.target/i386/pr95798-1.c: Ditto.
> > >       * gcc.target/i386/pr95798-2.c: Ditto.
> > >       * gfortran.dg/pr77498.f: Ditto.
> > > ---
> > >  gcc/common.opt                                 |  2 +-
> > >  gcc/doc/invoke.texi                            |  8 +++++---
> > >  gcc/opts.c                                     | 18 +++++++++++++++---
> > >  .../c-c++-common/Wstringop-overflow-2.c        |  2 +-
> > >  gcc/testsuite/g++.dg/tree-ssa/pr81408.C        |  2 +-
> > >  gcc/testsuite/g++.dg/warn/Wuninitialized-13.C  |  2 +-
> > >  gcc/testsuite/gcc.dg/Warray-bounds-51.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/Warray-parameter-3.c      |  2 +-
> > >  gcc/testsuite/gcc.dg/Wstringop-overflow-13.c   |  2 +-
> > >  gcc/testsuite/gcc.dg/Wstringop-overflow-14.c   |  2 +-
> > >  gcc/testsuite/gcc.dg/Wstringop-overflow-21.c   |  2 +-
> > >  gcc/testsuite/gcc.dg/Wstringop-overflow-68.c   |  2 +-
> > >  gcc/testsuite/gcc.dg/gomp/pr46032-2.c          |  2 +-
> > >  gcc/testsuite/gcc.dg/gomp/pr46032-3.c          |  2 +-
> > >  gcc/testsuite/gcc.dg/gomp/simd-2.c             |  2 +-
> > >  gcc/testsuite/gcc.dg/gomp/simd-3.c             |  2 +-
> > >  gcc/testsuite/gcc.dg/graphite/fuse-1.c         |  2 +-
> > >  gcc/testsuite/gcc.dg/pr67089-6.c               |  2 +-
> > >  gcc/testsuite/gcc.dg/pr82929-2.c               |  2 +-
> > >  gcc/testsuite/gcc.dg/pr82929.c                 |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_1.c         |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_11.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_15.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_16.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_19.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_24.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_25.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_28.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_30.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_5.c         |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_7.c         |  2 +-
> > >  gcc/testsuite/gcc.dg/store_merging_8.c         |  2 +-
> > >  gcc/testsuite/gcc.dg/strlenopt-85.c            |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/dump-6.c         |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c      |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/pr47059.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/pr86017.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/pr91482.c        |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c      |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c  |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c     |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c     |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c     |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c     |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c     |  2 +-
> > >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c     |  2 +-
> > >  gcc/testsuite/gcc.dg/uninit-40.c               |  2 +-
> > >  gcc/testsuite/gcc.dg/unroll-7.c                |  2 +-
> > >  gcc/testsuite/gcc.misc-tests/help.exp          |  2 +-
> > >  .../i386/avx512vpopcntdqvl-vpopcntd-1.c        |  2 +-
> > >  gcc/testsuite/gcc.target/i386/pr22141.c        |  2 +-
> > >  gcc/testsuite/gcc.target/i386/pr34012.c        |  2 +-
> > >  gcc/testsuite/gcc.target/i386/pr49781-1.c      |  2 +-
> > >  gcc/testsuite/gcc.target/i386/pr95798-1.c      |  2 +-
> > >  gcc/testsuite/gcc.target/i386/pr95798-2.c      |  2 +-
> > >  gcc/testsuite/gfortran.dg/pr77498.f            |  2 +-
> > >  56 files changed, 74 insertions(+), 60 deletions(-)
> > >
> > > diff --git a/gcc/common.opt b/gcc/common.opt
> > > index b921f5e3b25..4f2c0294c29 100644
> > > --- a/gcc/common.opt
> > > +++ b/gcc/common.opt
> > > @@ -3031,7 +3031,7 @@ Perform variable tracking and also tag variables that are uninitialized.
> > >
> > >  ; Alias to enable both -ftree-loop-vectorize and -ftree-slp-vectorize.
> > >  ftree-vectorize
> > > -Common Optimization
> > > +Common Var(flag_tree_vectorize) Optimization
> > >  Enable vectorization on trees.
> > >
> > >  ftree-vectorizer-verbose=
> > > diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
> > > index 78cfc100ac2..be022ef8024 100644
> > > --- a/gcc/doc/invoke.texi
> > > +++ b/gcc/doc/invoke.texi
> > > @@ -10409,9 +10409,13 @@ also turns on the following optimization flags:
> > >  -fstrict-aliasing @gol
> > >  -fthread-jumps @gol
> > >  -ftree-builtin-call-dce @gol
> > > +-ftree-loop-vectorize @gol
> > >  -ftree-pre @gol
> > > +-ftree-slp-vectorize @gol
> > >  -ftree-switch-conversion  -ftree-tail-merge @gol
> > > --ftree-vrp}
> > > +-ftree-vrp @gol
> > > +-fvect-cost-model @gol
> >
> > the above is redundant
> >
> > > +-fvect-cost-model=very-cheap}
> > >
> > >  Please note the warning under @option{-fgcse} about
> > >  invoking @option{-O2} on programs that use computed gotos.
> > > @@ -10431,9 +10435,7 @@ by @option{-O2} and also turns on the following optimization flags:
> > >  -fsplit-loops @gol
> > >  -fsplit-paths @gol
> > >  -ftree-loop-distribution @gol
> > > --ftree-loop-vectorize @gol
> > >  -ftree-partial-pre @gol
> > > --ftree-slp-vectorize @gol
> > >  -funswitch-loops @gol
> > >  -fvect-cost-model @gol
> >
> > likewise - so just remove it here as you are around
> >
> > >  -fvect-cost-model=dynamic @gol
> > > diff --git a/gcc/opts.c b/gcc/opts.c
> > > index 1d2d22d7a3f..cee372a3235 100644
> > > --- a/gcc/opts.c
> > > +++ b/gcc/opts.c
> > > @@ -634,7 +634,8 @@ static const struct default_options default_options_table[] =
> > >      { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
> > >      { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
> > >      { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
> > > -    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
> > > +    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL,
> > > +      VECT_COST_MODEL_VERY_CHEAP },
> > >      { OPT_LEVELS_2_PLUS, OPT_finline_functions, NULL, 1 },
> > >      { OPT_LEVELS_2_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
> > >
> > > @@ -646,6 +647,9 @@ static const struct default_options default_options_table[] =
> > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
> > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
> > >        REORDER_BLOCKS_ALGORITHM_STC },
> > > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_loop_vectorize, NULL, 1 },
> > > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_slp_vectorize, NULL, 1 },
> > > +
> > >  #ifdef INSN_SCHEDULING
> > >    /* Only run the pre-regalloc scheduling pass if optimizing for speed.  */
> > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
> > > @@ -663,9 +667,7 @@ static const struct default_options default_options_table[] =
> > >      { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
> > >      { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
> > >      { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
> > > -    { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
> > >      { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
> > > -    { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
> > >      { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
> > >      { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
> > >      { OPT_LEVELS_3_PLUS, OPT_fversion_loops_for_strides, NULL, 1 },
> > > @@ -1331,6 +1333,16 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
> > >        = (opts->x_flag_unroll_loops
> > >           || opts->x_flag_peel_loops
> > >           || opts->x_optimize >= 3);
> > > +
> > > +  /* Use -fvect-cost-model=cheap instead of -fvect-cost-mode=very-cheap
> > > +     by default with explicit -ftree-{loop,slp}-vectorize.  */
> > > +  if (opts->x_optimize == 2
> > > +      && (opts_set->x_flag_tree_loop_vectorize
> > > +       || opts_set->x_flag_tree_vectorize))
> > > +    SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
> > > +                      VECT_COST_MODEL_CHEAP);
> > > +
> > > +
> >
> > please avoid adding excessive vertical space at the end of the function
> >
> > >  }
> > >
> > >  #define LEFT_COLUMN  27
> > > diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > index 1d79930cd58..9351f7e7a1a 100644
> > > --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > @@ -1,7 +1,7 @@
> > >  /* PR middle-end/91458 - inconsistent warning for writing past the end
> > >     of an array member
> > >     { dg-do compile }
> > > -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> > > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> >
> > The testcase is large - what part requires this change?  Given the
> > testcase was added for inconsistent warnings do they now become
> > inconsistent again as we enable vectorization at -O2?
> >
> > That said, the testcase adjustments need some explaining - I suppose
> > you didn't just slap -fno-tree-vectorize to all of those changing
> > behavior?
> >
> void ga1_ (void)
> {
>   a1_.a[0] = 0;
>   a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
>   a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> 
>   struct A1 a;
>   a.a[0] = 0;
>   a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
>   a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
>   sink (&a);
> }
> 
> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> there are 2 accesses, but after enabling vectorization, there's only
> one access, so one warning is missing which causes the failure.
> 
>    <bb 2> [local count: 1073741824]:
>   a1__.a[0] = 0;
>   a1__.a[1] = 1;
>   a1__.a[2] = 2;
>   MEM <char[1]> [(struct A1 *)&a + 1B] = {};
>   a.n = 1;
>   MEM <vector(2) char> [(char *)&a + 2B] = { 1, 2 };
>   sink (&a);
>   a ={v} {CLOBBER};
>   return;

I see, so it seems you looked into each instance you changed - I don't
want to repeat that exercise here.

Thus the patch is OK with the minor nits I had fixed.  Note that
other targets testsuites likely will need similar adjustments so
please watch out (but a lot of target people are in CC and could
deal with such fallout themselves).

Please also prepare an entry for gcc-12/changes.html since this
is an important change.  Make sure to mention -fvect-cost-model
since otherwise people might expect vectorization to be as good
as with -O3.

Thanks,
Richard.

> 
> > Thanks,
> > Richard.
> >
> > >  void sink (void*);
> > >
> > > diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > index 39e32fd4bc9..bc14309480c 100644
> > > --- a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > +++ b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed" } */
> > > +/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed -fno-tree-vectorize" } */
> > >  struct p
> > >  {
> > >    char *ay;
> > > diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > index 49ee878806a..60e8dd4f0e2 100644
> > > --- a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > +++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > @@ -1,6 +1,6 @@
> > >  /* PR c/98597 - ICE in -Wuninitialized printing a MEM_REF
> > >     { dg-do compile }
> > > -   { dg-options "-O2 -Wall" } */
> > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > >
> > >  struct shared_count {
> > >    shared_count () { }
> > > diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-51.c b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > index 6028b11637c..8b81a0ccfa7 100644
> > > --- a/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > +++ b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > @@ -1,7 +1,7 @@
> > >  /* PR middle-end/92333 - missing variable name referencing VLA in warnings
> > >     PR middle-end/82608 - missing -Warray-bounds on an out-of-bounds VLA index
> > >     { dg-do compile }
> > > -   { dg-options "-O2 -Wall" } */
> > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > >
> > >  void sink (void*);
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/Warray-parameter-3.c b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > index cbf3e9339f5..fbef715aa99 100644
> > > --- a/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > +++ b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > @@ -59,7 +59,7 @@ void fas1 (int[static 2]);    // { dg-warning "\\\[-Warray-parameter=" }
> > >
> > >  /* Also verify that -Warray-bounds doesn't trigger for ordinary array
> > >     parameters...  */
> > > -#pragma GCC optimize "2"
> > > +#pragma GCC optimize ("2,-fno-tree-vectorize")
> > >
> > >  __attribute__ ((noipa)) void
> > >  gca3 (char a[3])
> > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > index bd513151cea..a78242bf26e 100644
> > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > @@ -3,7 +3,7 @@
> > >     PR middle-end/89911 - ICE on a call with no arguments to strnlen
> > >     declared with no prototype
> > >     { dg-do compile }
> > > -   { dg-options "-O2 -Wall" } */
> > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > >
> > >  typedef __SIZE_TYPE__ size_t;
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > index d6201b068b6..808bf87c386 100644
> > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > @@ -2,7 +2,7 @@
> > >     types than char are diagnosed.
> > >     { dg-do compile }
> > >     { dg-require-effective-target int32plus }
> > > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > > +   { dg-options "-O2 -fno-tree-vectorize -Wall -Wno-array-bounds" } */
> > >
> > >  typedef __INT16_TYPE__  int16_t;
> > >  typedef __INT32_TYPE__  int32_t;
> > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > index 3a27460220c..f418a17ca93 100644
> > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > @@ -1,7 +1,7 @@
> > >  /* PR middle-end/92312 - bogus -Wstringop-overflow storing into a trailing
> > >     array backed by larger buffer
> > >     { dg-do compile }
> > > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-tree-vectorize" } */
> > >
> > >  struct S0 { char a, b[0]; };
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > index 6bcba274541..7cc1012130c 100644
> > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > @@ -2,7 +2,7 @@
> > >     a larger scalar into a smaller array
> > >     Verify overflow by aggregate stores.
> > >     { dg-do compile }
> > > -   { dg-options "-O2" } */
> > > +   { dg-options "-O2 -fno-tree-vectorize" } */
> > >
> > >  #define A(N) (A ## N)
> > >  #define Ac1 (AC1){ 0 }
> > > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > index e110880bd8e..2e562618489 100644
> > > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > >
> > >  #define N 2
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > index a4af7ec4a8a..da1ab487385 100644
> > > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > >
> > >  #define N 2
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-2.c b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > index 85acb980f10..f4912127b81 100644
> > > --- a/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > +++ b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> > >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> > >  /* { dg-additional-options "-mavx" { target avx } } */
> > >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-3.c b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > index 86fee858673..c75060c07ae 100644
> > > --- a/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > +++ b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> > >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> > >  /* { dg-additional-options "-mavx" { target avx } } */
> > >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > > diff --git a/gcc/testsuite/gcc.dg/graphite/fuse-1.c b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > index 527b6e5c415..61289d312c2 100644
> > > --- a/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > +++ b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > @@ -1,6 +1,6 @@
> > >  /* Check that the two loops are fused and that we manage to fold the two xor
> > >     operations.  */
> > > -/* { dg-options "-O2 -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> > >
> > >  /* Make sure we fuse the loops like this:
> > >  AST generated by isl:
> > > diff --git a/gcc/testsuite/gcc.dg/pr67089-6.c b/gcc/testsuite/gcc.dg/pr67089-6.c
> > > index db2ffdfeca4..b59d75b2318 100644
> > > --- a/gcc/testsuite/gcc.dg/pr67089-6.c
> > > +++ b/gcc/testsuite/gcc.dg/pr67089-6.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR target/67089 */
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> > >
> > >  extern void abort (void);
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/pr82929-2.c b/gcc/testsuite/gcc.dg/pr82929-2.c
> > > index 3442f91af02..b886f1cce76 100644
> > > --- a/gcc/testsuite/gcc.dg/pr82929-2.c
> > > +++ b/gcc/testsuite/gcc.dg/pr82929-2.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR tree-optimization/82929 */
> > >  /* { dg-do compile { target store_merge } } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  void
> > >  foo (short *p, short *q, short *r)
> > > diff --git a/gcc/testsuite/gcc.dg/pr82929.c b/gcc/testsuite/gcc.dg/pr82929.c
> > > index bb84f2b21a3..123e1919cec 100644
> > > --- a/gcc/testsuite/gcc.dg/pr82929.c
> > > +++ b/gcc/testsuite/gcc.dg/pr82929.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR tree-optimization/82929 */
> > >  /* { dg-do compile { target store_merge } } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  void
> > >  foo (short *p, short *q, short *r)
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_1.c b/gcc/testsuite/gcc.dg/store_merging_1.c
> > > index 4cc43dfd9e1..91ca925be0e 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_1.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_1.c
> > > @@ -1,6 +1,6 @@
> > >  /* { dg-do compile } */
> > >  /* { dg-require-effective-target store_merge } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  struct bar {
> > >    int a;
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_11.c b/gcc/testsuite/gcc.dg/store_merging_11.c
> > > index 2ec2394afb9..60ed5cd8bf9 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_11.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_11.c
> > > @@ -1,6 +1,6 @@
> > >  /* { dg-do run } */
> > >  /* { dg-require-effective-target store_merge } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  struct S { unsigned char b[2]; unsigned short c; unsigned char d[4]; unsigned long e; };
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_15.c b/gcc/testsuite/gcc.dg/store_merging_15.c
> > > index acd7de571f8..13fcca4aa11 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_15.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_15.c
> > > @@ -1,6 +1,6 @@
> > >  /* { dg-do run } */
> > >  /* { dg-require-effective-target store_merge } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  struct S { unsigned char a, b; unsigned short c; unsigned char d, e, f, g; unsigned long long h; };
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_16.c b/gcc/testsuite/gcc.dg/store_merging_16.c
> > > index 9545dcce3de..cd83f1c0fe5 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_16.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_16.c
> > > @@ -2,7 +2,7 @@
> > >     are either big or little endian (not pdp endian).  */
> > >  /* { dg-do run { target { lp64 && { i?86-*-* x86_64-*-* powerpc*-*-* aarch64*-*-* } } } } */
> > >  /* { dg-require-effective-target store_merge } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  __attribute__((noipa)) void
> > >  f1 (unsigned char *p, unsigned long long q)
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_19.c b/gcc/testsuite/gcc.dg/store_merging_19.c
> > > index 0841bb4deee..0a2bbc4bfde 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_19.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_19.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR tree-optimization/83843 */
> > >  /* { dg-do run } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >  /* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" { target store_merge } } } */
> > >
> > >  __attribute__((noipa)) void
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_24.c b/gcc/testsuite/gcc.dg/store_merging_24.c
> > > index 744fe60e8e0..5291bb9e986 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_24.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_24.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR tree-optimization/87859 */
> > >  /* { dg-do run } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 19 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_25.c b/gcc/testsuite/gcc.dg/store_merging_25.c
> > > index cf182190e91..96611b5e57b 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_25.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_25.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR tree-optimization/87859 */
> > >  /* { dg-do run } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 14 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_28.c b/gcc/testsuite/gcc.dg/store_merging_28.c
> > > index 2d6cffc4694..fadb7fff993 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_28.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_28.c
> > > @@ -1,7 +1,7 @@
> > >  /* PR tree-optimization/88709 */
> > >  /* { dg-do compile } */
> > >  /* { dg-require-effective-target store_merge } */
> > > -/* { dg-options "-O2 -fno-ipa-icf -fdump-tree-store-merging-details" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-ipa-icf -fdump-tree-store-merging-details" } */
> > >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 16 stores" 8 "store-merging" { target { i?86-*-* x86_64-*-* } } } } */
> > >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 6 stores" 1 "store-merging" { target { ! arm*-*-* } } } } */
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_30.c b/gcc/testsuite/gcc.dg/store_merging_30.c
> > > index 694d560a621..baf94efe733 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_30.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_30.c
> > > @@ -1,7 +1,7 @@
> > >  /* PR tree-optimization/94573 */
> > >  /* { dg-do compile } */
> > >  /* { dg-require-effective-target store_merge } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > >  /* { dg-final { scan-tree-dump "New sequence of 4 stores to replace old one of 8 stores" "store-merging" { target lp64 } } } */
> > >
> > >  int var[43][12];
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_5.c b/gcc/testsuite/gcc.dg/store_merging_5.c
> > > index 6e7c72510ff..b0cb0da78e0 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_5.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_5.c
> > > @@ -1,6 +1,6 @@
> > >  /* { dg-do compile } */
> > >  /* { dg-require-effective-target store_merge } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  /* Make sure that non-aliasing non-constant interspersed stores do not
> > >     stop chains.  */
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_7.c b/gcc/testsuite/gcc.dg/store_merging_7.c
> > > index c744ece6407..dbe000a463e 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_7.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_7.c
> > > @@ -1,6 +1,6 @@
> > >  /* { dg-do compile } */
> > >  /* { dg-require-effective-target store_merge } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  /* Check that we can merge consecutive array members through the pointer.
> > >     PR rtl-optimization/23684.  */
> > > diff --git a/gcc/testsuite/gcc.dg/store_merging_8.c b/gcc/testsuite/gcc.dg/store_merging_8.c
> > > index e710a544ff0..d719e0a2257 100644
> > > --- a/gcc/testsuite/gcc.dg/store_merging_8.c
> > > +++ b/gcc/testsuite/gcc.dg/store_merging_8.c
> > > @@ -1,6 +1,6 @@
> > >  /* { dg-do compile } */
> > >  /* { dg-require-effective-target store_merge } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  struct baz {
> > >    struct bar {
> > > diff --git a/gcc/testsuite/gcc.dg/strlenopt-85.c b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > index e049e0c30e0..2ba1ee05700 100644
> > > --- a/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > +++ b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > @@ -4,7 +4,7 @@
> > >     of memory allocated by calloc() even if one or more nul bytes are
> > >     written into it.
> > >     { dg-do compile }
> > > -   { dg-options "-O2 -fdump-tree-optimized" } */
> > > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > >
> > >  unsigned n0, n1;
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > index 70659c00c0e..6c803908781 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR middle-end/90676 - default GIMPLE dumps lack information
> > >     { dg-do compile }
> > > -   { dg-options "-O2 -fdump-tree-store-merging" }
> > > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" }
> > >     { dg-require-effective-target int32plus }
> > >     { dg-require-effective-target store_merge } */
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > index 50d86a00485..b9e40e964c1 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fopt-info-loop-missed" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fopt-info-loop-missed" } */
> > >  extern void g(void);
> > >
> > >  void
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > index 9f9c61aa213..860cde12c0f 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-Os -fdump-tree-optimized" } */
> > > +/* { dg-options "-Os -fno-tree-vectorize -fdump-tree-optimized" } */
> > >
> > >
> > >  struct struct1
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > index f216e83c7b3..c7ef73ad59e 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > >
> > >  void f (void*);
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > index 7d6a724e4ad..0ddad573129 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> > >
> > >  void write64 (void *p)
> > >  {
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > index f68be2b3379..8c3d9a4fc58 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > @@ -1,6 +1,6 @@
> > >  /* { dg-do compile } */
> > >  /* { dg-do run } */
> > > -/* { dg-options "-O2 -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> > >
> > >  void abort (void);
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > index ec08d6c0318..1fc8f089345 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do run } */
> > > -/* { dg-options "-O2 -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> > >
> > >  int arr1[105] = {2, 3, 5, 7, 11, 13, 0};
> > >  int arr2[105] = {2, 3, 5, 7, 11, 13, 0};
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > index 467903bf3fc..46f0d0c2317 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > @@ -1,7 +1,7 @@
> > >  /* Prefetching used to prefer nonsensical unroll factor of 5 in this testcase.  */
> > >
> > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> > >
> > >  #define N 1000000
> > >
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > index 12f09016943..3fa71685ace 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> > >
> > >  #define N 1000
> > >  #define K 900
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > index cbd6a80d345..00f41c3e4f4 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > >
> > >  #define K 1000000
> > >  int a[K];
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > index da4847320b1..e8848c30acc 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > >
> > >  #define K 1000000
> > >  int a[K], b[K];
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > index 92b2df80ec8..2e7b5b496ea 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > >  int g(_Complex int*);
> > >  int f(void)
> > >  {
> > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > index 718b7466e50..7bb8d060631 100644
> > > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > >  int g(_Complex int*);
> > >  int f(void)
> > >  {
> > > diff --git a/gcc/testsuite/gcc.dg/uninit-40.c b/gcc/testsuite/gcc.dg/uninit-40.c
> > > index c015191ca32..8708079d397 100644
> > > --- a/gcc/testsuite/gcc.dg/uninit-40.c
> > > +++ b/gcc/testsuite/gcc.dg/uninit-40.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR tree-optimization/98597 */
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -Wuninitialized" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -Wuninitialized" } */
> > >
> > >  union U { double d; int i; float f; };
> > >  struct S { char a; int b; char c; unsigned d; union U e; int f[3]; unsigned g[3]; };
> > > diff --git a/gcc/testsuite/gcc.dg/unroll-7.c b/gcc/testsuite/gcc.dg/unroll-7.c
> > > index 055369bf8b1..695af5757cc 100644
> > > --- a/gcc/testsuite/gcc.dg/unroll-7.c
> > > +++ b/gcc/testsuite/gcc.dg/unroll-7.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> > >  /* { dg-require-effective-target int32plus } */
> > >
> > >  extern int *a;
> > > diff --git a/gcc/testsuite/gcc.misc-tests/help.exp b/gcc/testsuite/gcc.misc-tests/help.exp
> > > index 5e034d26947..eb6d8686c6a 100644
> > > --- a/gcc/testsuite/gcc.misc-tests/help.exp
> > > +++ b/gcc/testsuite/gcc.misc-tests/help.exp
> > > @@ -79,7 +79,7 @@ check_for_options c "--help=target,optimizers" "" "" ""
> > >  check_for_options c "--help=warnings,^joined,^undocumented" "" "" ""
> > >  check_for_options c "-Q -O2 --help=optimizers" {
> > >  -O
> > > --ftree-loop-vectorize[^\n]*disabled
> > > +-ftree-loop-vectorize[^\n]*enabled
> > >  } "  -g  " ""
> > >  check_for_options c "-Q -O3 --help=optimizers" {
> > >  -O
> > > diff --git a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > index 709cd21e671..a732bc466db 100644
> > > --- a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > +++ b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do run } */
> > > -/* { dg-options "-O2 -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> > >  /* { dg-require-effective-target avx512vl } */
> > >  /* { dg-require-effective-target avx512vpopcntdqvl } */
> > >  /* { dg-require-effective-target avx512bw } */
> > > diff --git a/gcc/testsuite/gcc.target/i386/pr22141.c b/gcc/testsuite/gcc.target/i386/pr22141.c
> > > index 036422e8ccf..b68b97f3f72 100644
> > > --- a/gcc/testsuite/gcc.target/i386/pr22141.c
> > > +++ b/gcc/testsuite/gcc.target/i386/pr22141.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR middle-end/22141 */
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-Os" } */
> > > +/* { dg-options "-Os -fno-tree-vectorize" } */
> > >
> > >  extern void abort (void);
> > >
> > > diff --git a/gcc/testsuite/gcc.target/i386/pr34012.c b/gcc/testsuite/gcc.target/i386/pr34012.c
> > > index d0cffa05290..1c1f0eea52e 100644
> > > --- a/gcc/testsuite/gcc.target/i386/pr34012.c
> > > +++ b/gcc/testsuite/gcc.target/i386/pr34012.c
> > > @@ -1,7 +1,7 @@
> > >  /* PR rtl-optimization/34012 */
> > >  /* { dg-do compile } */
> > >  /* { dg-require-effective-target lp64 } */
> > > -/* { dg-options "-O2 -fno-store-merging" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-store-merging" } */
> > >
> > >  void bar (long int *);
> > >  void
> > > diff --git a/gcc/testsuite/gcc.target/i386/pr49781-1.c b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > index 60f9d50d866..d5a2e32db97 100644
> > > --- a/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > +++ b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > @@ -1,5 +1,5 @@
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -fpic -mtune=generic" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -fpic -mtune=generic" } */
> > >  /* { dg-require-effective-target fpic } */
> > >
> > >  static int heap[2*(256 +1+29)+1];
> > > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-1.c b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > index 9a7e32d6f2f..526f48921fd 100644
> > > --- a/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > +++ b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR target/95798 */
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> > >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-2.c b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > index c670d3780e8..6b5c5a73e96 100644
> > > --- a/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > +++ b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > @@ -1,6 +1,6 @@
> > >  /* PR target/95798 */
> > >  /* { dg-do compile } */
> > > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> > >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > diff --git a/gcc/testsuite/gfortran.dg/pr77498.f b/gcc/testsuite/gfortran.dg/pr77498.f
> > > index f957b57bb00..a0fc8275a84 100644
> > > --- a/gcc/testsuite/gfortran.dg/pr77498.f
> > > +++ b/gcc/testsuite/gfortran.dg/pr77498.f
> > > @@ -1,5 +1,5 @@
> > >  ! { dg-do compile }
> > > -! { dg-options "-O2 -ffast-math -fdump-tree-pre" }
> > > +! { dg-options "-O2 -fno-tree-vectorize -ffast-math -fdump-tree-pre" }
> > >
> > >        subroutine foo(U,V,R,N,A)
> > >        integer N
> > >
> >
> > --
> > Richard Biener <rguenther@suse.de>
> > SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> > Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
> 
> 
> 
>
Hongtao Liu Sept. 17, 2021, 3:26 a.m. UTC | #4
On Thu, Sep 16, 2021 at 8:31 PM Richard Biener <rguenther@suse.de> wrote:
>
> On Thu, 16 Sep 2021, Hongtao Liu wrote:
>
> > On Thu, Sep 16, 2021 at 4:23 PM Richard Biener via Gcc-patches
> > <gcc-patches@gcc.gnu.org> wrote:
> > >
> > > On Thu, 16 Sep 2021, liuhongt wrote:
> > >
> > > > Ping
> > > > rebased on latest trunk.
> > > >
> > > > gcc/ChangeLog:
> > > >
> > > >       * common.opt (ftree-vectorize): Add Var(flag_tree_vectorize).
> > > >       * doc/invoke.texi (Options That Control Optimization): Update
> > > >       documents.
> > > >       * opts.c (default_options_table): Enable auto-vectorization at
> > > >       O2 with very-cheap cost model.
> > > >       (finish_options): Use cheap cost model for
> > > >       explicit -ftree{,-loop}-vectorize.
> > > >
> > > > gcc/testsuite/ChangeLog:
> > > >
> > > >       * c-c++-common/Wstringop-overflow-2.c: Adjust testcase.
> > > >       * g++.dg/tree-ssa/pr81408.C: Ditto.
> > > >       * g++.dg/warn/Wuninitialized-13.C: Ditto.
> > > >       * gcc.dg/Warray-bounds-51.c: Ditto.
> > > >       * gcc.dg/Warray-parameter-3.c: Ditto.
> > > >       * gcc.dg/Wstringop-overflow-13.c: Ditto.
> > > >       * gcc.dg/Wstringop-overflow-14.c: Ditto.
> > > >       * gcc.dg/Wstringop-overflow-21.c: Ditto.
> > > >       * gcc.dg/Wstringop-overflow-68.c: Ditto.
> > > >       * gcc.dg/gomp/pr46032-2.c: Ditto.
> > > >       * gcc.dg/gomp/pr46032-3.c: Ditto.
> > > >       * gcc.dg/gomp/simd-2.c: Ditto.
> > > >       * gcc.dg/gomp/simd-3.c: Ditto.
> > > >       * gcc.dg/graphite/fuse-1.c: Ditto.
> > > >       * gcc.dg/pr67089-6.c: Ditto.
> > > >       * gcc.dg/pr82929-2.c: Ditto.
> > > >       * gcc.dg/pr82929.c: Ditto.
> > > >       * gcc.dg/store_merging_1.c: Ditto.
> > > >       * gcc.dg/store_merging_11.c: Ditto.
> > > >       * gcc.dg/store_merging_15.c: Ditto.
> > > >       * gcc.dg/store_merging_16.c: Ditto.
> > > >       * gcc.dg/store_merging_19.c: Ditto.
> > > >       * gcc.dg/store_merging_24.c: Ditto.
> > > >       * gcc.dg/store_merging_25.c: Ditto.
> > > >       * gcc.dg/store_merging_28.c: Ditto.
> > > >       * gcc.dg/store_merging_30.c: Ditto.
> > > >       * gcc.dg/store_merging_5.c: Ditto.
> > > >       * gcc.dg/store_merging_7.c: Ditto.
> > > >       * gcc.dg/store_merging_8.c: Ditto.
> > > >       * gcc.dg/strlenopt-85.c: Ditto.
> > > >       * gcc.dg/tree-ssa/dump-6.c: Ditto.
> > > >       * gcc.dg/tree-ssa/pr19210-1.c: Ditto.
> > > >       * gcc.dg/tree-ssa/pr47059.c: Ditto.
> > > >       * gcc.dg/tree-ssa/pr86017.c: Ditto.
> > > >       * gcc.dg/tree-ssa/pr91482.c: Ditto.
> > > >       * gcc.dg/tree-ssa/predcom-1.c: Ditto.
> > > >       * gcc.dg/tree-ssa/predcom-dse-3.c: Ditto.
> > > >       * gcc.dg/tree-ssa/prefetch-3.c: Ditto.
> > > >       * gcc.dg/tree-ssa/prefetch-6.c: Ditto.
> > > >       * gcc.dg/tree-ssa/prefetch-8.c: Ditto.
> > > >       * gcc.dg/tree-ssa/prefetch-9.c: Ditto.
> > > >       * gcc.dg/tree-ssa/ssa-dse-18.c: Ditto.
> > > >       * gcc.dg/tree-ssa/ssa-dse-19.c: Ditto.
> > > >       * gcc.dg/uninit-40.c: Ditto.
> > > >       * gcc.dg/unroll-7.c: Ditto.
> > > >       * gcc.misc-tests/help.exp: Ditto.
> > > >       * gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c: Ditto.
> > > >       * gcc.target/i386/pr22141.c: Ditto.
> > > >       * gcc.target/i386/pr34012.c: Ditto.
> > > >       * gcc.target/i386/pr49781-1.c: Ditto.
> > > >       * gcc.target/i386/pr95798-1.c: Ditto.
> > > >       * gcc.target/i386/pr95798-2.c: Ditto.
> > > >       * gfortran.dg/pr77498.f: Ditto.
> > > > ---
> > > >  gcc/common.opt                                 |  2 +-
> > > >  gcc/doc/invoke.texi                            |  8 +++++---
> > > >  gcc/opts.c                                     | 18 +++++++++++++++---
> > > >  .../c-c++-common/Wstringop-overflow-2.c        |  2 +-
> > > >  gcc/testsuite/g++.dg/tree-ssa/pr81408.C        |  2 +-
> > > >  gcc/testsuite/g++.dg/warn/Wuninitialized-13.C  |  2 +-
> > > >  gcc/testsuite/gcc.dg/Warray-bounds-51.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/Warray-parameter-3.c      |  2 +-
> > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-13.c   |  2 +-
> > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-14.c   |  2 +-
> > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-21.c   |  2 +-
> > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-68.c   |  2 +-
> > > >  gcc/testsuite/gcc.dg/gomp/pr46032-2.c          |  2 +-
> > > >  gcc/testsuite/gcc.dg/gomp/pr46032-3.c          |  2 +-
> > > >  gcc/testsuite/gcc.dg/gomp/simd-2.c             |  2 +-
> > > >  gcc/testsuite/gcc.dg/gomp/simd-3.c             |  2 +-
> > > >  gcc/testsuite/gcc.dg/graphite/fuse-1.c         |  2 +-
> > > >  gcc/testsuite/gcc.dg/pr67089-6.c               |  2 +-
> > > >  gcc/testsuite/gcc.dg/pr82929-2.c               |  2 +-
> > > >  gcc/testsuite/gcc.dg/pr82929.c                 |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_1.c         |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_11.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_15.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_16.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_19.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_24.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_25.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_28.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_30.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_5.c         |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_7.c         |  2 +-
> > > >  gcc/testsuite/gcc.dg/store_merging_8.c         |  2 +-
> > > >  gcc/testsuite/gcc.dg/strlenopt-85.c            |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/dump-6.c         |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c      |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/pr47059.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/pr86017.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/pr91482.c        |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c      |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c  |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c     |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c     |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c     |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c     |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c     |  2 +-
> > > >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c     |  2 +-
> > > >  gcc/testsuite/gcc.dg/uninit-40.c               |  2 +-
> > > >  gcc/testsuite/gcc.dg/unroll-7.c                |  2 +-
> > > >  gcc/testsuite/gcc.misc-tests/help.exp          |  2 +-
> > > >  .../i386/avx512vpopcntdqvl-vpopcntd-1.c        |  2 +-
> > > >  gcc/testsuite/gcc.target/i386/pr22141.c        |  2 +-
> > > >  gcc/testsuite/gcc.target/i386/pr34012.c        |  2 +-
> > > >  gcc/testsuite/gcc.target/i386/pr49781-1.c      |  2 +-
> > > >  gcc/testsuite/gcc.target/i386/pr95798-1.c      |  2 +-
> > > >  gcc/testsuite/gcc.target/i386/pr95798-2.c      |  2 +-
> > > >  gcc/testsuite/gfortran.dg/pr77498.f            |  2 +-
> > > >  56 files changed, 74 insertions(+), 60 deletions(-)
> > > >
> > > > diff --git a/gcc/common.opt b/gcc/common.opt
> > > > index b921f5e3b25..4f2c0294c29 100644
> > > > --- a/gcc/common.opt
> > > > +++ b/gcc/common.opt
> > > > @@ -3031,7 +3031,7 @@ Perform variable tracking and also tag variables that are uninitialized.
> > > >
> > > >  ; Alias to enable both -ftree-loop-vectorize and -ftree-slp-vectorize.
> > > >  ftree-vectorize
> > > > -Common Optimization
> > > > +Common Var(flag_tree_vectorize) Optimization
> > > >  Enable vectorization on trees.
> > > >
> > > >  ftree-vectorizer-verbose=
> > > > diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
> > > > index 78cfc100ac2..be022ef8024 100644
> > > > --- a/gcc/doc/invoke.texi
> > > > +++ b/gcc/doc/invoke.texi
> > > > @@ -10409,9 +10409,13 @@ also turns on the following optimization flags:
> > > >  -fstrict-aliasing @gol
> > > >  -fthread-jumps @gol
> > > >  -ftree-builtin-call-dce @gol
> > > > +-ftree-loop-vectorize @gol
> > > >  -ftree-pre @gol
> > > > +-ftree-slp-vectorize @gol
> > > >  -ftree-switch-conversion  -ftree-tail-merge @gol
> > > > --ftree-vrp}
> > > > +-ftree-vrp @gol
> > > > +-fvect-cost-model @gol
> > >
> > > the above is redundant
> > >
> > > > +-fvect-cost-model=very-cheap}
> > > >
> > > >  Please note the warning under @option{-fgcse} about
> > > >  invoking @option{-O2} on programs that use computed gotos.
> > > > @@ -10431,9 +10435,7 @@ by @option{-O2} and also turns on the following optimization flags:
> > > >  -fsplit-loops @gol
> > > >  -fsplit-paths @gol
> > > >  -ftree-loop-distribution @gol
> > > > --ftree-loop-vectorize @gol
> > > >  -ftree-partial-pre @gol
> > > > --ftree-slp-vectorize @gol
> > > >  -funswitch-loops @gol
> > > >  -fvect-cost-model @gol
> > >
> > > likewise - so just remove it here as you are around
> > >
> > > >  -fvect-cost-model=dynamic @gol
> > > > diff --git a/gcc/opts.c b/gcc/opts.c
> > > > index 1d2d22d7a3f..cee372a3235 100644
> > > > --- a/gcc/opts.c
> > > > +++ b/gcc/opts.c
> > > > @@ -634,7 +634,8 @@ static const struct default_options default_options_table[] =
> > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
> > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
> > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
> > > > -    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
> > > > +    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL,
> > > > +      VECT_COST_MODEL_VERY_CHEAP },
> > > >      { OPT_LEVELS_2_PLUS, OPT_finline_functions, NULL, 1 },
> > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
> > > >
> > > > @@ -646,6 +647,9 @@ static const struct default_options default_options_table[] =
> > > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
> > > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
> > > >        REORDER_BLOCKS_ALGORITHM_STC },
> > > > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_loop_vectorize, NULL, 1 },
> > > > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_slp_vectorize, NULL, 1 },
> > > > +
> > > >  #ifdef INSN_SCHEDULING
> > > >    /* Only run the pre-regalloc scheduling pass if optimizing for speed.  */
> > > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
> > > > @@ -663,9 +667,7 @@ static const struct default_options default_options_table[] =
> > > >      { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
> > > >      { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
> > > >      { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
> > > > -    { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
> > > >      { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
> > > > -    { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
> > > >      { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
> > > >      { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
> > > >      { OPT_LEVELS_3_PLUS, OPT_fversion_loops_for_strides, NULL, 1 },
> > > > @@ -1331,6 +1333,16 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
> > > >        = (opts->x_flag_unroll_loops
> > > >           || opts->x_flag_peel_loops
> > > >           || opts->x_optimize >= 3);
> > > > +
> > > > +  /* Use -fvect-cost-model=cheap instead of -fvect-cost-mode=very-cheap
> > > > +     by default with explicit -ftree-{loop,slp}-vectorize.  */
> > > > +  if (opts->x_optimize == 2
> > > > +      && (opts_set->x_flag_tree_loop_vectorize
> > > > +       || opts_set->x_flag_tree_vectorize))
> > > > +    SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
> > > > +                      VECT_COST_MODEL_CHEAP);
> > > > +
> > > > +
> > >
> > > please avoid adding excessive vertical space at the end of the function
> > >
> > > >  }
> > > >
> > > >  #define LEFT_COLUMN  27
> > > > diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > index 1d79930cd58..9351f7e7a1a 100644
> > > > --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > @@ -1,7 +1,7 @@
> > > >  /* PR middle-end/91458 - inconsistent warning for writing past the end
> > > >     of an array member
> > > >     { dg-do compile }
> > > > -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> > > > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> > >
> > > The testcase is large - what part requires this change?  Given the
> > > testcase was added for inconsistent warnings do they now become
> > > inconsistent again as we enable vectorization at -O2?
> > >
> > > That said, the testcase adjustments need some explaining - I suppose
> > > you didn't just slap -fno-tree-vectorize to all of those changing
> > > behavior?
> > >
> > void ga1_ (void)
> > {
> >   a1_.a[0] = 0;
> >   a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
> >   a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> >
> >   struct A1 a;
> >   a.a[0] = 0;
> >   a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
> >   a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
> >   sink (&a);
> > }
> >
> > It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> > there are 2 accesses, but after enabling vectorization, there's only
> > one access, so one warning is missing which causes the failure.
> >
> >    <bb 2> [local count: 1073741824]:
> >   a1__.a[0] = 0;
> >   a1__.a[1] = 1;
> >   a1__.a[2] = 2;
> >   MEM <char[1]> [(struct A1 *)&a + 1B] = {};
> >   a.n = 1;
> >   MEM <vector(2) char> [(char *)&a + 2B] = { 1, 2 };
> >   sink (&a);
> >   a ={v} {CLOBBER};
> >   return;
>
> I see, so it seems you looked into each instance you changed - I don't
> want to repeat that exercise here.
>
Going through all testcases i changed, i found 3 miss optimization
issue after enable O2 vectorization. The issues are recorded in
pr102382/pr102382/pr102384, I'm not sure if they're block issues which
needed to be solved first before installing the patch.
Also I notice  openmp case gcc.dg/gomp/simd-3.c #pragma omp for simd
will enable vectorization for the region w/ original cost model cheap,
but now cost model is very cheap, would that be ok?

> Thus the patch is OK with the minor nits I had fixed.  Note that
> other targets testsuites likely will need similar adjustments so
> please watch out (but a lot of target people are in CC and could
> deal with such fallout themselves).
>
> Please also prepare an entry for gcc-12/changes.html since this
> is an important change.  Make sure to mention -fvect-cost-model
> since otherwise people might expect vectorization to be as good
> as with -O3.
>
> Thanks,
> Richard.
>
> >
> > > Thanks,
> > > Richard.
> > >
> > > >  void sink (void*);
> > > >
> > > > diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > > index 39e32fd4bc9..bc14309480c 100644
> > > > --- a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > > +++ b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed" } */
> > > > +/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed -fno-tree-vectorize" } */
> > > >  struct p
> > > >  {
> > > >    char *ay;
> > > > diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > > index 49ee878806a..60e8dd4f0e2 100644
> > > > --- a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > > +++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR c/98597 - ICE in -Wuninitialized printing a MEM_REF
> > > >     { dg-do compile }
> > > > -   { dg-options "-O2 -Wall" } */
> > > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > > >
> > > >  struct shared_count {
> > > >    shared_count () { }
> > > > diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-51.c b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > > index 6028b11637c..8b81a0ccfa7 100644
> > > > --- a/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > > +++ b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > > @@ -1,7 +1,7 @@
> > > >  /* PR middle-end/92333 - missing variable name referencing VLA in warnings
> > > >     PR middle-end/82608 - missing -Warray-bounds on an out-of-bounds VLA index
> > > >     { dg-do compile }
> > > > -   { dg-options "-O2 -Wall" } */
> > > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > > >
> > > >  void sink (void*);
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/Warray-parameter-3.c b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > > index cbf3e9339f5..fbef715aa99 100644
> > > > --- a/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > > +++ b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > > @@ -59,7 +59,7 @@ void fas1 (int[static 2]);    // { dg-warning "\\\[-Warray-parameter=" }
> > > >
> > > >  /* Also verify that -Warray-bounds doesn't trigger for ordinary array
> > > >     parameters...  */
> > > > -#pragma GCC optimize "2"
> > > > +#pragma GCC optimize ("2,-fno-tree-vectorize")
> > > >
> > > >  __attribute__ ((noipa)) void
> > > >  gca3 (char a[3])
> > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > > index bd513151cea..a78242bf26e 100644
> > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > > @@ -3,7 +3,7 @@
> > > >     PR middle-end/89911 - ICE on a call with no arguments to strnlen
> > > >     declared with no prototype
> > > >     { dg-do compile }
> > > > -   { dg-options "-O2 -Wall" } */
> > > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > > >
> > > >  typedef __SIZE_TYPE__ size_t;
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > > index d6201b068b6..808bf87c386 100644
> > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > > @@ -2,7 +2,7 @@
> > > >     types than char are diagnosed.
> > > >     { dg-do compile }
> > > >     { dg-require-effective-target int32plus }
> > > > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > > > +   { dg-options "-O2 -fno-tree-vectorize -Wall -Wno-array-bounds" } */
> > > >
> > > >  typedef __INT16_TYPE__  int16_t;
> > > >  typedef __INT32_TYPE__  int32_t;
> > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > > index 3a27460220c..f418a17ca93 100644
> > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > > @@ -1,7 +1,7 @@
> > > >  /* PR middle-end/92312 - bogus -Wstringop-overflow storing into a trailing
> > > >     array backed by larger buffer
> > > >     { dg-do compile }
> > > > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > > > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-tree-vectorize" } */
> > > >
> > > >  struct S0 { char a, b[0]; };
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > > index 6bcba274541..7cc1012130c 100644
> > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > > @@ -2,7 +2,7 @@
> > > >     a larger scalar into a smaller array
> > > >     Verify overflow by aggregate stores.
> > > >     { dg-do compile }
> > > > -   { dg-options "-O2" } */
> > > > +   { dg-options "-O2 -fno-tree-vectorize" } */
> > > >
> > > >  #define A(N) (A ## N)
> > > >  #define Ac1 (AC1){ 0 }
> > > > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > > index e110880bd8e..2e562618489 100644
> > > > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > >
> > > >  #define N 2
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > > index a4af7ec4a8a..da1ab487385 100644
> > > > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > >
> > > >  #define N 2
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-2.c b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > > index 85acb980f10..f4912127b81 100644
> > > > --- a/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > > +++ b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > > > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> > > >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> > > >  /* { dg-additional-options "-mavx" { target avx } } */
> > > >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > > > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-3.c b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > > index 86fee858673..c75060c07ae 100644
> > > > --- a/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > > +++ b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > > > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> > > >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> > > >  /* { dg-additional-options "-mavx" { target avx } } */
> > > >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > > > diff --git a/gcc/testsuite/gcc.dg/graphite/fuse-1.c b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > > index 527b6e5c415..61289d312c2 100644
> > > > --- a/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > > +++ b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* Check that the two loops are fused and that we manage to fold the two xor
> > > >     operations.  */
> > > > -/* { dg-options "-O2 -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> > > >
> > > >  /* Make sure we fuse the loops like this:
> > > >  AST generated by isl:
> > > > diff --git a/gcc/testsuite/gcc.dg/pr67089-6.c b/gcc/testsuite/gcc.dg/pr67089-6.c
> > > > index db2ffdfeca4..b59d75b2318 100644
> > > > --- a/gcc/testsuite/gcc.dg/pr67089-6.c
> > > > +++ b/gcc/testsuite/gcc.dg/pr67089-6.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR target/67089 */
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> > > >
> > > >  extern void abort (void);
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/pr82929-2.c b/gcc/testsuite/gcc.dg/pr82929-2.c
> > > > index 3442f91af02..b886f1cce76 100644
> > > > --- a/gcc/testsuite/gcc.dg/pr82929-2.c
> > > > +++ b/gcc/testsuite/gcc.dg/pr82929-2.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR tree-optimization/82929 */
> > > >  /* { dg-do compile { target store_merge } } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  void
> > > >  foo (short *p, short *q, short *r)
> > > > diff --git a/gcc/testsuite/gcc.dg/pr82929.c b/gcc/testsuite/gcc.dg/pr82929.c
> > > > index bb84f2b21a3..123e1919cec 100644
> > > > --- a/gcc/testsuite/gcc.dg/pr82929.c
> > > > +++ b/gcc/testsuite/gcc.dg/pr82929.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR tree-optimization/82929 */
> > > >  /* { dg-do compile { target store_merge } } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  void
> > > >  foo (short *p, short *q, short *r)
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_1.c b/gcc/testsuite/gcc.dg/store_merging_1.c
> > > > index 4cc43dfd9e1..91ca925be0e 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_1.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_1.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* { dg-do compile } */
> > > >  /* { dg-require-effective-target store_merge } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  struct bar {
> > > >    int a;
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_11.c b/gcc/testsuite/gcc.dg/store_merging_11.c
> > > > index 2ec2394afb9..60ed5cd8bf9 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_11.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_11.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* { dg-do run } */
> > > >  /* { dg-require-effective-target store_merge } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  struct S { unsigned char b[2]; unsigned short c; unsigned char d[4]; unsigned long e; };
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_15.c b/gcc/testsuite/gcc.dg/store_merging_15.c
> > > > index acd7de571f8..13fcca4aa11 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_15.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_15.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* { dg-do run } */
> > > >  /* { dg-require-effective-target store_merge } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  struct S { unsigned char a, b; unsigned short c; unsigned char d, e, f, g; unsigned long long h; };
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_16.c b/gcc/testsuite/gcc.dg/store_merging_16.c
> > > > index 9545dcce3de..cd83f1c0fe5 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_16.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_16.c
> > > > @@ -2,7 +2,7 @@
> > > >     are either big or little endian (not pdp endian).  */
> > > >  /* { dg-do run { target { lp64 && { i?86-*-* x86_64-*-* powerpc*-*-* aarch64*-*-* } } } } */
> > > >  /* { dg-require-effective-target store_merge } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  __attribute__((noipa)) void
> > > >  f1 (unsigned char *p, unsigned long long q)
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_19.c b/gcc/testsuite/gcc.dg/store_merging_19.c
> > > > index 0841bb4deee..0a2bbc4bfde 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_19.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_19.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR tree-optimization/83843 */
> > > >  /* { dg-do run } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >  /* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" { target store_merge } } } */
> > > >
> > > >  __attribute__((noipa)) void
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_24.c b/gcc/testsuite/gcc.dg/store_merging_24.c
> > > > index 744fe60e8e0..5291bb9e986 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_24.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_24.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR tree-optimization/87859 */
> > > >  /* { dg-do run } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > > >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 19 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_25.c b/gcc/testsuite/gcc.dg/store_merging_25.c
> > > > index cf182190e91..96611b5e57b 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_25.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_25.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR tree-optimization/87859 */
> > > >  /* { dg-do run } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > > >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 14 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_28.c b/gcc/testsuite/gcc.dg/store_merging_28.c
> > > > index 2d6cffc4694..fadb7fff993 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_28.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_28.c
> > > > @@ -1,7 +1,7 @@
> > > >  /* PR tree-optimization/88709 */
> > > >  /* { dg-do compile } */
> > > >  /* { dg-require-effective-target store_merge } */
> > > > -/* { dg-options "-O2 -fno-ipa-icf -fdump-tree-store-merging-details" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-ipa-icf -fdump-tree-store-merging-details" } */
> > > >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 16 stores" 8 "store-merging" { target { i?86-*-* x86_64-*-* } } } } */
> > > >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 6 stores" 1 "store-merging" { target { ! arm*-*-* } } } } */
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_30.c b/gcc/testsuite/gcc.dg/store_merging_30.c
> > > > index 694d560a621..baf94efe733 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_30.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_30.c
> > > > @@ -1,7 +1,7 @@
> > > >  /* PR tree-optimization/94573 */
> > > >  /* { dg-do compile } */
> > > >  /* { dg-require-effective-target store_merge } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > > >  /* { dg-final { scan-tree-dump "New sequence of 4 stores to replace old one of 8 stores" "store-merging" { target lp64 } } } */
> > > >
> > > >  int var[43][12];
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_5.c b/gcc/testsuite/gcc.dg/store_merging_5.c
> > > > index 6e7c72510ff..b0cb0da78e0 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_5.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_5.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* { dg-do compile } */
> > > >  /* { dg-require-effective-target store_merge } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  /* Make sure that non-aliasing non-constant interspersed stores do not
> > > >     stop chains.  */
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_7.c b/gcc/testsuite/gcc.dg/store_merging_7.c
> > > > index c744ece6407..dbe000a463e 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_7.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_7.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* { dg-do compile } */
> > > >  /* { dg-require-effective-target store_merge } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  /* Check that we can merge consecutive array members through the pointer.
> > > >     PR rtl-optimization/23684.  */
> > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_8.c b/gcc/testsuite/gcc.dg/store_merging_8.c
> > > > index e710a544ff0..d719e0a2257 100644
> > > > --- a/gcc/testsuite/gcc.dg/store_merging_8.c
> > > > +++ b/gcc/testsuite/gcc.dg/store_merging_8.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* { dg-do compile } */
> > > >  /* { dg-require-effective-target store_merge } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  struct baz {
> > > >    struct bar {
> > > > diff --git a/gcc/testsuite/gcc.dg/strlenopt-85.c b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > > index e049e0c30e0..2ba1ee05700 100644
> > > > --- a/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > > +++ b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > > @@ -4,7 +4,7 @@
> > > >     of memory allocated by calloc() even if one or more nul bytes are
> > > >     written into it.
> > > >     { dg-do compile }
> > > > -   { dg-options "-O2 -fdump-tree-optimized" } */
> > > > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > > >
> > > >  unsigned n0, n1;
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > > index 70659c00c0e..6c803908781 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR middle-end/90676 - default GIMPLE dumps lack information
> > > >     { dg-do compile }
> > > > -   { dg-options "-O2 -fdump-tree-store-merging" }
> > > > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" }
> > > >     { dg-require-effective-target int32plus }
> > > >     { dg-require-effective-target store_merge } */
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > > index 50d86a00485..b9e40e964c1 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fopt-info-loop-missed" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fopt-info-loop-missed" } */
> > > >  extern void g(void);
> > > >
> > > >  void
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > > index 9f9c61aa213..860cde12c0f 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-Os -fdump-tree-optimized" } */
> > > > +/* { dg-options "-Os -fno-tree-vectorize -fdump-tree-optimized" } */
> > > >
> > > >
> > > >  struct struct1
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > > index f216e83c7b3..c7ef73ad59e 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > >
> > > >  void f (void*);
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > > index 7d6a724e4ad..0ddad573129 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> > > >
> > > >  void write64 (void *p)
> > > >  {
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > > index f68be2b3379..8c3d9a4fc58 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* { dg-do compile } */
> > > >  /* { dg-do run } */
> > > > -/* { dg-options "-O2 -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > >
> > > >  void abort (void);
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > > index ec08d6c0318..1fc8f089345 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do run } */
> > > > -/* { dg-options "-O2 -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > >
> > > >  int arr1[105] = {2, 3, 5, 7, 11, 13, 0};
> > > >  int arr2[105] = {2, 3, 5, 7, 11, 13, 0};
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > > index 467903bf3fc..46f0d0c2317 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > > @@ -1,7 +1,7 @@
> > > >  /* Prefetching used to prefer nonsensical unroll factor of 5 in this testcase.  */
> > > >
> > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> > > >
> > > >  #define N 1000000
> > > >
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > > index 12f09016943..3fa71685ace 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> > > >
> > > >  #define N 1000
> > > >  #define K 900
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > > index cbd6a80d345..00f41c3e4f4 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > >
> > > >  #define K 1000000
> > > >  int a[K];
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > > index da4847320b1..e8848c30acc 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > >
> > > >  #define K 1000000
> > > >  int a[K], b[K];
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > > index 92b2df80ec8..2e7b5b496ea 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > > >  int g(_Complex int*);
> > > >  int f(void)
> > > >  {
> > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > > index 718b7466e50..7bb8d060631 100644
> > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > > >  int g(_Complex int*);
> > > >  int f(void)
> > > >  {
> > > > diff --git a/gcc/testsuite/gcc.dg/uninit-40.c b/gcc/testsuite/gcc.dg/uninit-40.c
> > > > index c015191ca32..8708079d397 100644
> > > > --- a/gcc/testsuite/gcc.dg/uninit-40.c
> > > > +++ b/gcc/testsuite/gcc.dg/uninit-40.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR tree-optimization/98597 */
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -Wuninitialized" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -Wuninitialized" } */
> > > >
> > > >  union U { double d; int i; float f; };
> > > >  struct S { char a; int b; char c; unsigned d; union U e; int f[3]; unsigned g[3]; };
> > > > diff --git a/gcc/testsuite/gcc.dg/unroll-7.c b/gcc/testsuite/gcc.dg/unroll-7.c
> > > > index 055369bf8b1..695af5757cc 100644
> > > > --- a/gcc/testsuite/gcc.dg/unroll-7.c
> > > > +++ b/gcc/testsuite/gcc.dg/unroll-7.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> > > >  /* { dg-require-effective-target int32plus } */
> > > >
> > > >  extern int *a;
> > > > diff --git a/gcc/testsuite/gcc.misc-tests/help.exp b/gcc/testsuite/gcc.misc-tests/help.exp
> > > > index 5e034d26947..eb6d8686c6a 100644
> > > > --- a/gcc/testsuite/gcc.misc-tests/help.exp
> > > > +++ b/gcc/testsuite/gcc.misc-tests/help.exp
> > > > @@ -79,7 +79,7 @@ check_for_options c "--help=target,optimizers" "" "" ""
> > > >  check_for_options c "--help=warnings,^joined,^undocumented" "" "" ""
> > > >  check_for_options c "-Q -O2 --help=optimizers" {
> > > >  -O
> > > > --ftree-loop-vectorize[^\n]*disabled
> > > > +-ftree-loop-vectorize[^\n]*enabled
> > > >  } "  -g  " ""
> > > >  check_for_options c "-Q -O3 --help=optimizers" {
> > > >  -O
> > > > diff --git a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > > index 709cd21e671..a732bc466db 100644
> > > > --- a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > > +++ b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do run } */
> > > > -/* { dg-options "-O2 -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> > > >  /* { dg-require-effective-target avx512vl } */
> > > >  /* { dg-require-effective-target avx512vpopcntdqvl } */
> > > >  /* { dg-require-effective-target avx512bw } */
> > > > diff --git a/gcc/testsuite/gcc.target/i386/pr22141.c b/gcc/testsuite/gcc.target/i386/pr22141.c
> > > > index 036422e8ccf..b68b97f3f72 100644
> > > > --- a/gcc/testsuite/gcc.target/i386/pr22141.c
> > > > +++ b/gcc/testsuite/gcc.target/i386/pr22141.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR middle-end/22141 */
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-Os" } */
> > > > +/* { dg-options "-Os -fno-tree-vectorize" } */
> > > >
> > > >  extern void abort (void);
> > > >
> > > > diff --git a/gcc/testsuite/gcc.target/i386/pr34012.c b/gcc/testsuite/gcc.target/i386/pr34012.c
> > > > index d0cffa05290..1c1f0eea52e 100644
> > > > --- a/gcc/testsuite/gcc.target/i386/pr34012.c
> > > > +++ b/gcc/testsuite/gcc.target/i386/pr34012.c
> > > > @@ -1,7 +1,7 @@
> > > >  /* PR rtl-optimization/34012 */
> > > >  /* { dg-do compile } */
> > > >  /* { dg-require-effective-target lp64 } */
> > > > -/* { dg-options "-O2 -fno-store-merging" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-store-merging" } */
> > > >
> > > >  void bar (long int *);
> > > >  void
> > > > diff --git a/gcc/testsuite/gcc.target/i386/pr49781-1.c b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > > index 60f9d50d866..d5a2e32db97 100644
> > > > --- a/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > > +++ b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > > @@ -1,5 +1,5 @@
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -fpic -mtune=generic" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -fpic -mtune=generic" } */
> > > >  /* { dg-require-effective-target fpic } */
> > > >
> > > >  static int heap[2*(256 +1+29)+1];
> > > > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-1.c b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > > index 9a7e32d6f2f..526f48921fd 100644
> > > > --- a/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > > +++ b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR target/95798 */
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> > > >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-2.c b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > > index c670d3780e8..6b5c5a73e96 100644
> > > > --- a/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > > +++ b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > > @@ -1,6 +1,6 @@
> > > >  /* PR target/95798 */
> > > >  /* { dg-do compile } */
> > > > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > > > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> > > >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > diff --git a/gcc/testsuite/gfortran.dg/pr77498.f b/gcc/testsuite/gfortran.dg/pr77498.f
> > > > index f957b57bb00..a0fc8275a84 100644
> > > > --- a/gcc/testsuite/gfortran.dg/pr77498.f
> > > > +++ b/gcc/testsuite/gfortran.dg/pr77498.f
> > > > @@ -1,5 +1,5 @@
> > > >  ! { dg-do compile }
> > > > -! { dg-options "-O2 -ffast-math -fdump-tree-pre" }
> > > > +! { dg-options "-O2 -fno-tree-vectorize -ffast-math -fdump-tree-pre" }
> > > >
> > > >        subroutine foo(U,V,R,N,A)
> > > >        integer N
> > > >
> > >
> > > --
> > > Richard Biener <rguenther@suse.de>
> > > SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> > > Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
> >
> >
> >
> >
>
> --
> Richard Biener <rguenther@suse.de>
> SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
Richard Biener Sept. 17, 2021, 7:47 a.m. UTC | #5
On Fri, 17 Sep 2021, Hongtao Liu wrote:

> On Thu, Sep 16, 2021 at 8:31 PM Richard Biener <rguenther@suse.de> wrote:
> >
> > On Thu, 16 Sep 2021, Hongtao Liu wrote:
> >
> > > On Thu, Sep 16, 2021 at 4:23 PM Richard Biener via Gcc-patches
> > > <gcc-patches@gcc.gnu.org> wrote:
> > > >
> > > > On Thu, 16 Sep 2021, liuhongt wrote:
> > > >
> > > > > Ping
> > > > > rebased on latest trunk.
> > > > >
> > > > > gcc/ChangeLog:
> > > > >
> > > > >       * common.opt (ftree-vectorize): Add Var(flag_tree_vectorize).
> > > > >       * doc/invoke.texi (Options That Control Optimization): Update
> > > > >       documents.
> > > > >       * opts.c (default_options_table): Enable auto-vectorization at
> > > > >       O2 with very-cheap cost model.
> > > > >       (finish_options): Use cheap cost model for
> > > > >       explicit -ftree{,-loop}-vectorize.
> > > > >
> > > > > gcc/testsuite/ChangeLog:
> > > > >
> > > > >       * c-c++-common/Wstringop-overflow-2.c: Adjust testcase.
> > > > >       * g++.dg/tree-ssa/pr81408.C: Ditto.
> > > > >       * g++.dg/warn/Wuninitialized-13.C: Ditto.
> > > > >       * gcc.dg/Warray-bounds-51.c: Ditto.
> > > > >       * gcc.dg/Warray-parameter-3.c: Ditto.
> > > > >       * gcc.dg/Wstringop-overflow-13.c: Ditto.
> > > > >       * gcc.dg/Wstringop-overflow-14.c: Ditto.
> > > > >       * gcc.dg/Wstringop-overflow-21.c: Ditto.
> > > > >       * gcc.dg/Wstringop-overflow-68.c: Ditto.
> > > > >       * gcc.dg/gomp/pr46032-2.c: Ditto.
> > > > >       * gcc.dg/gomp/pr46032-3.c: Ditto.
> > > > >       * gcc.dg/gomp/simd-2.c: Ditto.
> > > > >       * gcc.dg/gomp/simd-3.c: Ditto.
> > > > >       * gcc.dg/graphite/fuse-1.c: Ditto.
> > > > >       * gcc.dg/pr67089-6.c: Ditto.
> > > > >       * gcc.dg/pr82929-2.c: Ditto.
> > > > >       * gcc.dg/pr82929.c: Ditto.
> > > > >       * gcc.dg/store_merging_1.c: Ditto.
> > > > >       * gcc.dg/store_merging_11.c: Ditto.
> > > > >       * gcc.dg/store_merging_15.c: Ditto.
> > > > >       * gcc.dg/store_merging_16.c: Ditto.
> > > > >       * gcc.dg/store_merging_19.c: Ditto.
> > > > >       * gcc.dg/store_merging_24.c: Ditto.
> > > > >       * gcc.dg/store_merging_25.c: Ditto.
> > > > >       * gcc.dg/store_merging_28.c: Ditto.
> > > > >       * gcc.dg/store_merging_30.c: Ditto.
> > > > >       * gcc.dg/store_merging_5.c: Ditto.
> > > > >       * gcc.dg/store_merging_7.c: Ditto.
> > > > >       * gcc.dg/store_merging_8.c: Ditto.
> > > > >       * gcc.dg/strlenopt-85.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/dump-6.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/pr19210-1.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/pr47059.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/pr86017.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/pr91482.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/predcom-1.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/predcom-dse-3.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/prefetch-3.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/prefetch-6.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/prefetch-8.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/prefetch-9.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/ssa-dse-18.c: Ditto.
> > > > >       * gcc.dg/tree-ssa/ssa-dse-19.c: Ditto.
> > > > >       * gcc.dg/uninit-40.c: Ditto.
> > > > >       * gcc.dg/unroll-7.c: Ditto.
> > > > >       * gcc.misc-tests/help.exp: Ditto.
> > > > >       * gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c: Ditto.
> > > > >       * gcc.target/i386/pr22141.c: Ditto.
> > > > >       * gcc.target/i386/pr34012.c: Ditto.
> > > > >       * gcc.target/i386/pr49781-1.c: Ditto.
> > > > >       * gcc.target/i386/pr95798-1.c: Ditto.
> > > > >       * gcc.target/i386/pr95798-2.c: Ditto.
> > > > >       * gfortran.dg/pr77498.f: Ditto.
> > > > > ---
> > > > >  gcc/common.opt                                 |  2 +-
> > > > >  gcc/doc/invoke.texi                            |  8 +++++---
> > > > >  gcc/opts.c                                     | 18 +++++++++++++++---
> > > > >  .../c-c++-common/Wstringop-overflow-2.c        |  2 +-
> > > > >  gcc/testsuite/g++.dg/tree-ssa/pr81408.C        |  2 +-
> > > > >  gcc/testsuite/g++.dg/warn/Wuninitialized-13.C  |  2 +-
> > > > >  gcc/testsuite/gcc.dg/Warray-bounds-51.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/Warray-parameter-3.c      |  2 +-
> > > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-13.c   |  2 +-
> > > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-14.c   |  2 +-
> > > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-21.c   |  2 +-
> > > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-68.c   |  2 +-
> > > > >  gcc/testsuite/gcc.dg/gomp/pr46032-2.c          |  2 +-
> > > > >  gcc/testsuite/gcc.dg/gomp/pr46032-3.c          |  2 +-
> > > > >  gcc/testsuite/gcc.dg/gomp/simd-2.c             |  2 +-
> > > > >  gcc/testsuite/gcc.dg/gomp/simd-3.c             |  2 +-
> > > > >  gcc/testsuite/gcc.dg/graphite/fuse-1.c         |  2 +-
> > > > >  gcc/testsuite/gcc.dg/pr67089-6.c               |  2 +-
> > > > >  gcc/testsuite/gcc.dg/pr82929-2.c               |  2 +-
> > > > >  gcc/testsuite/gcc.dg/pr82929.c                 |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_1.c         |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_11.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_15.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_16.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_19.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_24.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_25.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_28.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_30.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_5.c         |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_7.c         |  2 +-
> > > > >  gcc/testsuite/gcc.dg/store_merging_8.c         |  2 +-
> > > > >  gcc/testsuite/gcc.dg/strlenopt-85.c            |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/dump-6.c         |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c      |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/pr47059.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/pr86017.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/pr91482.c        |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c      |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c  |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c     |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c     |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c     |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c     |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c     |  2 +-
> > > > >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c     |  2 +-
> > > > >  gcc/testsuite/gcc.dg/uninit-40.c               |  2 +-
> > > > >  gcc/testsuite/gcc.dg/unroll-7.c                |  2 +-
> > > > >  gcc/testsuite/gcc.misc-tests/help.exp          |  2 +-
> > > > >  .../i386/avx512vpopcntdqvl-vpopcntd-1.c        |  2 +-
> > > > >  gcc/testsuite/gcc.target/i386/pr22141.c        |  2 +-
> > > > >  gcc/testsuite/gcc.target/i386/pr34012.c        |  2 +-
> > > > >  gcc/testsuite/gcc.target/i386/pr49781-1.c      |  2 +-
> > > > >  gcc/testsuite/gcc.target/i386/pr95798-1.c      |  2 +-
> > > > >  gcc/testsuite/gcc.target/i386/pr95798-2.c      |  2 +-
> > > > >  gcc/testsuite/gfortran.dg/pr77498.f            |  2 +-
> > > > >  56 files changed, 74 insertions(+), 60 deletions(-)
> > > > >
> > > > > diff --git a/gcc/common.opt b/gcc/common.opt
> > > > > index b921f5e3b25..4f2c0294c29 100644
> > > > > --- a/gcc/common.opt
> > > > > +++ b/gcc/common.opt
> > > > > @@ -3031,7 +3031,7 @@ Perform variable tracking and also tag variables that are uninitialized.
> > > > >
> > > > >  ; Alias to enable both -ftree-loop-vectorize and -ftree-slp-vectorize.
> > > > >  ftree-vectorize
> > > > > -Common Optimization
> > > > > +Common Var(flag_tree_vectorize) Optimization
> > > > >  Enable vectorization on trees.
> > > > >
> > > > >  ftree-vectorizer-verbose=
> > > > > diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
> > > > > index 78cfc100ac2..be022ef8024 100644
> > > > > --- a/gcc/doc/invoke.texi
> > > > > +++ b/gcc/doc/invoke.texi
> > > > > @@ -10409,9 +10409,13 @@ also turns on the following optimization flags:
> > > > >  -fstrict-aliasing @gol
> > > > >  -fthread-jumps @gol
> > > > >  -ftree-builtin-call-dce @gol
> > > > > +-ftree-loop-vectorize @gol
> > > > >  -ftree-pre @gol
> > > > > +-ftree-slp-vectorize @gol
> > > > >  -ftree-switch-conversion  -ftree-tail-merge @gol
> > > > > --ftree-vrp}
> > > > > +-ftree-vrp @gol
> > > > > +-fvect-cost-model @gol
> > > >
> > > > the above is redundant
> > > >
> > > > > +-fvect-cost-model=very-cheap}
> > > > >
> > > > >  Please note the warning under @option{-fgcse} about
> > > > >  invoking @option{-O2} on programs that use computed gotos.
> > > > > @@ -10431,9 +10435,7 @@ by @option{-O2} and also turns on the following optimization flags:
> > > > >  -fsplit-loops @gol
> > > > >  -fsplit-paths @gol
> > > > >  -ftree-loop-distribution @gol
> > > > > --ftree-loop-vectorize @gol
> > > > >  -ftree-partial-pre @gol
> > > > > --ftree-slp-vectorize @gol
> > > > >  -funswitch-loops @gol
> > > > >  -fvect-cost-model @gol
> > > >
> > > > likewise - so just remove it here as you are around
> > > >
> > > > >  -fvect-cost-model=dynamic @gol
> > > > > diff --git a/gcc/opts.c b/gcc/opts.c
> > > > > index 1d2d22d7a3f..cee372a3235 100644
> > > > > --- a/gcc/opts.c
> > > > > +++ b/gcc/opts.c
> > > > > @@ -634,7 +634,8 @@ static const struct default_options default_options_table[] =
> > > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
> > > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
> > > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
> > > > > -    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
> > > > > +    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL,
> > > > > +      VECT_COST_MODEL_VERY_CHEAP },
> > > > >      { OPT_LEVELS_2_PLUS, OPT_finline_functions, NULL, 1 },
> > > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
> > > > >
> > > > > @@ -646,6 +647,9 @@ static const struct default_options default_options_table[] =
> > > > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
> > > > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
> > > > >        REORDER_BLOCKS_ALGORITHM_STC },
> > > > > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_loop_vectorize, NULL, 1 },
> > > > > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_slp_vectorize, NULL, 1 },
> > > > > +
> > > > >  #ifdef INSN_SCHEDULING
> > > > >    /* Only run the pre-regalloc scheduling pass if optimizing for speed.  */
> > > > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
> > > > > @@ -663,9 +667,7 @@ static const struct default_options default_options_table[] =
> > > > >      { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
> > > > >      { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
> > > > >      { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
> > > > > -    { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
> > > > >      { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
> > > > > -    { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
> > > > >      { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
> > > > >      { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
> > > > >      { OPT_LEVELS_3_PLUS, OPT_fversion_loops_for_strides, NULL, 1 },
> > > > > @@ -1331,6 +1333,16 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
> > > > >        = (opts->x_flag_unroll_loops
> > > > >           || opts->x_flag_peel_loops
> > > > >           || opts->x_optimize >= 3);
> > > > > +
> > > > > +  /* Use -fvect-cost-model=cheap instead of -fvect-cost-mode=very-cheap
> > > > > +     by default with explicit -ftree-{loop,slp}-vectorize.  */
> > > > > +  if (opts->x_optimize == 2
> > > > > +      && (opts_set->x_flag_tree_loop_vectorize
> > > > > +       || opts_set->x_flag_tree_vectorize))
> > > > > +    SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
> > > > > +                      VECT_COST_MODEL_CHEAP);
> > > > > +
> > > > > +
> > > >
> > > > please avoid adding excessive vertical space at the end of the function
> > > >
> > > > >  }
> > > > >
> > > > >  #define LEFT_COLUMN  27
> > > > > diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > > index 1d79930cd58..9351f7e7a1a 100644
> > > > > --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > > +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > > @@ -1,7 +1,7 @@
> > > > >  /* PR middle-end/91458 - inconsistent warning for writing past the end
> > > > >     of an array member
> > > > >     { dg-do compile }
> > > > > -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> > > > > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> > > >
> > > > The testcase is large - what part requires this change?  Given the
> > > > testcase was added for inconsistent warnings do they now become
> > > > inconsistent again as we enable vectorization at -O2?
> > > >
> > > > That said, the testcase adjustments need some explaining - I suppose
> > > > you didn't just slap -fno-tree-vectorize to all of those changing
> > > > behavior?
> > > >
> > > void ga1_ (void)
> > > {
> > >   a1_.a[0] = 0;
> > >   a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > >   a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > >
> > >   struct A1 a;
> > >   a.a[0] = 0;
> > >   a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > >   a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > >   sink (&a);
> > > }
> > >
> > > It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> > > there are 2 accesses, but after enabling vectorization, there's only
> > > one access, so one warning is missing which causes the failure.
> > >
> > >    <bb 2> [local count: 1073741824]:
> > >   a1__.a[0] = 0;
> > >   a1__.a[1] = 1;
> > >   a1__.a[2] = 2;
> > >   MEM <char[1]> [(struct A1 *)&a + 1B] = {};
> > >   a.n = 1;
> > >   MEM <vector(2) char> [(char *)&a + 2B] = { 1, 2 };
> > >   sink (&a);
> > >   a ={v} {CLOBBER};
> > >   return;
> >
> > I see, so it seems you looked into each instance you changed - I don't
> > want to repeat that exercise here.
> >
> Going through all testcases i changed, i found 3 miss optimization
> issue after enable O2 vectorization. The issues are recorded in
> pr102382/pr102382/pr102384, I'm not sure if they're block issues which
> needed to be solved first before installing the patch.

All those issues also appear when using -O3, correct?  I had a look
and the strlenopt bug should be fixable, but not sure about the
others.

> Also I notice  openmp case gcc.dg/gomp/simd-3.c #pragma omp for simd
> will enable vectorization for the region w/ original cost model cheap,
> but now cost model is very cheap, would that be ok?

I think omp for simd will set force_vectorize on the loop, we might
want to consider what that should mean for the purpose of selecting
a cost model.  There's also the 'vectorize' pragma with a similar
effect.  One might argue both cases warrant turning off the cost
model ...?

Richard.

> > Thus the patch is OK with the minor nits I had fixed.  Note that
> > other targets testsuites likely will need similar adjustments so
> > please watch out (but a lot of target people are in CC and could
> > deal with such fallout themselves).
> >
> > Please also prepare an entry for gcc-12/changes.html since this
> > is an important change.  Make sure to mention -fvect-cost-model
> > since otherwise people might expect vectorization to be as good
> > as with -O3.
> >
> > Thanks,
> > Richard.
> >
> > >
> > > > Thanks,
> > > > Richard.
> > > >
> > > > >  void sink (void*);
> > > > >
> > > > > diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > > > index 39e32fd4bc9..bc14309480c 100644
> > > > > --- a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > > > +++ b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed" } */
> > > > > +/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed -fno-tree-vectorize" } */
> > > > >  struct p
> > > > >  {
> > > > >    char *ay;
> > > > > diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > > > index 49ee878806a..60e8dd4f0e2 100644
> > > > > --- a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > > > +++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR c/98597 - ICE in -Wuninitialized printing a MEM_REF
> > > > >     { dg-do compile }
> > > > > -   { dg-options "-O2 -Wall" } */
> > > > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > > > >
> > > > >  struct shared_count {
> > > > >    shared_count () { }
> > > > > diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-51.c b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > > > index 6028b11637c..8b81a0ccfa7 100644
> > > > > --- a/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > > > +++ b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > > > @@ -1,7 +1,7 @@
> > > > >  /* PR middle-end/92333 - missing variable name referencing VLA in warnings
> > > > >     PR middle-end/82608 - missing -Warray-bounds on an out-of-bounds VLA index
> > > > >     { dg-do compile }
> > > > > -   { dg-options "-O2 -Wall" } */
> > > > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > > > >
> > > > >  void sink (void*);
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/Warray-parameter-3.c b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > > > index cbf3e9339f5..fbef715aa99 100644
> > > > > --- a/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > > > +++ b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > > > @@ -59,7 +59,7 @@ void fas1 (int[static 2]);    // { dg-warning "\\\[-Warray-parameter=" }
> > > > >
> > > > >  /* Also verify that -Warray-bounds doesn't trigger for ordinary array
> > > > >     parameters...  */
> > > > > -#pragma GCC optimize "2"
> > > > > +#pragma GCC optimize ("2,-fno-tree-vectorize")
> > > > >
> > > > >  __attribute__ ((noipa)) void
> > > > >  gca3 (char a[3])
> > > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > > > index bd513151cea..a78242bf26e 100644
> > > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > > > @@ -3,7 +3,7 @@
> > > > >     PR middle-end/89911 - ICE on a call with no arguments to strnlen
> > > > >     declared with no prototype
> > > > >     { dg-do compile }
> > > > > -   { dg-options "-O2 -Wall" } */
> > > > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > > > >
> > > > >  typedef __SIZE_TYPE__ size_t;
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > > > index d6201b068b6..808bf87c386 100644
> > > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > > > @@ -2,7 +2,7 @@
> > > > >     types than char are diagnosed.
> > > > >     { dg-do compile }
> > > > >     { dg-require-effective-target int32plus }
> > > > > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > > > > +   { dg-options "-O2 -fno-tree-vectorize -Wall -Wno-array-bounds" } */
> > > > >
> > > > >  typedef __INT16_TYPE__  int16_t;
> > > > >  typedef __INT32_TYPE__  int32_t;
> > > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > > > index 3a27460220c..f418a17ca93 100644
> > > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > > > @@ -1,7 +1,7 @@
> > > > >  /* PR middle-end/92312 - bogus -Wstringop-overflow storing into a trailing
> > > > >     array backed by larger buffer
> > > > >     { dg-do compile }
> > > > > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > > > > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-tree-vectorize" } */
> > > > >
> > > > >  struct S0 { char a, b[0]; };
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > > > index 6bcba274541..7cc1012130c 100644
> > > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > > > @@ -2,7 +2,7 @@
> > > > >     a larger scalar into a smaller array
> > > > >     Verify overflow by aggregate stores.
> > > > >     { dg-do compile }
> > > > > -   { dg-options "-O2" } */
> > > > > +   { dg-options "-O2 -fno-tree-vectorize" } */
> > > > >
> > > > >  #define A(N) (A ## N)
> > > > >  #define Ac1 (AC1){ 0 }
> > > > > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > > > index e110880bd8e..2e562618489 100644
> > > > > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > > > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > >
> > > > >  #define N 2
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > > > index a4af7ec4a8a..da1ab487385 100644
> > > > > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > > > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > >
> > > > >  #define N 2
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-2.c b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > > > index 85acb980f10..f4912127b81 100644
> > > > > --- a/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > > > +++ b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > > > > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> > > > >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> > > > >  /* { dg-additional-options "-mavx" { target avx } } */
> > > > >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > > > > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-3.c b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > > > index 86fee858673..c75060c07ae 100644
> > > > > --- a/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > > > +++ b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > > > > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> > > > >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> > > > >  /* { dg-additional-options "-mavx" { target avx } } */
> > > > >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > > > > diff --git a/gcc/testsuite/gcc.dg/graphite/fuse-1.c b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > > > index 527b6e5c415..61289d312c2 100644
> > > > > --- a/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > > > +++ b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* Check that the two loops are fused and that we manage to fold the two xor
> > > > >     operations.  */
> > > > > -/* { dg-options "-O2 -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> > > > >
> > > > >  /* Make sure we fuse the loops like this:
> > > > >  AST generated by isl:
> > > > > diff --git a/gcc/testsuite/gcc.dg/pr67089-6.c b/gcc/testsuite/gcc.dg/pr67089-6.c
> > > > > index db2ffdfeca4..b59d75b2318 100644
> > > > > --- a/gcc/testsuite/gcc.dg/pr67089-6.c
> > > > > +++ b/gcc/testsuite/gcc.dg/pr67089-6.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR target/67089 */
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> > > > >
> > > > >  extern void abort (void);
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/pr82929-2.c b/gcc/testsuite/gcc.dg/pr82929-2.c
> > > > > index 3442f91af02..b886f1cce76 100644
> > > > > --- a/gcc/testsuite/gcc.dg/pr82929-2.c
> > > > > +++ b/gcc/testsuite/gcc.dg/pr82929-2.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR tree-optimization/82929 */
> > > > >  /* { dg-do compile { target store_merge } } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  void
> > > > >  foo (short *p, short *q, short *r)
> > > > > diff --git a/gcc/testsuite/gcc.dg/pr82929.c b/gcc/testsuite/gcc.dg/pr82929.c
> > > > > index bb84f2b21a3..123e1919cec 100644
> > > > > --- a/gcc/testsuite/gcc.dg/pr82929.c
> > > > > +++ b/gcc/testsuite/gcc.dg/pr82929.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR tree-optimization/82929 */
> > > > >  /* { dg-do compile { target store_merge } } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  void
> > > > >  foo (short *p, short *q, short *r)
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_1.c b/gcc/testsuite/gcc.dg/store_merging_1.c
> > > > > index 4cc43dfd9e1..91ca925be0e 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_1.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_1.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* { dg-do compile } */
> > > > >  /* { dg-require-effective-target store_merge } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  struct bar {
> > > > >    int a;
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_11.c b/gcc/testsuite/gcc.dg/store_merging_11.c
> > > > > index 2ec2394afb9..60ed5cd8bf9 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_11.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_11.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* { dg-do run } */
> > > > >  /* { dg-require-effective-target store_merge } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  struct S { unsigned char b[2]; unsigned short c; unsigned char d[4]; unsigned long e; };
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_15.c b/gcc/testsuite/gcc.dg/store_merging_15.c
> > > > > index acd7de571f8..13fcca4aa11 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_15.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_15.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* { dg-do run } */
> > > > >  /* { dg-require-effective-target store_merge } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  struct S { unsigned char a, b; unsigned short c; unsigned char d, e, f, g; unsigned long long h; };
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_16.c b/gcc/testsuite/gcc.dg/store_merging_16.c
> > > > > index 9545dcce3de..cd83f1c0fe5 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_16.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_16.c
> > > > > @@ -2,7 +2,7 @@
> > > > >     are either big or little endian (not pdp endian).  */
> > > > >  /* { dg-do run { target { lp64 && { i?86-*-* x86_64-*-* powerpc*-*-* aarch64*-*-* } } } } */
> > > > >  /* { dg-require-effective-target store_merge } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  __attribute__((noipa)) void
> > > > >  f1 (unsigned char *p, unsigned long long q)
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_19.c b/gcc/testsuite/gcc.dg/store_merging_19.c
> > > > > index 0841bb4deee..0a2bbc4bfde 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_19.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_19.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR tree-optimization/83843 */
> > > > >  /* { dg-do run } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >  /* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" { target store_merge } } } */
> > > > >
> > > > >  __attribute__((noipa)) void
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_24.c b/gcc/testsuite/gcc.dg/store_merging_24.c
> > > > > index 744fe60e8e0..5291bb9e986 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_24.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_24.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR tree-optimization/87859 */
> > > > >  /* { dg-do run } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > > > >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 19 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > > >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_25.c b/gcc/testsuite/gcc.dg/store_merging_25.c
> > > > > index cf182190e91..96611b5e57b 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_25.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_25.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR tree-optimization/87859 */
> > > > >  /* { dg-do run } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > > > >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 14 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > > >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_28.c b/gcc/testsuite/gcc.dg/store_merging_28.c
> > > > > index 2d6cffc4694..fadb7fff993 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_28.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_28.c
> > > > > @@ -1,7 +1,7 @@
> > > > >  /* PR tree-optimization/88709 */
> > > > >  /* { dg-do compile } */
> > > > >  /* { dg-require-effective-target store_merge } */
> > > > > -/* { dg-options "-O2 -fno-ipa-icf -fdump-tree-store-merging-details" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-ipa-icf -fdump-tree-store-merging-details" } */
> > > > >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 16 stores" 8 "store-merging" { target { i?86-*-* x86_64-*-* } } } } */
> > > > >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 6 stores" 1 "store-merging" { target { ! arm*-*-* } } } } */
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_30.c b/gcc/testsuite/gcc.dg/store_merging_30.c
> > > > > index 694d560a621..baf94efe733 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_30.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_30.c
> > > > > @@ -1,7 +1,7 @@
> > > > >  /* PR tree-optimization/94573 */
> > > > >  /* { dg-do compile } */
> > > > >  /* { dg-require-effective-target store_merge } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > > > >  /* { dg-final { scan-tree-dump "New sequence of 4 stores to replace old one of 8 stores" "store-merging" { target lp64 } } } */
> > > > >
> > > > >  int var[43][12];
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_5.c b/gcc/testsuite/gcc.dg/store_merging_5.c
> > > > > index 6e7c72510ff..b0cb0da78e0 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_5.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_5.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* { dg-do compile } */
> > > > >  /* { dg-require-effective-target store_merge } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  /* Make sure that non-aliasing non-constant interspersed stores do not
> > > > >     stop chains.  */
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_7.c b/gcc/testsuite/gcc.dg/store_merging_7.c
> > > > > index c744ece6407..dbe000a463e 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_7.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_7.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* { dg-do compile } */
> > > > >  /* { dg-require-effective-target store_merge } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  /* Check that we can merge consecutive array members through the pointer.
> > > > >     PR rtl-optimization/23684.  */
> > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_8.c b/gcc/testsuite/gcc.dg/store_merging_8.c
> > > > > index e710a544ff0..d719e0a2257 100644
> > > > > --- a/gcc/testsuite/gcc.dg/store_merging_8.c
> > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_8.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* { dg-do compile } */
> > > > >  /* { dg-require-effective-target store_merge } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  struct baz {
> > > > >    struct bar {
> > > > > diff --git a/gcc/testsuite/gcc.dg/strlenopt-85.c b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > > > index e049e0c30e0..2ba1ee05700 100644
> > > > > --- a/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > > > +++ b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > > > @@ -4,7 +4,7 @@
> > > > >     of memory allocated by calloc() even if one or more nul bytes are
> > > > >     written into it.
> > > > >     { dg-do compile }
> > > > > -   { dg-options "-O2 -fdump-tree-optimized" } */
> > > > > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > > > >
> > > > >  unsigned n0, n1;
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > > > index 70659c00c0e..6c803908781 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR middle-end/90676 - default GIMPLE dumps lack information
> > > > >     { dg-do compile }
> > > > > -   { dg-options "-O2 -fdump-tree-store-merging" }
> > > > > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" }
> > > > >     { dg-require-effective-target int32plus }
> > > > >     { dg-require-effective-target store_merge } */
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > > > index 50d86a00485..b9e40e964c1 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fopt-info-loop-missed" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fopt-info-loop-missed" } */
> > > > >  extern void g(void);
> > > > >
> > > > >  void
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > > > index 9f9c61aa213..860cde12c0f 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-Os -fdump-tree-optimized" } */
> > > > > +/* { dg-options "-Os -fno-tree-vectorize -fdump-tree-optimized" } */
> > > > >
> > > > >
> > > > >  struct struct1
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > > > index f216e83c7b3..c7ef73ad59e 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > >
> > > > >  void f (void*);
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > > > index 7d6a724e4ad..0ddad573129 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> > > > >
> > > > >  void write64 (void *p)
> > > > >  {
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > > > index f68be2b3379..8c3d9a4fc58 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* { dg-do compile } */
> > > > >  /* { dg-do run } */
> > > > > -/* { dg-options "-O2 -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > >
> > > > >  void abort (void);
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > > > index ec08d6c0318..1fc8f089345 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do run } */
> > > > > -/* { dg-options "-O2 -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > >
> > > > >  int arr1[105] = {2, 3, 5, 7, 11, 13, 0};
> > > > >  int arr2[105] = {2, 3, 5, 7, 11, 13, 0};
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > > > index 467903bf3fc..46f0d0c2317 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > > > @@ -1,7 +1,7 @@
> > > > >  /* Prefetching used to prefer nonsensical unroll factor of 5 in this testcase.  */
> > > > >
> > > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> > > > >
> > > > >  #define N 1000000
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > > > index 12f09016943..3fa71685ace 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> > > > >
> > > > >  #define N 1000
> > > > >  #define K 900
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > > > index cbd6a80d345..00f41c3e4f4 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > >
> > > > >  #define K 1000000
> > > > >  int a[K];
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > > > index da4847320b1..e8848c30acc 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > >
> > > > >  #define K 1000000
> > > > >  int a[K], b[K];
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > > > index 92b2df80ec8..2e7b5b496ea 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > > > >  int g(_Complex int*);
> > > > >  int f(void)
> > > > >  {
> > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > > > index 718b7466e50..7bb8d060631 100644
> > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > > > >  int g(_Complex int*);
> > > > >  int f(void)
> > > > >  {
> > > > > diff --git a/gcc/testsuite/gcc.dg/uninit-40.c b/gcc/testsuite/gcc.dg/uninit-40.c
> > > > > index c015191ca32..8708079d397 100644
> > > > > --- a/gcc/testsuite/gcc.dg/uninit-40.c
> > > > > +++ b/gcc/testsuite/gcc.dg/uninit-40.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR tree-optimization/98597 */
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -Wuninitialized" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -Wuninitialized" } */
> > > > >
> > > > >  union U { double d; int i; float f; };
> > > > >  struct S { char a; int b; char c; unsigned d; union U e; int f[3]; unsigned g[3]; };
> > > > > diff --git a/gcc/testsuite/gcc.dg/unroll-7.c b/gcc/testsuite/gcc.dg/unroll-7.c
> > > > > index 055369bf8b1..695af5757cc 100644
> > > > > --- a/gcc/testsuite/gcc.dg/unroll-7.c
> > > > > +++ b/gcc/testsuite/gcc.dg/unroll-7.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> > > > >  /* { dg-require-effective-target int32plus } */
> > > > >
> > > > >  extern int *a;
> > > > > diff --git a/gcc/testsuite/gcc.misc-tests/help.exp b/gcc/testsuite/gcc.misc-tests/help.exp
> > > > > index 5e034d26947..eb6d8686c6a 100644
> > > > > --- a/gcc/testsuite/gcc.misc-tests/help.exp
> > > > > +++ b/gcc/testsuite/gcc.misc-tests/help.exp
> > > > > @@ -79,7 +79,7 @@ check_for_options c "--help=target,optimizers" "" "" ""
> > > > >  check_for_options c "--help=warnings,^joined,^undocumented" "" "" ""
> > > > >  check_for_options c "-Q -O2 --help=optimizers" {
> > > > >  -O
> > > > > --ftree-loop-vectorize[^\n]*disabled
> > > > > +-ftree-loop-vectorize[^\n]*enabled
> > > > >  } "  -g  " ""
> > > > >  check_for_options c "-Q -O3 --help=optimizers" {
> > > > >  -O
> > > > > diff --git a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > > > index 709cd21e671..a732bc466db 100644
> > > > > --- a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > > > +++ b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do run } */
> > > > > -/* { dg-options "-O2 -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> > > > >  /* { dg-require-effective-target avx512vl } */
> > > > >  /* { dg-require-effective-target avx512vpopcntdqvl } */
> > > > >  /* { dg-require-effective-target avx512bw } */
> > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr22141.c b/gcc/testsuite/gcc.target/i386/pr22141.c
> > > > > index 036422e8ccf..b68b97f3f72 100644
> > > > > --- a/gcc/testsuite/gcc.target/i386/pr22141.c
> > > > > +++ b/gcc/testsuite/gcc.target/i386/pr22141.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR middle-end/22141 */
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-Os" } */
> > > > > +/* { dg-options "-Os -fno-tree-vectorize" } */
> > > > >
> > > > >  extern void abort (void);
> > > > >
> > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr34012.c b/gcc/testsuite/gcc.target/i386/pr34012.c
> > > > > index d0cffa05290..1c1f0eea52e 100644
> > > > > --- a/gcc/testsuite/gcc.target/i386/pr34012.c
> > > > > +++ b/gcc/testsuite/gcc.target/i386/pr34012.c
> > > > > @@ -1,7 +1,7 @@
> > > > >  /* PR rtl-optimization/34012 */
> > > > >  /* { dg-do compile } */
> > > > >  /* { dg-require-effective-target lp64 } */
> > > > > -/* { dg-options "-O2 -fno-store-merging" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-store-merging" } */
> > > > >
> > > > >  void bar (long int *);
> > > > >  void
> > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr49781-1.c b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > > > index 60f9d50d866..d5a2e32db97 100644
> > > > > --- a/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > > > +++ b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > > > @@ -1,5 +1,5 @@
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -fpic -mtune=generic" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fpic -mtune=generic" } */
> > > > >  /* { dg-require-effective-target fpic } */
> > > > >
> > > > >  static int heap[2*(256 +1+29)+1];
> > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-1.c b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > > > index 9a7e32d6f2f..526f48921fd 100644
> > > > > --- a/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > > > +++ b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR target/95798 */
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> > > > >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-2.c b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > > > index c670d3780e8..6b5c5a73e96 100644
> > > > > --- a/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > > > +++ b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > > > @@ -1,6 +1,6 @@
> > > > >  /* PR target/95798 */
> > > > >  /* { dg-do compile } */
> > > > > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > > > > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> > > > >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > > diff --git a/gcc/testsuite/gfortran.dg/pr77498.f b/gcc/testsuite/gfortran.dg/pr77498.f
> > > > > index f957b57bb00..a0fc8275a84 100644
> > > > > --- a/gcc/testsuite/gfortran.dg/pr77498.f
> > > > > +++ b/gcc/testsuite/gfortran.dg/pr77498.f
> > > > > @@ -1,5 +1,5 @@
> > > > >  ! { dg-do compile }
> > > > > -! { dg-options "-O2 -ffast-math -fdump-tree-pre" }
> > > > > +! { dg-options "-O2 -fno-tree-vectorize -ffast-math -fdump-tree-pre" }
> > > > >
> > > > >        subroutine foo(U,V,R,N,A)
> > > > >        integer N
> > > > >
> > > >
> > > > --
> > > > Richard Biener <rguenther@suse.de>
> > > > SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> > > > Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
> > >
> > >
> > >
> > >
> >
> > --
> > Richard Biener <rguenther@suse.de>
> > SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> > Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
> 
> 
> 
>
Hongtao Liu Sept. 17, 2021, 8:06 a.m. UTC | #6
On Fri, Sep 17, 2021 at 3:47 PM Richard Biener <rguenther@suse.de> wrote:
>
> On Fri, 17 Sep 2021, Hongtao Liu wrote:
>
> > On Thu, Sep 16, 2021 at 8:31 PM Richard Biener <rguenther@suse.de> wrote:
> > >
> > > On Thu, 16 Sep 2021, Hongtao Liu wrote:
> > >
> > > > On Thu, Sep 16, 2021 at 4:23 PM Richard Biener via Gcc-patches
> > > > <gcc-patches@gcc.gnu.org> wrote:
> > > > >
> > > > > On Thu, 16 Sep 2021, liuhongt wrote:
> > > > >
> > > > > > Ping
> > > > > > rebased on latest trunk.
> > > > > >
> > > > > > gcc/ChangeLog:
> > > > > >
> > > > > >       * common.opt (ftree-vectorize): Add Var(flag_tree_vectorize).
> > > > > >       * doc/invoke.texi (Options That Control Optimization): Update
> > > > > >       documents.
> > > > > >       * opts.c (default_options_table): Enable auto-vectorization at
> > > > > >       O2 with very-cheap cost model.
> > > > > >       (finish_options): Use cheap cost model for
> > > > > >       explicit -ftree{,-loop}-vectorize.
> > > > > >
> > > > > > gcc/testsuite/ChangeLog:
> > > > > >
> > > > > >       * c-c++-common/Wstringop-overflow-2.c: Adjust testcase.
> > > > > >       * g++.dg/tree-ssa/pr81408.C: Ditto.
> > > > > >       * g++.dg/warn/Wuninitialized-13.C: Ditto.
> > > > > >       * gcc.dg/Warray-bounds-51.c: Ditto.
> > > > > >       * gcc.dg/Warray-parameter-3.c: Ditto.
> > > > > >       * gcc.dg/Wstringop-overflow-13.c: Ditto.
> > > > > >       * gcc.dg/Wstringop-overflow-14.c: Ditto.
> > > > > >       * gcc.dg/Wstringop-overflow-21.c: Ditto.
> > > > > >       * gcc.dg/Wstringop-overflow-68.c: Ditto.
> > > > > >       * gcc.dg/gomp/pr46032-2.c: Ditto.
> > > > > >       * gcc.dg/gomp/pr46032-3.c: Ditto.
> > > > > >       * gcc.dg/gomp/simd-2.c: Ditto.
> > > > > >       * gcc.dg/gomp/simd-3.c: Ditto.
> > > > > >       * gcc.dg/graphite/fuse-1.c: Ditto.
> > > > > >       * gcc.dg/pr67089-6.c: Ditto.
> > > > > >       * gcc.dg/pr82929-2.c: Ditto.
> > > > > >       * gcc.dg/pr82929.c: Ditto.
> > > > > >       * gcc.dg/store_merging_1.c: Ditto.
> > > > > >       * gcc.dg/store_merging_11.c: Ditto.
> > > > > >       * gcc.dg/store_merging_15.c: Ditto.
> > > > > >       * gcc.dg/store_merging_16.c: Ditto.
> > > > > >       * gcc.dg/store_merging_19.c: Ditto.
> > > > > >       * gcc.dg/store_merging_24.c: Ditto.
> > > > > >       * gcc.dg/store_merging_25.c: Ditto.
> > > > > >       * gcc.dg/store_merging_28.c: Ditto.
> > > > > >       * gcc.dg/store_merging_30.c: Ditto.
> > > > > >       * gcc.dg/store_merging_5.c: Ditto.
> > > > > >       * gcc.dg/store_merging_7.c: Ditto.
> > > > > >       * gcc.dg/store_merging_8.c: Ditto.
> > > > > >       * gcc.dg/strlenopt-85.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/dump-6.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/pr19210-1.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/pr47059.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/pr86017.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/pr91482.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/predcom-1.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/predcom-dse-3.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/prefetch-3.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/prefetch-6.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/prefetch-8.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/prefetch-9.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/ssa-dse-18.c: Ditto.
> > > > > >       * gcc.dg/tree-ssa/ssa-dse-19.c: Ditto.
> > > > > >       * gcc.dg/uninit-40.c: Ditto.
> > > > > >       * gcc.dg/unroll-7.c: Ditto.
> > > > > >       * gcc.misc-tests/help.exp: Ditto.
> > > > > >       * gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c: Ditto.
> > > > > >       * gcc.target/i386/pr22141.c: Ditto.
> > > > > >       * gcc.target/i386/pr34012.c: Ditto.
> > > > > >       * gcc.target/i386/pr49781-1.c: Ditto.
> > > > > >       * gcc.target/i386/pr95798-1.c: Ditto.
> > > > > >       * gcc.target/i386/pr95798-2.c: Ditto.
> > > > > >       * gfortran.dg/pr77498.f: Ditto.
> > > > > > ---
> > > > > >  gcc/common.opt                                 |  2 +-
> > > > > >  gcc/doc/invoke.texi                            |  8 +++++---
> > > > > >  gcc/opts.c                                     | 18 +++++++++++++++---
> > > > > >  .../c-c++-common/Wstringop-overflow-2.c        |  2 +-
> > > > > >  gcc/testsuite/g++.dg/tree-ssa/pr81408.C        |  2 +-
> > > > > >  gcc/testsuite/g++.dg/warn/Wuninitialized-13.C  |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/Warray-bounds-51.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/Warray-parameter-3.c      |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-13.c   |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-14.c   |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-21.c   |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/Wstringop-overflow-68.c   |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/gomp/pr46032-2.c          |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/gomp/pr46032-3.c          |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/gomp/simd-2.c             |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/gomp/simd-3.c             |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/graphite/fuse-1.c         |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/pr67089-6.c               |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/pr82929-2.c               |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/pr82929.c                 |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_1.c         |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_11.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_15.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_16.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_19.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_24.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_25.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_28.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_30.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_5.c         |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_7.c         |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/store_merging_8.c         |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/strlenopt-85.c            |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/dump-6.c         |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c      |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/pr47059.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/pr86017.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/pr91482.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c      |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c  |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c     |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c     |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c     |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c     |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c     |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c     |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/uninit-40.c               |  2 +-
> > > > > >  gcc/testsuite/gcc.dg/unroll-7.c                |  2 +-
> > > > > >  gcc/testsuite/gcc.misc-tests/help.exp          |  2 +-
> > > > > >  .../i386/avx512vpopcntdqvl-vpopcntd-1.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.target/i386/pr22141.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.target/i386/pr34012.c        |  2 +-
> > > > > >  gcc/testsuite/gcc.target/i386/pr49781-1.c      |  2 +-
> > > > > >  gcc/testsuite/gcc.target/i386/pr95798-1.c      |  2 +-
> > > > > >  gcc/testsuite/gcc.target/i386/pr95798-2.c      |  2 +-
> > > > > >  gcc/testsuite/gfortran.dg/pr77498.f            |  2 +-
> > > > > >  56 files changed, 74 insertions(+), 60 deletions(-)
> > > > > >
> > > > > > diff --git a/gcc/common.opt b/gcc/common.opt
> > > > > > index b921f5e3b25..4f2c0294c29 100644
> > > > > > --- a/gcc/common.opt
> > > > > > +++ b/gcc/common.opt
> > > > > > @@ -3031,7 +3031,7 @@ Perform variable tracking and also tag variables that are uninitialized.
> > > > > >
> > > > > >  ; Alias to enable both -ftree-loop-vectorize and -ftree-slp-vectorize.
> > > > > >  ftree-vectorize
> > > > > > -Common Optimization
> > > > > > +Common Var(flag_tree_vectorize) Optimization
> > > > > >  Enable vectorization on trees.
> > > > > >
> > > > > >  ftree-vectorizer-verbose=
> > > > > > diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
> > > > > > index 78cfc100ac2..be022ef8024 100644
> > > > > > --- a/gcc/doc/invoke.texi
> > > > > > +++ b/gcc/doc/invoke.texi
> > > > > > @@ -10409,9 +10409,13 @@ also turns on the following optimization flags:
> > > > > >  -fstrict-aliasing @gol
> > > > > >  -fthread-jumps @gol
> > > > > >  -ftree-builtin-call-dce @gol
> > > > > > +-ftree-loop-vectorize @gol
> > > > > >  -ftree-pre @gol
> > > > > > +-ftree-slp-vectorize @gol
> > > > > >  -ftree-switch-conversion  -ftree-tail-merge @gol
> > > > > > --ftree-vrp}
> > > > > > +-ftree-vrp @gol
> > > > > > +-fvect-cost-model @gol
> > > > >
> > > > > the above is redundant
> > > > >
> > > > > > +-fvect-cost-model=very-cheap}
> > > > > >
> > > > > >  Please note the warning under @option{-fgcse} about
> > > > > >  invoking @option{-O2} on programs that use computed gotos.
> > > > > > @@ -10431,9 +10435,7 @@ by @option{-O2} and also turns on the following optimization flags:
> > > > > >  -fsplit-loops @gol
> > > > > >  -fsplit-paths @gol
> > > > > >  -ftree-loop-distribution @gol
> > > > > > --ftree-loop-vectorize @gol
> > > > > >  -ftree-partial-pre @gol
> > > > > > --ftree-slp-vectorize @gol
> > > > > >  -funswitch-loops @gol
> > > > > >  -fvect-cost-model @gol
> > > > >
> > > > > likewise - so just remove it here as you are around
> > > > >
> > > > > >  -fvect-cost-model=dynamic @gol
> > > > > > diff --git a/gcc/opts.c b/gcc/opts.c
> > > > > > index 1d2d22d7a3f..cee372a3235 100644
> > > > > > --- a/gcc/opts.c
> > > > > > +++ b/gcc/opts.c
> > > > > > @@ -634,7 +634,8 @@ static const struct default_options default_options_table[] =
> > > > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
> > > > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
> > > > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
> > > > > > -    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
> > > > > > +    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL,
> > > > > > +      VECT_COST_MODEL_VERY_CHEAP },
> > > > > >      { OPT_LEVELS_2_PLUS, OPT_finline_functions, NULL, 1 },
> > > > > >      { OPT_LEVELS_2_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
> > > > > >
> > > > > > @@ -646,6 +647,9 @@ static const struct default_options default_options_table[] =
> > > > > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
> > > > > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
> > > > > >        REORDER_BLOCKS_ALGORITHM_STC },
> > > > > > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_loop_vectorize, NULL, 1 },
> > > > > > +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_slp_vectorize, NULL, 1 },
> > > > > > +
> > > > > >  #ifdef INSN_SCHEDULING
> > > > > >    /* Only run the pre-regalloc scheduling pass if optimizing for speed.  */
> > > > > >      { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
> > > > > > @@ -663,9 +667,7 @@ static const struct default_options default_options_table[] =
> > > > > >      { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
> > > > > >      { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
> > > > > >      { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
> > > > > > -    { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
> > > > > >      { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
> > > > > > -    { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
> > > > > >      { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
> > > > > >      { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
> > > > > >      { OPT_LEVELS_3_PLUS, OPT_fversion_loops_for_strides, NULL, 1 },
> > > > > > @@ -1331,6 +1333,16 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
> > > > > >        = (opts->x_flag_unroll_loops
> > > > > >           || opts->x_flag_peel_loops
> > > > > >           || opts->x_optimize >= 3);
> > > > > > +
> > > > > > +  /* Use -fvect-cost-model=cheap instead of -fvect-cost-mode=very-cheap
> > > > > > +     by default with explicit -ftree-{loop,slp}-vectorize.  */
> > > > > > +  if (opts->x_optimize == 2
> > > > > > +      && (opts_set->x_flag_tree_loop_vectorize
> > > > > > +       || opts_set->x_flag_tree_vectorize))
> > > > > > +    SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
> > > > > > +                      VECT_COST_MODEL_CHEAP);
> > > > > > +
> > > > > > +
> > > > >
> > > > > please avoid adding excessive vertical space at the end of the function
> > > > >
> > > > > >  }
> > > > > >
> > > > > >  #define LEFT_COLUMN  27
> > > > > > diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > > > index 1d79930cd58..9351f7e7a1a 100644
> > > > > > --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > > > +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > > > @@ -1,7 +1,7 @@
> > > > > >  /* PR middle-end/91458 - inconsistent warning for writing past the end
> > > > > >     of an array member
> > > > > >     { dg-do compile }
> > > > > > -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> > > > > > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> > > > >
> > > > > The testcase is large - what part requires this change?  Given the
> > > > > testcase was added for inconsistent warnings do they now become
> > > > > inconsistent again as we enable vectorization at -O2?
> > > > >
> > > > > That said, the testcase adjustments need some explaining - I suppose
> > > > > you didn't just slap -fno-tree-vectorize to all of those changing
> > > > > behavior?
> > > > >
> > > > void ga1_ (void)
> > > > {
> > > >   a1_.a[0] = 0;
> > > >   a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > > >   a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > > >
> > > >   struct A1 a;
> > > >   a.a[0] = 0;
> > > >   a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > > >   a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > > >   sink (&a);
> > > > }
> > > >
> > > > It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> > > > there are 2 accesses, but after enabling vectorization, there's only
> > > > one access, so one warning is missing which causes the failure.
> > > >
> > > >    <bb 2> [local count: 1073741824]:
> > > >   a1__.a[0] = 0;
> > > >   a1__.a[1] = 1;
> > > >   a1__.a[2] = 2;
> > > >   MEM <char[1]> [(struct A1 *)&a + 1B] = {};
> > > >   a.n = 1;
> > > >   MEM <vector(2) char> [(char *)&a + 2B] = { 1, 2 };
> > > >   sink (&a);
> > > >   a ={v} {CLOBBER};
> > > >   return;
> > >
> > > I see, so it seems you looked into each instance you changed - I don't
> > > want to repeat that exercise here.
> > >
> > Going through all testcases i changed, i found 3 miss optimization
> > issue after enable O2 vectorization. The issues are recorded in
> > pr102382/pr102382/pr102384, I'm not sure if they're block issues which
> > needed to be solved first before installing the patch.
>
> All those issues also appear when using -O3, correct?  I had a look
Yes.
> and the strlenopt bug should be fixable, but not sure about the
> others.
>
> > Also I notice  openmp case gcc.dg/gomp/simd-3.c #pragma omp for simd
> > will enable vectorization for the region w/ original cost model cheap,
> > but now cost model is very cheap, would that be ok?
>
> I think omp for simd will set force_vectorize on the loop, we might
> want to consider what that should mean for the purpose of selecting
> a cost model.  There's also the 'vectorize' pragma with a similar
> effect.  One might argue both cases warrant turning off the cost
> model ...?
>
> Richard.
>
> > > Thus the patch is OK with the minor nits I had fixed.  Note that
> > > other targets testsuites likely will need similar adjustments so
> > > please watch out (but a lot of target people are in CC and could
> > > deal with such fallout themselves).
> > >
> > > Please also prepare an entry for gcc-12/changes.html since this
> > > is an important change.  Make sure to mention -fvect-cost-model
> > > since otherwise people might expect vectorization to be as good
> > > as with -O3.
> > >
> > > Thanks,
> > > Richard.
> > >
> > > >
> > > > > Thanks,
> > > > > Richard.
> > > > >
> > > > > >  void sink (void*);
> > > > > >
> > > > > > diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > > > > index 39e32fd4bc9..bc14309480c 100644
> > > > > > --- a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > > > > +++ b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed" } */
> > > > > > +/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed -fno-tree-vectorize" } */
> > > > > >  struct p
> > > > > >  {
> > > > > >    char *ay;
> > > > > > diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > > > > index 49ee878806a..60e8dd4f0e2 100644
> > > > > > --- a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > > > > +++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR c/98597 - ICE in -Wuninitialized printing a MEM_REF
> > > > > >     { dg-do compile }
> > > > > > -   { dg-options "-O2 -Wall" } */
> > > > > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > > > > >
> > > > > >  struct shared_count {
> > > > > >    shared_count () { }
> > > > > > diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-51.c b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > > > > index 6028b11637c..8b81a0ccfa7 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> > > > > > @@ -1,7 +1,7 @@
> > > > > >  /* PR middle-end/92333 - missing variable name referencing VLA in warnings
> > > > > >     PR middle-end/82608 - missing -Warray-bounds on an out-of-bounds VLA index
> > > > > >     { dg-do compile }
> > > > > > -   { dg-options "-O2 -Wall" } */
> > > > > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > > > > >
> > > > > >  void sink (void*);
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/Warray-parameter-3.c b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > > > > index cbf3e9339f5..fbef715aa99 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> > > > > > @@ -59,7 +59,7 @@ void fas1 (int[static 2]);    // { dg-warning "\\\[-Warray-parameter=" }
> > > > > >
> > > > > >  /* Also verify that -Warray-bounds doesn't trigger for ordinary array
> > > > > >     parameters...  */
> > > > > > -#pragma GCC optimize "2"
> > > > > > +#pragma GCC optimize ("2,-fno-tree-vectorize")
> > > > > >
> > > > > >  __attribute__ ((noipa)) void
> > > > > >  gca3 (char a[3])
> > > > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > > > > index bd513151cea..a78242bf26e 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> > > > > > @@ -3,7 +3,7 @@
> > > > > >     PR middle-end/89911 - ICE on a call with no arguments to strnlen
> > > > > >     declared with no prototype
> > > > > >     { dg-do compile }
> > > > > > -   { dg-options "-O2 -Wall" } */
> > > > > > +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> > > > > >
> > > > > >  typedef __SIZE_TYPE__ size_t;
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > > > > index d6201b068b6..808bf87c386 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> > > > > > @@ -2,7 +2,7 @@
> > > > > >     types than char are diagnosed.
> > > > > >     { dg-do compile }
> > > > > >     { dg-require-effective-target int32plus }
> > > > > > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > > > > > +   { dg-options "-O2 -fno-tree-vectorize -Wall -Wno-array-bounds" } */
> > > > > >
> > > > > >  typedef __INT16_TYPE__  int16_t;
> > > > > >  typedef __INT32_TYPE__  int32_t;
> > > > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > > > > index 3a27460220c..f418a17ca93 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> > > > > > @@ -1,7 +1,7 @@
> > > > > >  /* PR middle-end/92312 - bogus -Wstringop-overflow storing into a trailing
> > > > > >     array backed by larger buffer
> > > > > >     { dg-do compile }
> > > > > > -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> > > > > > +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-tree-vectorize" } */
> > > > > >
> > > > > >  struct S0 { char a, b[0]; };
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > > > > index 6bcba274541..7cc1012130c 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> > > > > > @@ -2,7 +2,7 @@
> > > > > >     a larger scalar into a smaller array
> > > > > >     Verify overflow by aggregate stores.
> > > > > >     { dg-do compile }
> > > > > > -   { dg-options "-O2" } */
> > > > > > +   { dg-options "-O2 -fno-tree-vectorize" } */
> > > > > >
> > > > > >  #define A(N) (A ## N)
> > > > > >  #define Ac1 (AC1){ 0 }
> > > > > > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > > > > index e110880bd8e..2e562618489 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > > >
> > > > > >  #define N 2
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > > > > index a4af7ec4a8a..da1ab487385 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> > > > > >
> > > > > >  #define N 2
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-2.c b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > > > > index 85acb980f10..f4912127b81 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > > > > > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> > > > > >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> > > > > >  /* { dg-additional-options "-mavx" { target avx } } */
> > > > > >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > > > > > diff --git a/gcc/testsuite/gcc.dg/gomp/simd-3.c b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > > > > index 86fee858673..c75060c07ae 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> > > > > > +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> > > > > >  /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> > > > > >  /* { dg-additional-options "-mavx" { target avx } } */
> > > > > >  /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> > > > > > diff --git a/gcc/testsuite/gcc.dg/graphite/fuse-1.c b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > > > > index 527b6e5c415..61289d312c2 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* Check that the two loops are fused and that we manage to fold the two xor
> > > > > >     operations.  */
> > > > > > -/* { dg-options "-O2 -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> > > > > >
> > > > > >  /* Make sure we fuse the loops like this:
> > > > > >  AST generated by isl:
> > > > > > diff --git a/gcc/testsuite/gcc.dg/pr67089-6.c b/gcc/testsuite/gcc.dg/pr67089-6.c
> > > > > > index db2ffdfeca4..b59d75b2318 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/pr67089-6.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/pr67089-6.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR target/67089 */
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> > > > > >
> > > > > >  extern void abort (void);
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/pr82929-2.c b/gcc/testsuite/gcc.dg/pr82929-2.c
> > > > > > index 3442f91af02..b886f1cce76 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/pr82929-2.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/pr82929-2.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR tree-optimization/82929 */
> > > > > >  /* { dg-do compile { target store_merge } } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  void
> > > > > >  foo (short *p, short *q, short *r)
> > > > > > diff --git a/gcc/testsuite/gcc.dg/pr82929.c b/gcc/testsuite/gcc.dg/pr82929.c
> > > > > > index bb84f2b21a3..123e1919cec 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/pr82929.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/pr82929.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR tree-optimization/82929 */
> > > > > >  /* { dg-do compile { target store_merge } } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  void
> > > > > >  foo (short *p, short *q, short *r)
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_1.c b/gcc/testsuite/gcc.dg/store_merging_1.c
> > > > > > index 4cc43dfd9e1..91ca925be0e 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_1.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_1.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* { dg-do compile } */
> > > > > >  /* { dg-require-effective-target store_merge } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  struct bar {
> > > > > >    int a;
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_11.c b/gcc/testsuite/gcc.dg/store_merging_11.c
> > > > > > index 2ec2394afb9..60ed5cd8bf9 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_11.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_11.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* { dg-do run } */
> > > > > >  /* { dg-require-effective-target store_merge } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  struct S { unsigned char b[2]; unsigned short c; unsigned char d[4]; unsigned long e; };
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_15.c b/gcc/testsuite/gcc.dg/store_merging_15.c
> > > > > > index acd7de571f8..13fcca4aa11 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_15.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_15.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* { dg-do run } */
> > > > > >  /* { dg-require-effective-target store_merge } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  struct S { unsigned char a, b; unsigned short c; unsigned char d, e, f, g; unsigned long long h; };
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_16.c b/gcc/testsuite/gcc.dg/store_merging_16.c
> > > > > > index 9545dcce3de..cd83f1c0fe5 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_16.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_16.c
> > > > > > @@ -2,7 +2,7 @@
> > > > > >     are either big or little endian (not pdp endian).  */
> > > > > >  /* { dg-do run { target { lp64 && { i?86-*-* x86_64-*-* powerpc*-*-* aarch64*-*-* } } } } */
> > > > > >  /* { dg-require-effective-target store_merge } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  __attribute__((noipa)) void
> > > > > >  f1 (unsigned char *p, unsigned long long q)
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_19.c b/gcc/testsuite/gcc.dg/store_merging_19.c
> > > > > > index 0841bb4deee..0a2bbc4bfde 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_19.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_19.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR tree-optimization/83843 */
> > > > > >  /* { dg-do run } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >  /* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" { target store_merge } } } */
> > > > > >
> > > > > >  __attribute__((noipa)) void
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_24.c b/gcc/testsuite/gcc.dg/store_merging_24.c
> > > > > > index 744fe60e8e0..5291bb9e986 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_24.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_24.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR tree-optimization/87859 */
> > > > > >  /* { dg-do run } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > > > > >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 19 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > > > >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_25.c b/gcc/testsuite/gcc.dg/store_merging_25.c
> > > > > > index cf182190e91..96611b5e57b 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_25.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_25.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR tree-optimization/87859 */
> > > > > >  /* { dg-do run } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > > > > >  /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 14 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > > > >  /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_28.c b/gcc/testsuite/gcc.dg/store_merging_28.c
> > > > > > index 2d6cffc4694..fadb7fff993 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_28.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_28.c
> > > > > > @@ -1,7 +1,7 @@
> > > > > >  /* PR tree-optimization/88709 */
> > > > > >  /* { dg-do compile } */
> > > > > >  /* { dg-require-effective-target store_merge } */
> > > > > > -/* { dg-options "-O2 -fno-ipa-icf -fdump-tree-store-merging-details" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-ipa-icf -fdump-tree-store-merging-details" } */
> > > > > >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 16 stores" 8 "store-merging" { target { i?86-*-* x86_64-*-* } } } } */
> > > > > >  /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 6 stores" 1 "store-merging" { target { ! arm*-*-* } } } } */
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_30.c b/gcc/testsuite/gcc.dg/store_merging_30.c
> > > > > > index 694d560a621..baf94efe733 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_30.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_30.c
> > > > > > @@ -1,7 +1,7 @@
> > > > > >  /* PR tree-optimization/94573 */
> > > > > >  /* { dg-do compile } */
> > > > > >  /* { dg-require-effective-target store_merge } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> > > > > >  /* { dg-final { scan-tree-dump "New sequence of 4 stores to replace old one of 8 stores" "store-merging" { target lp64 } } } */
> > > > > >
> > > > > >  int var[43][12];
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_5.c b/gcc/testsuite/gcc.dg/store_merging_5.c
> > > > > > index 6e7c72510ff..b0cb0da78e0 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_5.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_5.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* { dg-do compile } */
> > > > > >  /* { dg-require-effective-target store_merge } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  /* Make sure that non-aliasing non-constant interspersed stores do not
> > > > > >     stop chains.  */
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_7.c b/gcc/testsuite/gcc.dg/store_merging_7.c
> > > > > > index c744ece6407..dbe000a463e 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_7.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_7.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* { dg-do compile } */
> > > > > >  /* { dg-require-effective-target store_merge } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  /* Check that we can merge consecutive array members through the pointer.
> > > > > >     PR rtl-optimization/23684.  */
> > > > > > diff --git a/gcc/testsuite/gcc.dg/store_merging_8.c b/gcc/testsuite/gcc.dg/store_merging_8.c
> > > > > > index e710a544ff0..d719e0a2257 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/store_merging_8.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/store_merging_8.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* { dg-do compile } */
> > > > > >  /* { dg-require-effective-target store_merge } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  struct baz {
> > > > > >    struct bar {
> > > > > > diff --git a/gcc/testsuite/gcc.dg/strlenopt-85.c b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > > > > index e049e0c30e0..2ba1ee05700 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/strlenopt-85.c
> > > > > > @@ -4,7 +4,7 @@
> > > > > >     of memory allocated by calloc() even if one or more nul bytes are
> > > > > >     written into it.
> > > > > >     { dg-do compile }
> > > > > > -   { dg-options "-O2 -fdump-tree-optimized" } */
> > > > > > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > > > > >
> > > > > >  unsigned n0, n1;
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > > > > index 70659c00c0e..6c803908781 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR middle-end/90676 - default GIMPLE dumps lack information
> > > > > >     { dg-do compile }
> > > > > > -   { dg-options "-O2 -fdump-tree-store-merging" }
> > > > > > +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" }
> > > > > >     { dg-require-effective-target int32plus }
> > > > > >     { dg-require-effective-target store_merge } */
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > > > > index 50d86a00485..b9e40e964c1 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fopt-info-loop-missed" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fopt-info-loop-missed" } */
> > > > > >  extern void g(void);
> > > > > >
> > > > > >  void
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > > > > index 9f9c61aa213..860cde12c0f 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-Os -fdump-tree-optimized" } */
> > > > > > +/* { dg-options "-Os -fno-tree-vectorize -fdump-tree-optimized" } */
> > > > > >
> > > > > >
> > > > > >  struct struct1
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > > > > index f216e83c7b3..c7ef73ad59e 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  void f (void*);
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > > > > index 7d6a724e4ad..0ddad573129 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> > > > > >
> > > > > >  void write64 (void *p)
> > > > > >  {
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > > > > index f68be2b3379..8c3d9a4fc58 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* { dg-do compile } */
> > > > > >  /* { dg-do run } */
> > > > > > -/* { dg-options "-O2 -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > > >
> > > > > >  void abort (void);
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > > > > index ec08d6c0318..1fc8f089345 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do run } */
> > > > > > -/* { dg-options "-O2 -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> > > > > >
> > > > > >  int arr1[105] = {2, 3, 5, 7, 11, 13, 0};
> > > > > >  int arr2[105] = {2, 3, 5, 7, 11, 13, 0};
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > > > > index 467903bf3fc..46f0d0c2317 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> > > > > > @@ -1,7 +1,7 @@
> > > > > >  /* Prefetching used to prefer nonsensical unroll factor of 5 in this testcase.  */
> > > > > >
> > > > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > > > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> > > > > >
> > > > > >  #define N 1000000
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > > > > index 12f09016943..3fa71685ace 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > > > -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> > > > > >
> > > > > >  #define N 1000
> > > > > >  #define K 900
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > > > > index cbd6a80d345..00f41c3e4f4 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > > > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > > >
> > > > > >  #define K 1000000
> > > > > >  int a[K];
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > > > > index da4847320b1..e8848c30acc 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> > > > > > -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> > > > > >
> > > > > >  #define K 1000000
> > > > > >  int a[K], b[K];
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > > > > index 92b2df80ec8..2e7b5b496ea 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > > > > >  int g(_Complex int*);
> > > > > >  int f(void)
> > > > > >  {
> > > > > > diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > > > > index 718b7466e50..7bb8d060631 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fdump-tree-optimized" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> > > > > >  int g(_Complex int*);
> > > > > >  int f(void)
> > > > > >  {
> > > > > > diff --git a/gcc/testsuite/gcc.dg/uninit-40.c b/gcc/testsuite/gcc.dg/uninit-40.c
> > > > > > index c015191ca32..8708079d397 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/uninit-40.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/uninit-40.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR tree-optimization/98597 */
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -Wuninitialized" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -Wuninitialized" } */
> > > > > >
> > > > > >  union U { double d; int i; float f; };
> > > > > >  struct S { char a; int b; char c; unsigned d; union U e; int f[3]; unsigned g[3]; };
> > > > > > diff --git a/gcc/testsuite/gcc.dg/unroll-7.c b/gcc/testsuite/gcc.dg/unroll-7.c
> > > > > > index 055369bf8b1..695af5757cc 100644
> > > > > > --- a/gcc/testsuite/gcc.dg/unroll-7.c
> > > > > > +++ b/gcc/testsuite/gcc.dg/unroll-7.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> > > > > >  /* { dg-require-effective-target int32plus } */
> > > > > >
> > > > > >  extern int *a;
> > > > > > diff --git a/gcc/testsuite/gcc.misc-tests/help.exp b/gcc/testsuite/gcc.misc-tests/help.exp
> > > > > > index 5e034d26947..eb6d8686c6a 100644
> > > > > > --- a/gcc/testsuite/gcc.misc-tests/help.exp
> > > > > > +++ b/gcc/testsuite/gcc.misc-tests/help.exp
> > > > > > @@ -79,7 +79,7 @@ check_for_options c "--help=target,optimizers" "" "" ""
> > > > > >  check_for_options c "--help=warnings,^joined,^undocumented" "" "" ""
> > > > > >  check_for_options c "-Q -O2 --help=optimizers" {
> > > > > >  -O
> > > > > > --ftree-loop-vectorize[^\n]*disabled
> > > > > > +-ftree-loop-vectorize[^\n]*enabled
> > > > > >  } "  -g  " ""
> > > > > >  check_for_options c "-Q -O3 --help=optimizers" {
> > > > > >  -O
> > > > > > diff --git a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > > > > index 709cd21e671..a732bc466db 100644
> > > > > > --- a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > > > > +++ b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do run } */
> > > > > > -/* { dg-options "-O2 -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> > > > > >  /* { dg-require-effective-target avx512vl } */
> > > > > >  /* { dg-require-effective-target avx512vpopcntdqvl } */
> > > > > >  /* { dg-require-effective-target avx512bw } */
> > > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr22141.c b/gcc/testsuite/gcc.target/i386/pr22141.c
> > > > > > index 036422e8ccf..b68b97f3f72 100644
> > > > > > --- a/gcc/testsuite/gcc.target/i386/pr22141.c
> > > > > > +++ b/gcc/testsuite/gcc.target/i386/pr22141.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR middle-end/22141 */
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-Os" } */
> > > > > > +/* { dg-options "-Os -fno-tree-vectorize" } */
> > > > > >
> > > > > >  extern void abort (void);
> > > > > >
> > > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr34012.c b/gcc/testsuite/gcc.target/i386/pr34012.c
> > > > > > index d0cffa05290..1c1f0eea52e 100644
> > > > > > --- a/gcc/testsuite/gcc.target/i386/pr34012.c
> > > > > > +++ b/gcc/testsuite/gcc.target/i386/pr34012.c
> > > > > > @@ -1,7 +1,7 @@
> > > > > >  /* PR rtl-optimization/34012 */
> > > > > >  /* { dg-do compile } */
> > > > > >  /* { dg-require-effective-target lp64 } */
> > > > > > -/* { dg-options "-O2 -fno-store-merging" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fno-store-merging" } */
> > > > > >
> > > > > >  void bar (long int *);
> > > > > >  void
> > > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr49781-1.c b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > > > > index 60f9d50d866..d5a2e32db97 100644
> > > > > > --- a/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > > > > +++ b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -fpic -mtune=generic" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -fpic -mtune=generic" } */
> > > > > >  /* { dg-require-effective-target fpic } */
> > > > > >
> > > > > >  static int heap[2*(256 +1+29)+1];
> > > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-1.c b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > > > > index 9a7e32d6f2f..526f48921fd 100644
> > > > > > --- a/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > > > > +++ b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR target/95798 */
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> > > > > >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > > >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > > >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > > > diff --git a/gcc/testsuite/gcc.target/i386/pr95798-2.c b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > > > > index c670d3780e8..6b5c5a73e96 100644
> > > > > > --- a/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > > > > +++ b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> > > > > > @@ -1,6 +1,6 @@
> > > > > >  /* PR target/95798 */
> > > > > >  /* { dg-do compile } */
> > > > > > -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> > > > > > +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> > > > > >  /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > > >  /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > > >  /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> > > > > > diff --git a/gcc/testsuite/gfortran.dg/pr77498.f b/gcc/testsuite/gfortran.dg/pr77498.f
> > > > > > index f957b57bb00..a0fc8275a84 100644
> > > > > > --- a/gcc/testsuite/gfortran.dg/pr77498.f
> > > > > > +++ b/gcc/testsuite/gfortran.dg/pr77498.f
> > > > > > @@ -1,5 +1,5 @@
> > > > > >  ! { dg-do compile }
> > > > > > -! { dg-options "-O2 -ffast-math -fdump-tree-pre" }
> > > > > > +! { dg-options "-O2 -fno-tree-vectorize -ffast-math -fdump-tree-pre" }
> > > > > >
> > > > > >        subroutine foo(U,V,R,N,A)
> > > > > >        integer N
> > > > > >
> > > > >
> > > > > --
> > > > > Richard Biener <rguenther@suse.de>
> > > > > SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> > > > > Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
> > > >
> > > >
> > > >
> > > >
> > >
> > > --
> > > Richard Biener <rguenther@suse.de>
> > > SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> > > Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
> >
> >
> >
> >
>
> --
> Richard Biener <rguenther@suse.de>
> SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
Martin Sebor Sept. 19, 2021, 8:13 p.m. UTC | #7
On 9/16/21 3:03 AM, Hongtao Liu via Gcc-patches wrote:
> On Thu, Sep 16, 2021 at 4:23 PM Richard Biener via Gcc-patches
> <gcc-patches@gcc.gnu.org> wrote:
>>
>> On Thu, 16 Sep 2021, liuhongt wrote:
>>
>>> Ping
>>> rebased on latest trunk.
>>>
>>> gcc/ChangeLog:
>>>
>>>        * common.opt (ftree-vectorize): Add Var(flag_tree_vectorize).
>>>        * doc/invoke.texi (Options That Control Optimization): Update
>>>        documents.
>>>        * opts.c (default_options_table): Enable auto-vectorization at
>>>        O2 with very-cheap cost model.
>>>        (finish_options): Use cheap cost model for
>>>        explicit -ftree{,-loop}-vectorize.
>>>
>>> gcc/testsuite/ChangeLog:
>>>
>>>        * c-c++-common/Wstringop-overflow-2.c: Adjust testcase.
>>>        * g++.dg/tree-ssa/pr81408.C: Ditto.
>>>        * g++.dg/warn/Wuninitialized-13.C: Ditto.
>>>        * gcc.dg/Warray-bounds-51.c: Ditto.
>>>        * gcc.dg/Warray-parameter-3.c: Ditto.
>>>        * gcc.dg/Wstringop-overflow-13.c: Ditto.
>>>        * gcc.dg/Wstringop-overflow-14.c: Ditto.
>>>        * gcc.dg/Wstringop-overflow-21.c: Ditto.
>>>        * gcc.dg/Wstringop-overflow-68.c: Ditto.
>>>        * gcc.dg/gomp/pr46032-2.c: Ditto.
>>>        * gcc.dg/gomp/pr46032-3.c: Ditto.
>>>        * gcc.dg/gomp/simd-2.c: Ditto.
>>>        * gcc.dg/gomp/simd-3.c: Ditto.
>>>        * gcc.dg/graphite/fuse-1.c: Ditto.
>>>        * gcc.dg/pr67089-6.c: Ditto.
>>>        * gcc.dg/pr82929-2.c: Ditto.
>>>        * gcc.dg/pr82929.c: Ditto.
>>>        * gcc.dg/store_merging_1.c: Ditto.
>>>        * gcc.dg/store_merging_11.c: Ditto.
>>>        * gcc.dg/store_merging_15.c: Ditto.
>>>        * gcc.dg/store_merging_16.c: Ditto.
>>>        * gcc.dg/store_merging_19.c: Ditto.
>>>        * gcc.dg/store_merging_24.c: Ditto.
>>>        * gcc.dg/store_merging_25.c: Ditto.
>>>        * gcc.dg/store_merging_28.c: Ditto.
>>>        * gcc.dg/store_merging_30.c: Ditto.
>>>        * gcc.dg/store_merging_5.c: Ditto.
>>>        * gcc.dg/store_merging_7.c: Ditto.
>>>        * gcc.dg/store_merging_8.c: Ditto.
>>>        * gcc.dg/strlenopt-85.c: Ditto.
>>>        * gcc.dg/tree-ssa/dump-6.c: Ditto.
>>>        * gcc.dg/tree-ssa/pr19210-1.c: Ditto.
>>>        * gcc.dg/tree-ssa/pr47059.c: Ditto.
>>>        * gcc.dg/tree-ssa/pr86017.c: Ditto.
>>>        * gcc.dg/tree-ssa/pr91482.c: Ditto.
>>>        * gcc.dg/tree-ssa/predcom-1.c: Ditto.
>>>        * gcc.dg/tree-ssa/predcom-dse-3.c: Ditto.
>>>        * gcc.dg/tree-ssa/prefetch-3.c: Ditto.
>>>        * gcc.dg/tree-ssa/prefetch-6.c: Ditto.
>>>        * gcc.dg/tree-ssa/prefetch-8.c: Ditto.
>>>        * gcc.dg/tree-ssa/prefetch-9.c: Ditto.
>>>        * gcc.dg/tree-ssa/ssa-dse-18.c: Ditto.
>>>        * gcc.dg/tree-ssa/ssa-dse-19.c: Ditto.
>>>        * gcc.dg/uninit-40.c: Ditto.
>>>        * gcc.dg/unroll-7.c: Ditto.
>>>        * gcc.misc-tests/help.exp: Ditto.
>>>        * gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c: Ditto.
>>>        * gcc.target/i386/pr22141.c: Ditto.
>>>        * gcc.target/i386/pr34012.c: Ditto.
>>>        * gcc.target/i386/pr49781-1.c: Ditto.
>>>        * gcc.target/i386/pr95798-1.c: Ditto.
>>>        * gcc.target/i386/pr95798-2.c: Ditto.
>>>        * gfortran.dg/pr77498.f: Ditto.
>>> ---
>>>   gcc/common.opt                                 |  2 +-
>>>   gcc/doc/invoke.texi                            |  8 +++++---
>>>   gcc/opts.c                                     | 18 +++++++++++++++---
>>>   .../c-c++-common/Wstringop-overflow-2.c        |  2 +-
>>>   gcc/testsuite/g++.dg/tree-ssa/pr81408.C        |  2 +-
>>>   gcc/testsuite/g++.dg/warn/Wuninitialized-13.C  |  2 +-
>>>   gcc/testsuite/gcc.dg/Warray-bounds-51.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/Warray-parameter-3.c      |  2 +-
>>>   gcc/testsuite/gcc.dg/Wstringop-overflow-13.c   |  2 +-
>>>   gcc/testsuite/gcc.dg/Wstringop-overflow-14.c   |  2 +-
>>>   gcc/testsuite/gcc.dg/Wstringop-overflow-21.c   |  2 +-
>>>   gcc/testsuite/gcc.dg/Wstringop-overflow-68.c   |  2 +-
>>>   gcc/testsuite/gcc.dg/gomp/pr46032-2.c          |  2 +-
>>>   gcc/testsuite/gcc.dg/gomp/pr46032-3.c          |  2 +-
>>>   gcc/testsuite/gcc.dg/gomp/simd-2.c             |  2 +-
>>>   gcc/testsuite/gcc.dg/gomp/simd-3.c             |  2 +-
>>>   gcc/testsuite/gcc.dg/graphite/fuse-1.c         |  2 +-
>>>   gcc/testsuite/gcc.dg/pr67089-6.c               |  2 +-
>>>   gcc/testsuite/gcc.dg/pr82929-2.c               |  2 +-
>>>   gcc/testsuite/gcc.dg/pr82929.c                 |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_1.c         |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_11.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_15.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_16.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_19.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_24.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_25.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_28.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_30.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_5.c         |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_7.c         |  2 +-
>>>   gcc/testsuite/gcc.dg/store_merging_8.c         |  2 +-
>>>   gcc/testsuite/gcc.dg/strlenopt-85.c            |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/dump-6.c         |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c      |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/pr47059.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/pr86017.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/pr91482.c        |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c      |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c  |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c     |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c     |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c     |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c     |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c     |  2 +-
>>>   gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c     |  2 +-
>>>   gcc/testsuite/gcc.dg/uninit-40.c               |  2 +-
>>>   gcc/testsuite/gcc.dg/unroll-7.c                |  2 +-
>>>   gcc/testsuite/gcc.misc-tests/help.exp          |  2 +-
>>>   .../i386/avx512vpopcntdqvl-vpopcntd-1.c        |  2 +-
>>>   gcc/testsuite/gcc.target/i386/pr22141.c        |  2 +-
>>>   gcc/testsuite/gcc.target/i386/pr34012.c        |  2 +-
>>>   gcc/testsuite/gcc.target/i386/pr49781-1.c      |  2 +-
>>>   gcc/testsuite/gcc.target/i386/pr95798-1.c      |  2 +-
>>>   gcc/testsuite/gcc.target/i386/pr95798-2.c      |  2 +-
>>>   gcc/testsuite/gfortran.dg/pr77498.f            |  2 +-
>>>   56 files changed, 74 insertions(+), 60 deletions(-)
>>>
>>> diff --git a/gcc/common.opt b/gcc/common.opt
>>> index b921f5e3b25..4f2c0294c29 100644
>>> --- a/gcc/common.opt
>>> +++ b/gcc/common.opt
>>> @@ -3031,7 +3031,7 @@ Perform variable tracking and also tag variables that are uninitialized.
>>>
>>>   ; Alias to enable both -ftree-loop-vectorize and -ftree-slp-vectorize.
>>>   ftree-vectorize
>>> -Common Optimization
>>> +Common Var(flag_tree_vectorize) Optimization
>>>   Enable vectorization on trees.
>>>
>>>   ftree-vectorizer-verbose=
>>> diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
>>> index 78cfc100ac2..be022ef8024 100644
>>> --- a/gcc/doc/invoke.texi
>>> +++ b/gcc/doc/invoke.texi
>>> @@ -10409,9 +10409,13 @@ also turns on the following optimization flags:
>>>   -fstrict-aliasing @gol
>>>   -fthread-jumps @gol
>>>   -ftree-builtin-call-dce @gol
>>> +-ftree-loop-vectorize @gol
>>>   -ftree-pre @gol
>>> +-ftree-slp-vectorize @gol
>>>   -ftree-switch-conversion  -ftree-tail-merge @gol
>>> --ftree-vrp}
>>> +-ftree-vrp @gol
>>> +-fvect-cost-model @gol
>>
>> the above is redundant
>>
>>> +-fvect-cost-model=very-cheap}
>>>
>>>   Please note the warning under @option{-fgcse} about
>>>   invoking @option{-O2} on programs that use computed gotos.
>>> @@ -10431,9 +10435,7 @@ by @option{-O2} and also turns on the following optimization flags:
>>>   -fsplit-loops @gol
>>>   -fsplit-paths @gol
>>>   -ftree-loop-distribution @gol
>>> --ftree-loop-vectorize @gol
>>>   -ftree-partial-pre @gol
>>> --ftree-slp-vectorize @gol
>>>   -funswitch-loops @gol
>>>   -fvect-cost-model @gol
>>
>> likewise - so just remove it here as you are around
>>
>>>   -fvect-cost-model=dynamic @gol
>>> diff --git a/gcc/opts.c b/gcc/opts.c
>>> index 1d2d22d7a3f..cee372a3235 100644
>>> --- a/gcc/opts.c
>>> +++ b/gcc/opts.c
>>> @@ -634,7 +634,8 @@ static const struct default_options default_options_table[] =
>>>       { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
>>>       { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
>>>       { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
>>> -    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
>>> +    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL,
>>> +      VECT_COST_MODEL_VERY_CHEAP },
>>>       { OPT_LEVELS_2_PLUS, OPT_finline_functions, NULL, 1 },
>>>       { OPT_LEVELS_2_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
>>>
>>> @@ -646,6 +647,9 @@ static const struct default_options default_options_table[] =
>>>       { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
>>>       { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
>>>         REORDER_BLOCKS_ALGORITHM_STC },
>>> +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_loop_vectorize, NULL, 1 },
>>> +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_slp_vectorize, NULL, 1 },
>>> +
>>>   #ifdef INSN_SCHEDULING
>>>     /* Only run the pre-regalloc scheduling pass if optimizing for speed.  */
>>>       { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
>>> @@ -663,9 +667,7 @@ static const struct default_options default_options_table[] =
>>>       { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
>>>       { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
>>>       { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
>>> -    { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
>>>       { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
>>> -    { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
>>>       { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
>>>       { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
>>>       { OPT_LEVELS_3_PLUS, OPT_fversion_loops_for_strides, NULL, 1 },
>>> @@ -1331,6 +1333,16 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
>>>         = (opts->x_flag_unroll_loops
>>>            || opts->x_flag_peel_loops
>>>            || opts->x_optimize >= 3);
>>> +
>>> +  /* Use -fvect-cost-model=cheap instead of -fvect-cost-mode=very-cheap
>>> +     by default with explicit -ftree-{loop,slp}-vectorize.  */
>>> +  if (opts->x_optimize == 2
>>> +      && (opts_set->x_flag_tree_loop_vectorize
>>> +       || opts_set->x_flag_tree_vectorize))
>>> +    SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
>>> +                      VECT_COST_MODEL_CHEAP);
>>> +
>>> +
>>
>> please avoid adding excessive vertical space at the end of the function
>>
>>>   }
>>>
>>>   #define LEFT_COLUMN  27
>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>> index 1d79930cd58..9351f7e7a1a 100644
>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>> @@ -1,7 +1,7 @@
>>>   /* PR middle-end/91458 - inconsistent warning for writing past the end
>>>      of an array member
>>>      { dg-do compile }
>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
>>
>> The testcase is large - what part requires this change?  Given the
>> testcase was added for inconsistent warnings do they now become
>> inconsistent again as we enable vectorization at -O2?
>>
>> That said, the testcase adjustments need some explaining - I suppose
>> you didn't just slap -fno-tree-vectorize to all of those changing
>> behavior?
>>
> void ga1_ (void)
> {
>    a1_.a[0] = 0;
>    a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
>    a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> 
>    struct A1 a;
>    a.a[0] = 0;
>    a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
>    a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
>    sink (&a);
> }
> 
> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> there are 2 accesses, but after enabling vectorization, there's only
> one access, so one warning is missing which causes the failure.

I would find it preferable to change the test code over disabling
optimizations that are on by default.  My concern is that the test
would no longer exercise the default behavior.  (The same goes for
the -fno-ipa-icf option.)

Thanks
Martin

> 
>     <bb 2> [local count: 1073741824]:
>    a1__.a[0] = 0;
>    a1__.a[1] = 1;
>    a1__.a[2] = 2;
>    MEM <char[1]> [(struct A1 *)&a + 1B] = {};
>    a.n = 1;
>    MEM <vector(2) char> [(char *)&a + 2B] = { 1, 2 };
>    sink (&a);
>    a ={v} {CLOBBER};
>    return;
> 
> 
>> Thanks,
>> Richard.
>>
>>>   void sink (void*);
>>>
>>> diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
>>> index 39e32fd4bc9..bc14309480c 100644
>>> --- a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
>>> +++ b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed" } */
>>> +/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed -fno-tree-vectorize" } */
>>>   struct p
>>>   {
>>>     char *ay;
>>> diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
>>> index 49ee878806a..60e8dd4f0e2 100644
>>> --- a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
>>> +++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
>>> @@ -1,6 +1,6 @@
>>>   /* PR c/98597 - ICE in -Wuninitialized printing a MEM_REF
>>>      { dg-do compile }
>>> -   { dg-options "-O2 -Wall" } */
>>> +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
>>>
>>>   struct shared_count {
>>>     shared_count () { }
>>> diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-51.c b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
>>> index 6028b11637c..8b81a0ccfa7 100644
>>> --- a/gcc/testsuite/gcc.dg/Warray-bounds-51.c
>>> +++ b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
>>> @@ -1,7 +1,7 @@
>>>   /* PR middle-end/92333 - missing variable name referencing VLA in warnings
>>>      PR middle-end/82608 - missing -Warray-bounds on an out-of-bounds VLA index
>>>      { dg-do compile }
>>> -   { dg-options "-O2 -Wall" } */
>>> +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
>>>
>>>   void sink (void*);
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/Warray-parameter-3.c b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
>>> index cbf3e9339f5..fbef715aa99 100644
>>> --- a/gcc/testsuite/gcc.dg/Warray-parameter-3.c
>>> +++ b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
>>> @@ -59,7 +59,7 @@ void fas1 (int[static 2]);    // { dg-warning "\\\[-Warray-parameter=" }
>>>
>>>   /* Also verify that -Warray-bounds doesn't trigger for ordinary array
>>>      parameters...  */
>>> -#pragma GCC optimize "2"
>>> +#pragma GCC optimize ("2,-fno-tree-vectorize")
>>>
>>>   __attribute__ ((noipa)) void
>>>   gca3 (char a[3])
>>> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
>>> index bd513151cea..a78242bf26e 100644
>>> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
>>> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
>>> @@ -3,7 +3,7 @@
>>>      PR middle-end/89911 - ICE on a call with no arguments to strnlen
>>>      declared with no prototype
>>>      { dg-do compile }
>>> -   { dg-options "-O2 -Wall" } */
>>> +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
>>>
>>>   typedef __SIZE_TYPE__ size_t;
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
>>> index d6201b068b6..808bf87c386 100644
>>> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
>>> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
>>> @@ -2,7 +2,7 @@
>>>      types than char are diagnosed.
>>>      { dg-do compile }
>>>      { dg-require-effective-target int32plus }
>>> -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
>>> +   { dg-options "-O2 -fno-tree-vectorize -Wall -Wno-array-bounds" } */
>>>
>>>   typedef __INT16_TYPE__  int16_t;
>>>   typedef __INT32_TYPE__  int32_t;
>>> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
>>> index 3a27460220c..f418a17ca93 100644
>>> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
>>> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
>>> @@ -1,7 +1,7 @@
>>>   /* PR middle-end/92312 - bogus -Wstringop-overflow storing into a trailing
>>>      array backed by larger buffer
>>>      { dg-do compile }
>>> -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-tree-vectorize" } */
>>>
>>>   struct S0 { char a, b[0]; };
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
>>> index 6bcba274541..7cc1012130c 100644
>>> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
>>> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
>>> @@ -2,7 +2,7 @@
>>>      a larger scalar into a smaller array
>>>      Verify overflow by aggregate stores.
>>>      { dg-do compile }
>>> -   { dg-options "-O2" } */
>>> +   { dg-options "-O2 -fno-tree-vectorize" } */
>>>
>>>   #define A(N) (A ## N)
>>>   #define Ac1 (AC1){ 0 }
>>> diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
>>> index e110880bd8e..2e562618489 100644
>>> --- a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
>>> +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
>>>
>>>   #define N 2
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
>>> index a4af7ec4a8a..da1ab487385 100644
>>> --- a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
>>> +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
>>>
>>>   #define N 2
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/gomp/simd-2.c b/gcc/testsuite/gcc.dg/gomp/simd-2.c
>>> index 85acb980f10..f4912127b81 100644
>>> --- a/gcc/testsuite/gcc.dg/gomp/simd-2.c
>>> +++ b/gcc/testsuite/gcc.dg/gomp/simd-2.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
>>> +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
>>>   /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
>>>   /* { dg-additional-options "-mavx" { target avx } } */
>>>   /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
>>> diff --git a/gcc/testsuite/gcc.dg/gomp/simd-3.c b/gcc/testsuite/gcc.dg/gomp/simd-3.c
>>> index 86fee858673..c75060c07ae 100644
>>> --- a/gcc/testsuite/gcc.dg/gomp/simd-3.c
>>> +++ b/gcc/testsuite/gcc.dg/gomp/simd-3.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
>>> +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
>>>   /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
>>>   /* { dg-additional-options "-mavx" { target avx } } */
>>>   /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
>>> diff --git a/gcc/testsuite/gcc.dg/graphite/fuse-1.c b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
>>> index 527b6e5c415..61289d312c2 100644
>>> --- a/gcc/testsuite/gcc.dg/graphite/fuse-1.c
>>> +++ b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
>>> @@ -1,6 +1,6 @@
>>>   /* Check that the two loops are fused and that we manage to fold the two xor
>>>      operations.  */
>>> -/* { dg-options "-O2 -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
>>>
>>>   /* Make sure we fuse the loops like this:
>>>   AST generated by isl:
>>> diff --git a/gcc/testsuite/gcc.dg/pr67089-6.c b/gcc/testsuite/gcc.dg/pr67089-6.c
>>> index db2ffdfeca4..b59d75b2318 100644
>>> --- a/gcc/testsuite/gcc.dg/pr67089-6.c
>>> +++ b/gcc/testsuite/gcc.dg/pr67089-6.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR target/67089 */
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -ftree-loop-if-convert -fdump-tree-widening_mul" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -ftree-loop-if-convert -fdump-tree-widening_mul" } */
>>>
>>>   extern void abort (void);
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/pr82929-2.c b/gcc/testsuite/gcc.dg/pr82929-2.c
>>> index 3442f91af02..b886f1cce76 100644
>>> --- a/gcc/testsuite/gcc.dg/pr82929-2.c
>>> +++ b/gcc/testsuite/gcc.dg/pr82929-2.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR tree-optimization/82929 */
>>>   /* { dg-do compile { target store_merge } } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   void
>>>   foo (short *p, short *q, short *r)
>>> diff --git a/gcc/testsuite/gcc.dg/pr82929.c b/gcc/testsuite/gcc.dg/pr82929.c
>>> index bb84f2b21a3..123e1919cec 100644
>>> --- a/gcc/testsuite/gcc.dg/pr82929.c
>>> +++ b/gcc/testsuite/gcc.dg/pr82929.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR tree-optimization/82929 */
>>>   /* { dg-do compile { target store_merge } } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   void
>>>   foo (short *p, short *q, short *r)
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_1.c b/gcc/testsuite/gcc.dg/store_merging_1.c
>>> index 4cc43dfd9e1..91ca925be0e 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_1.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_1.c
>>> @@ -1,6 +1,6 @@
>>>   /* { dg-do compile } */
>>>   /* { dg-require-effective-target store_merge } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   struct bar {
>>>     int a;
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_11.c b/gcc/testsuite/gcc.dg/store_merging_11.c
>>> index 2ec2394afb9..60ed5cd8bf9 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_11.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_11.c
>>> @@ -1,6 +1,6 @@
>>>   /* { dg-do run } */
>>>   /* { dg-require-effective-target store_merge } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   struct S { unsigned char b[2]; unsigned short c; unsigned char d[4]; unsigned long e; };
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_15.c b/gcc/testsuite/gcc.dg/store_merging_15.c
>>> index acd7de571f8..13fcca4aa11 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_15.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_15.c
>>> @@ -1,6 +1,6 @@
>>>   /* { dg-do run } */
>>>   /* { dg-require-effective-target store_merge } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   struct S { unsigned char a, b; unsigned short c; unsigned char d, e, f, g; unsigned long long h; };
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_16.c b/gcc/testsuite/gcc.dg/store_merging_16.c
>>> index 9545dcce3de..cd83f1c0fe5 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_16.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_16.c
>>> @@ -2,7 +2,7 @@
>>>      are either big or little endian (not pdp endian).  */
>>>   /* { dg-do run { target { lp64 && { i?86-*-* x86_64-*-* powerpc*-*-* aarch64*-*-* } } } } */
>>>   /* { dg-require-effective-target store_merge } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   __attribute__((noipa)) void
>>>   f1 (unsigned char *p, unsigned long long q)
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_19.c b/gcc/testsuite/gcc.dg/store_merging_19.c
>>> index 0841bb4deee..0a2bbc4bfde 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_19.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_19.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR tree-optimization/83843 */
>>>   /* { dg-do run } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>   /* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" { target store_merge } } } */
>>>
>>>   __attribute__((noipa)) void
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_24.c b/gcc/testsuite/gcc.dg/store_merging_24.c
>>> index 744fe60e8e0..5291bb9e986 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_24.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_24.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR tree-optimization/87859 */
>>>   /* { dg-do run } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
>>>   /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 19 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
>>>   /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_25.c b/gcc/testsuite/gcc.dg/store_merging_25.c
>>> index cf182190e91..96611b5e57b 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_25.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_25.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR tree-optimization/87859 */
>>>   /* { dg-do run } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
>>>   /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 14 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
>>>   /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_28.c b/gcc/testsuite/gcc.dg/store_merging_28.c
>>> index 2d6cffc4694..fadb7fff993 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_28.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_28.c
>>> @@ -1,7 +1,7 @@
>>>   /* PR tree-optimization/88709 */
>>>   /* { dg-do compile } */
>>>   /* { dg-require-effective-target store_merge } */
>>> -/* { dg-options "-O2 -fno-ipa-icf -fdump-tree-store-merging-details" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-ipa-icf -fdump-tree-store-merging-details" } */
>>>   /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 16 stores" 8 "store-merging" { target { i?86-*-* x86_64-*-* } } } } */
>>>   /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 6 stores" 1 "store-merging" { target { ! arm*-*-* } } } } */
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_30.c b/gcc/testsuite/gcc.dg/store_merging_30.c
>>> index 694d560a621..baf94efe733 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_30.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_30.c
>>> @@ -1,7 +1,7 @@
>>>   /* PR tree-optimization/94573 */
>>>   /* { dg-do compile } */
>>>   /* { dg-require-effective-target store_merge } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
>>>   /* { dg-final { scan-tree-dump "New sequence of 4 stores to replace old one of 8 stores" "store-merging" { target lp64 } } } */
>>>
>>>   int var[43][12];
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_5.c b/gcc/testsuite/gcc.dg/store_merging_5.c
>>> index 6e7c72510ff..b0cb0da78e0 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_5.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_5.c
>>> @@ -1,6 +1,6 @@
>>>   /* { dg-do compile } */
>>>   /* { dg-require-effective-target store_merge } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   /* Make sure that non-aliasing non-constant interspersed stores do not
>>>      stop chains.  */
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_7.c b/gcc/testsuite/gcc.dg/store_merging_7.c
>>> index c744ece6407..dbe000a463e 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_7.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_7.c
>>> @@ -1,6 +1,6 @@
>>>   /* { dg-do compile } */
>>>   /* { dg-require-effective-target store_merge } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   /* Check that we can merge consecutive array members through the pointer.
>>>      PR rtl-optimization/23684.  */
>>> diff --git a/gcc/testsuite/gcc.dg/store_merging_8.c b/gcc/testsuite/gcc.dg/store_merging_8.c
>>> index e710a544ff0..d719e0a2257 100644
>>> --- a/gcc/testsuite/gcc.dg/store_merging_8.c
>>> +++ b/gcc/testsuite/gcc.dg/store_merging_8.c
>>> @@ -1,6 +1,6 @@
>>>   /* { dg-do compile } */
>>>   /* { dg-require-effective-target store_merge } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   struct baz {
>>>     struct bar {
>>> diff --git a/gcc/testsuite/gcc.dg/strlenopt-85.c b/gcc/testsuite/gcc.dg/strlenopt-85.c
>>> index e049e0c30e0..2ba1ee05700 100644
>>> --- a/gcc/testsuite/gcc.dg/strlenopt-85.c
>>> +++ b/gcc/testsuite/gcc.dg/strlenopt-85.c
>>> @@ -4,7 +4,7 @@
>>>      of memory allocated by calloc() even if one or more nul bytes are
>>>      written into it.
>>>      { dg-do compile }
>>> -   { dg-options "-O2 -fdump-tree-optimized" } */
>>> +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
>>>
>>>   unsigned n0, n1;
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
>>> index 70659c00c0e..6c803908781 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR middle-end/90676 - default GIMPLE dumps lack information
>>>      { dg-do compile }
>>> -   { dg-options "-O2 -fdump-tree-store-merging" }
>>> +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" }
>>>      { dg-require-effective-target int32plus }
>>>      { dg-require-effective-target store_merge } */
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
>>> index 50d86a00485..b9e40e964c1 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fopt-info-loop-missed" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fopt-info-loop-missed" } */
>>>   extern void g(void);
>>>
>>>   void
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
>>> index 9f9c61aa213..860cde12c0f 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-Os -fdump-tree-optimized" } */
>>> +/* { dg-options "-Os -fno-tree-vectorize -fdump-tree-optimized" } */
>>>
>>>
>>>   struct struct1
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
>>> index f216e83c7b3..c7ef73ad59e 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
>>>
>>>   void f (void*);
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
>>> index 7d6a724e4ad..0ddad573129 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fdump-tree-ccp1 -fdump-tree-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-ccp1 -fdump-tree-store-merging" } */
>>>
>>>   void write64 (void *p)
>>>   {
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
>>> index f68be2b3379..8c3d9a4fc58 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
>>> @@ -1,6 +1,6 @@
>>>   /* { dg-do compile } */
>>>   /* { dg-do run } */
>>> -/* { dg-options "-O2 -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
>>>
>>>   void abort (void);
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
>>> index ec08d6c0318..1fc8f089345 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do run } */
>>> -/* { dg-options "-O2 -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
>>>
>>>   int arr1[105] = {2, 3, 5, 7, 11, 13, 0};
>>>   int arr2[105] = {2, 3, 5, 7, 11, 13, 0};
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
>>> index 467903bf3fc..46f0d0c2317 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
>>> @@ -1,7 +1,7 @@
>>>   /* Prefetching used to prefer nonsensical unroll factor of 5 in this testcase.  */
>>>
>>>   /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
>>> -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
>>>
>>>   #define N 1000000
>>>
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
>>> index 12f09016943..3fa71685ace 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
>>> -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
>>>
>>>   #define N 1000
>>>   #define K 900
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
>>> index cbd6a80d345..00f41c3e4f4 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
>>> -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
>>>
>>>   #define K 1000000
>>>   int a[K];
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
>>> index da4847320b1..e8848c30acc 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
>>> -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
>>>
>>>   #define K 1000000
>>>   int a[K], b[K];
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
>>> index 92b2df80ec8..2e7b5b496ea 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fdump-tree-optimized" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
>>>   int g(_Complex int*);
>>>   int f(void)
>>>   {
>>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
>>> index 718b7466e50..7bb8d060631 100644
>>> --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
>>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fdump-tree-optimized" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
>>>   int g(_Complex int*);
>>>   int f(void)
>>>   {
>>> diff --git a/gcc/testsuite/gcc.dg/uninit-40.c b/gcc/testsuite/gcc.dg/uninit-40.c
>>> index c015191ca32..8708079d397 100644
>>> --- a/gcc/testsuite/gcc.dg/uninit-40.c
>>> +++ b/gcc/testsuite/gcc.dg/uninit-40.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR tree-optimization/98597 */
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -Wuninitialized" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -Wuninitialized" } */
>>>
>>>   union U { double d; int i; float f; };
>>>   struct S { char a; int b; char c; unsigned d; union U e; int f[3]; unsigned g[3]; };
>>> diff --git a/gcc/testsuite/gcc.dg/unroll-7.c b/gcc/testsuite/gcc.dg/unroll-7.c
>>> index 055369bf8b1..695af5757cc 100644
>>> --- a/gcc/testsuite/gcc.dg/unroll-7.c
>>> +++ b/gcc/testsuite/gcc.dg/unroll-7.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fdump-rtl-loop2_unroll-details -funroll-loops" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-rtl-loop2_unroll-details -funroll-loops" } */
>>>   /* { dg-require-effective-target int32plus } */
>>>
>>>   extern int *a;
>>> diff --git a/gcc/testsuite/gcc.misc-tests/help.exp b/gcc/testsuite/gcc.misc-tests/help.exp
>>> index 5e034d26947..eb6d8686c6a 100644
>>> --- a/gcc/testsuite/gcc.misc-tests/help.exp
>>> +++ b/gcc/testsuite/gcc.misc-tests/help.exp
>>> @@ -79,7 +79,7 @@ check_for_options c "--help=target,optimizers" "" "" ""
>>>   check_for_options c "--help=warnings,^joined,^undocumented" "" "" ""
>>>   check_for_options c "-Q -O2 --help=optimizers" {
>>>   -O
>>> --ftree-loop-vectorize[^\n]*disabled
>>> +-ftree-loop-vectorize[^\n]*enabled
>>>   } "  -g  " ""
>>>   check_for_options c "-Q -O3 --help=optimizers" {
>>>   -O
>>> diff --git a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
>>> index 709cd21e671..a732bc466db 100644
>>> --- a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
>>> +++ b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do run } */
>>> -/* { dg-options "-O2 -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
>>>   /* { dg-require-effective-target avx512vl } */
>>>   /* { dg-require-effective-target avx512vpopcntdqvl } */
>>>   /* { dg-require-effective-target avx512bw } */
>>> diff --git a/gcc/testsuite/gcc.target/i386/pr22141.c b/gcc/testsuite/gcc.target/i386/pr22141.c
>>> index 036422e8ccf..b68b97f3f72 100644
>>> --- a/gcc/testsuite/gcc.target/i386/pr22141.c
>>> +++ b/gcc/testsuite/gcc.target/i386/pr22141.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR middle-end/22141 */
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-Os" } */
>>> +/* { dg-options "-Os -fno-tree-vectorize" } */
>>>
>>>   extern void abort (void);
>>>
>>> diff --git a/gcc/testsuite/gcc.target/i386/pr34012.c b/gcc/testsuite/gcc.target/i386/pr34012.c
>>> index d0cffa05290..1c1f0eea52e 100644
>>> --- a/gcc/testsuite/gcc.target/i386/pr34012.c
>>> +++ b/gcc/testsuite/gcc.target/i386/pr34012.c
>>> @@ -1,7 +1,7 @@
>>>   /* PR rtl-optimization/34012 */
>>>   /* { dg-do compile } */
>>>   /* { dg-require-effective-target lp64 } */
>>> -/* { dg-options "-O2 -fno-store-merging" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-store-merging" } */
>>>
>>>   void bar (long int *);
>>>   void
>>> diff --git a/gcc/testsuite/gcc.target/i386/pr49781-1.c b/gcc/testsuite/gcc.target/i386/pr49781-1.c
>>> index 60f9d50d866..d5a2e32db97 100644
>>> --- a/gcc/testsuite/gcc.target/i386/pr49781-1.c
>>> +++ b/gcc/testsuite/gcc.target/i386/pr49781-1.c
>>> @@ -1,5 +1,5 @@
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -fpic -mtune=generic" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -fpic -mtune=generic" } */
>>>   /* { dg-require-effective-target fpic } */
>>>
>>>   static int heap[2*(256 +1+29)+1];
>>> diff --git a/gcc/testsuite/gcc.target/i386/pr95798-1.c b/gcc/testsuite/gcc.target/i386/pr95798-1.c
>>> index 9a7e32d6f2f..526f48921fd 100644
>>> --- a/gcc/testsuite/gcc.target/i386/pr95798-1.c
>>> +++ b/gcc/testsuite/gcc.target/i386/pr95798-1.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR target/95798 */
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
>>>   /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>>>   /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>>>   /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>>> diff --git a/gcc/testsuite/gcc.target/i386/pr95798-2.c b/gcc/testsuite/gcc.target/i386/pr95798-2.c
>>> index c670d3780e8..6b5c5a73e96 100644
>>> --- a/gcc/testsuite/gcc.target/i386/pr95798-2.c
>>> +++ b/gcc/testsuite/gcc.target/i386/pr95798-2.c
>>> @@ -1,6 +1,6 @@
>>>   /* PR target/95798 */
>>>   /* { dg-do compile } */
>>> -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
>>> +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
>>>   /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>>>   /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>>>   /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
>>> diff --git a/gcc/testsuite/gfortran.dg/pr77498.f b/gcc/testsuite/gfortran.dg/pr77498.f
>>> index f957b57bb00..a0fc8275a84 100644
>>> --- a/gcc/testsuite/gfortran.dg/pr77498.f
>>> +++ b/gcc/testsuite/gfortran.dg/pr77498.f
>>> @@ -1,5 +1,5 @@
>>>   ! { dg-do compile }
>>> -! { dg-options "-O2 -ffast-math -fdump-tree-pre" }
>>> +! { dg-options "-O2 -fno-tree-vectorize -ffast-math -fdump-tree-pre" }
>>>
>>>         subroutine foo(U,V,R,N,A)
>>>         integer N
>>>
>>
>> --
>> Richard Biener <rguenther@suse.de>
>> SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
>> Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
> 
> 
>
Hongtao Liu Sept. 22, 2021, 1:38 a.m. UTC | #8
On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
>
> On 9/16/21 3:03 AM, Hongtao Liu via Gcc-patches wrote:
> > On Thu, Sep 16, 2021 at 4:23 PM Richard Biener via Gcc-patches
> > <gcc-patches@gcc.gnu.org> wrote:
> >>
> >> On Thu, 16 Sep 2021, liuhongt wrote:
> >>
> >>> Ping
> >>> rebased on latest trunk.
> >>>
> >>> gcc/ChangeLog:
> >>>
> >>>        * common.opt (ftree-vectorize): Add Var(flag_tree_vectorize).
> >>>        * doc/invoke.texi (Options That Control Optimization): Update
> >>>        documents.
> >>>        * opts.c (default_options_table): Enable auto-vectorization at
> >>>        O2 with very-cheap cost model.
> >>>        (finish_options): Use cheap cost model for
> >>>        explicit -ftree{,-loop}-vectorize.
> >>>
> >>> gcc/testsuite/ChangeLog:
> >>>
> >>>        * c-c++-common/Wstringop-overflow-2.c: Adjust testcase.
> >>>        * g++.dg/tree-ssa/pr81408.C: Ditto.
> >>>        * g++.dg/warn/Wuninitialized-13.C: Ditto.
> >>>        * gcc.dg/Warray-bounds-51.c: Ditto.
> >>>        * gcc.dg/Warray-parameter-3.c: Ditto.
> >>>        * gcc.dg/Wstringop-overflow-13.c: Ditto.
> >>>        * gcc.dg/Wstringop-overflow-14.c: Ditto.
> >>>        * gcc.dg/Wstringop-overflow-21.c: Ditto.
> >>>        * gcc.dg/Wstringop-overflow-68.c: Ditto.
> >>>        * gcc.dg/gomp/pr46032-2.c: Ditto.
> >>>        * gcc.dg/gomp/pr46032-3.c: Ditto.
> >>>        * gcc.dg/gomp/simd-2.c: Ditto.
> >>>        * gcc.dg/gomp/simd-3.c: Ditto.
> >>>        * gcc.dg/graphite/fuse-1.c: Ditto.
> >>>        * gcc.dg/pr67089-6.c: Ditto.
> >>>        * gcc.dg/pr82929-2.c: Ditto.
> >>>        * gcc.dg/pr82929.c: Ditto.
> >>>        * gcc.dg/store_merging_1.c: Ditto.
> >>>        * gcc.dg/store_merging_11.c: Ditto.
> >>>        * gcc.dg/store_merging_15.c: Ditto.
> >>>        * gcc.dg/store_merging_16.c: Ditto.
> >>>        * gcc.dg/store_merging_19.c: Ditto.
> >>>        * gcc.dg/store_merging_24.c: Ditto.
> >>>        * gcc.dg/store_merging_25.c: Ditto.
> >>>        * gcc.dg/store_merging_28.c: Ditto.
> >>>        * gcc.dg/store_merging_30.c: Ditto.
> >>>        * gcc.dg/store_merging_5.c: Ditto.
> >>>        * gcc.dg/store_merging_7.c: Ditto.
> >>>        * gcc.dg/store_merging_8.c: Ditto.
> >>>        * gcc.dg/strlenopt-85.c: Ditto.
> >>>        * gcc.dg/tree-ssa/dump-6.c: Ditto.
> >>>        * gcc.dg/tree-ssa/pr19210-1.c: Ditto.
> >>>        * gcc.dg/tree-ssa/pr47059.c: Ditto.
> >>>        * gcc.dg/tree-ssa/pr86017.c: Ditto.
> >>>        * gcc.dg/tree-ssa/pr91482.c: Ditto.
> >>>        * gcc.dg/tree-ssa/predcom-1.c: Ditto.
> >>>        * gcc.dg/tree-ssa/predcom-dse-3.c: Ditto.
> >>>        * gcc.dg/tree-ssa/prefetch-3.c: Ditto.
> >>>        * gcc.dg/tree-ssa/prefetch-6.c: Ditto.
> >>>        * gcc.dg/tree-ssa/prefetch-8.c: Ditto.
> >>>        * gcc.dg/tree-ssa/prefetch-9.c: Ditto.
> >>>        * gcc.dg/tree-ssa/ssa-dse-18.c: Ditto.
> >>>        * gcc.dg/tree-ssa/ssa-dse-19.c: Ditto.
> >>>        * gcc.dg/uninit-40.c: Ditto.
> >>>        * gcc.dg/unroll-7.c: Ditto.
> >>>        * gcc.misc-tests/help.exp: Ditto.
> >>>        * gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c: Ditto.
> >>>        * gcc.target/i386/pr22141.c: Ditto.
> >>>        * gcc.target/i386/pr34012.c: Ditto.
> >>>        * gcc.target/i386/pr49781-1.c: Ditto.
> >>>        * gcc.target/i386/pr95798-1.c: Ditto.
> >>>        * gcc.target/i386/pr95798-2.c: Ditto.
> >>>        * gfortran.dg/pr77498.f: Ditto.
> >>> ---
> >>>   gcc/common.opt                                 |  2 +-
> >>>   gcc/doc/invoke.texi                            |  8 +++++---
> >>>   gcc/opts.c                                     | 18 +++++++++++++++---
> >>>   .../c-c++-common/Wstringop-overflow-2.c        |  2 +-
> >>>   gcc/testsuite/g++.dg/tree-ssa/pr81408.C        |  2 +-
> >>>   gcc/testsuite/g++.dg/warn/Wuninitialized-13.C  |  2 +-
> >>>   gcc/testsuite/gcc.dg/Warray-bounds-51.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/Warray-parameter-3.c      |  2 +-
> >>>   gcc/testsuite/gcc.dg/Wstringop-overflow-13.c   |  2 +-
> >>>   gcc/testsuite/gcc.dg/Wstringop-overflow-14.c   |  2 +-
> >>>   gcc/testsuite/gcc.dg/Wstringop-overflow-21.c   |  2 +-
> >>>   gcc/testsuite/gcc.dg/Wstringop-overflow-68.c   |  2 +-
> >>>   gcc/testsuite/gcc.dg/gomp/pr46032-2.c          |  2 +-
> >>>   gcc/testsuite/gcc.dg/gomp/pr46032-3.c          |  2 +-
> >>>   gcc/testsuite/gcc.dg/gomp/simd-2.c             |  2 +-
> >>>   gcc/testsuite/gcc.dg/gomp/simd-3.c             |  2 +-
> >>>   gcc/testsuite/gcc.dg/graphite/fuse-1.c         |  2 +-
> >>>   gcc/testsuite/gcc.dg/pr67089-6.c               |  2 +-
> >>>   gcc/testsuite/gcc.dg/pr82929-2.c               |  2 +-
> >>>   gcc/testsuite/gcc.dg/pr82929.c                 |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_1.c         |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_11.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_15.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_16.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_19.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_24.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_25.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_28.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_30.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_5.c         |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_7.c         |  2 +-
> >>>   gcc/testsuite/gcc.dg/store_merging_8.c         |  2 +-
> >>>   gcc/testsuite/gcc.dg/strlenopt-85.c            |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/dump-6.c         |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c      |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/pr47059.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/pr86017.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/pr91482.c        |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c      |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c  |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c     |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c     |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c     |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c     |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c     |  2 +-
> >>>   gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c     |  2 +-
> >>>   gcc/testsuite/gcc.dg/uninit-40.c               |  2 +-
> >>>   gcc/testsuite/gcc.dg/unroll-7.c                |  2 +-
> >>>   gcc/testsuite/gcc.misc-tests/help.exp          |  2 +-
> >>>   .../i386/avx512vpopcntdqvl-vpopcntd-1.c        |  2 +-
> >>>   gcc/testsuite/gcc.target/i386/pr22141.c        |  2 +-
> >>>   gcc/testsuite/gcc.target/i386/pr34012.c        |  2 +-
> >>>   gcc/testsuite/gcc.target/i386/pr49781-1.c      |  2 +-
> >>>   gcc/testsuite/gcc.target/i386/pr95798-1.c      |  2 +-
> >>>   gcc/testsuite/gcc.target/i386/pr95798-2.c      |  2 +-
> >>>   gcc/testsuite/gfortran.dg/pr77498.f            |  2 +-
> >>>   56 files changed, 74 insertions(+), 60 deletions(-)
> >>>
> >>> diff --git a/gcc/common.opt b/gcc/common.opt
> >>> index b921f5e3b25..4f2c0294c29 100644
> >>> --- a/gcc/common.opt
> >>> +++ b/gcc/common.opt
> >>> @@ -3031,7 +3031,7 @@ Perform variable tracking and also tag variables that are uninitialized.
> >>>
> >>>   ; Alias to enable both -ftree-loop-vectorize and -ftree-slp-vectorize.
> >>>   ftree-vectorize
> >>> -Common Optimization
> >>> +Common Var(flag_tree_vectorize) Optimization
> >>>   Enable vectorization on trees.
> >>>
> >>>   ftree-vectorizer-verbose=
> >>> diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
> >>> index 78cfc100ac2..be022ef8024 100644
> >>> --- a/gcc/doc/invoke.texi
> >>> +++ b/gcc/doc/invoke.texi
> >>> @@ -10409,9 +10409,13 @@ also turns on the following optimization flags:
> >>>   -fstrict-aliasing @gol
> >>>   -fthread-jumps @gol
> >>>   -ftree-builtin-call-dce @gol
> >>> +-ftree-loop-vectorize @gol
> >>>   -ftree-pre @gol
> >>> +-ftree-slp-vectorize @gol
> >>>   -ftree-switch-conversion  -ftree-tail-merge @gol
> >>> --ftree-vrp}
> >>> +-ftree-vrp @gol
> >>> +-fvect-cost-model @gol
> >>
> >> the above is redundant
> >>
> >>> +-fvect-cost-model=very-cheap}
> >>>
> >>>   Please note the warning under @option{-fgcse} about
> >>>   invoking @option{-O2} on programs that use computed gotos.
> >>> @@ -10431,9 +10435,7 @@ by @option{-O2} and also turns on the following optimization flags:
> >>>   -fsplit-loops @gol
> >>>   -fsplit-paths @gol
> >>>   -ftree-loop-distribution @gol
> >>> --ftree-loop-vectorize @gol
> >>>   -ftree-partial-pre @gol
> >>> --ftree-slp-vectorize @gol
> >>>   -funswitch-loops @gol
> >>>   -fvect-cost-model @gol
> >>
> >> likewise - so just remove it here as you are around
> >>
> >>>   -fvect-cost-model=dynamic @gol
> >>> diff --git a/gcc/opts.c b/gcc/opts.c
> >>> index 1d2d22d7a3f..cee372a3235 100644
> >>> --- a/gcc/opts.c
> >>> +++ b/gcc/opts.c
> >>> @@ -634,7 +634,8 @@ static const struct default_options default_options_table[] =
> >>>       { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
> >>>       { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
> >>>       { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
> >>> -    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
> >>> +    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL,
> >>> +      VECT_COST_MODEL_VERY_CHEAP },
> >>>       { OPT_LEVELS_2_PLUS, OPT_finline_functions, NULL, 1 },
> >>>       { OPT_LEVELS_2_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
> >>>
> >>> @@ -646,6 +647,9 @@ static const struct default_options default_options_table[] =
> >>>       { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
> >>>       { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
> >>>         REORDER_BLOCKS_ALGORITHM_STC },
> >>> +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_loop_vectorize, NULL, 1 },
> >>> +    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_slp_vectorize, NULL, 1 },
> >>> +
> >>>   #ifdef INSN_SCHEDULING
> >>>     /* Only run the pre-regalloc scheduling pass if optimizing for speed.  */
> >>>       { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
> >>> @@ -663,9 +667,7 @@ static const struct default_options default_options_table[] =
> >>>       { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
> >>>       { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
> >>>       { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
> >>> -    { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
> >>>       { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
> >>> -    { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
> >>>       { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
> >>>       { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
> >>>       { OPT_LEVELS_3_PLUS, OPT_fversion_loops_for_strides, NULL, 1 },
> >>> @@ -1331,6 +1333,16 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
> >>>         = (opts->x_flag_unroll_loops
> >>>            || opts->x_flag_peel_loops
> >>>            || opts->x_optimize >= 3);
> >>> +
> >>> +  /* Use -fvect-cost-model=cheap instead of -fvect-cost-mode=very-cheap
> >>> +     by default with explicit -ftree-{loop,slp}-vectorize.  */
> >>> +  if (opts->x_optimize == 2
> >>> +      && (opts_set->x_flag_tree_loop_vectorize
> >>> +       || opts_set->x_flag_tree_vectorize))
> >>> +    SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
> >>> +                      VECT_COST_MODEL_CHEAP);
> >>> +
> >>> +
> >>
> >> please avoid adding excessive vertical space at the end of the function
> >>
> >>>   }
> >>>
> >>>   #define LEFT_COLUMN  27
> >>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> >>> index 1d79930cd58..9351f7e7a1a 100644
> >>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> >>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> >>> @@ -1,7 +1,7 @@
> >>>   /* PR middle-end/91458 - inconsistent warning for writing past the end
> >>>      of an array member
> >>>      { dg-do compile }
> >>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> >>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> >>
> >> The testcase is large - what part requires this change?  Given the
> >> testcase was added for inconsistent warnings do they now become
> >> inconsistent again as we enable vectorization at -O2?
> >>
> >> That said, the testcase adjustments need some explaining - I suppose
> >> you didn't just slap -fno-tree-vectorize to all of those changing
> >> behavior?
> >>
> > void ga1_ (void)
> > {
> >    a1_.a[0] = 0;
> >    a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
> >    a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> >
> >    struct A1 a;
> >    a.a[0] = 0;
> >    a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
> >    a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
> >    sink (&a);
> > }
> >
> > It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> > there are 2 accesses, but after enabling vectorization, there's only
> > one access, so one warning is missing which causes the failure.
>
> I would find it preferable to change the test code over disabling
> optimizations that are on by default.  My concern is that the test
> would no longer exercise the default behavior.  (The same goes for
> the -fno-ipa-icf option.)
Hmm, it's a middle-end test, for some backend, it may not do
vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
relative cost model).
>
> Thanks
> Martin
>
> >
> >     <bb 2> [local count: 1073741824]:
> >    a1__.a[0] = 0;
> >    a1__.a[1] = 1;
> >    a1__.a[2] = 2;
> >    MEM <char[1]> [(struct A1 *)&a + 1B] = {};
> >    a.n = 1;
> >    MEM <vector(2) char> [(char *)&a + 2B] = { 1, 2 };
> >    sink (&a);
> >    a ={v} {CLOBBER};
> >    return;
> >
> >
> >> Thanks,
> >> Richard.
> >>
> >>>   void sink (void*);
> >>>
> >>> diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> >>> index 39e32fd4bc9..bc14309480c 100644
> >>> --- a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> >>> +++ b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed" } */
> >>> +/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed -fno-tree-vectorize" } */
> >>>   struct p
> >>>   {
> >>>     char *ay;
> >>> diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> >>> index 49ee878806a..60e8dd4f0e2 100644
> >>> --- a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> >>> +++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR c/98597 - ICE in -Wuninitialized printing a MEM_REF
> >>>      { dg-do compile }
> >>> -   { dg-options "-O2 -Wall" } */
> >>> +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> >>>
> >>>   struct shared_count {
> >>>     shared_count () { }
> >>> diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-51.c b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> >>> index 6028b11637c..8b81a0ccfa7 100644
> >>> --- a/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> >>> +++ b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
> >>> @@ -1,7 +1,7 @@
> >>>   /* PR middle-end/92333 - missing variable name referencing VLA in warnings
> >>>      PR middle-end/82608 - missing -Warray-bounds on an out-of-bounds VLA index
> >>>      { dg-do compile }
> >>> -   { dg-options "-O2 -Wall" } */
> >>> +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> >>>
> >>>   void sink (void*);
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/Warray-parameter-3.c b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> >>> index cbf3e9339f5..fbef715aa99 100644
> >>> --- a/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> >>> +++ b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
> >>> @@ -59,7 +59,7 @@ void fas1 (int[static 2]);    // { dg-warning "\\\[-Warray-parameter=" }
> >>>
> >>>   /* Also verify that -Warray-bounds doesn't trigger for ordinary array
> >>>      parameters...  */
> >>> -#pragma GCC optimize "2"
> >>> +#pragma GCC optimize ("2,-fno-tree-vectorize")
> >>>
> >>>   __attribute__ ((noipa)) void
> >>>   gca3 (char a[3])
> >>> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> >>> index bd513151cea..a78242bf26e 100644
> >>> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> >>> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
> >>> @@ -3,7 +3,7 @@
> >>>      PR middle-end/89911 - ICE on a call with no arguments to strnlen
> >>>      declared with no prototype
> >>>      { dg-do compile }
> >>> -   { dg-options "-O2 -Wall" } */
> >>> +   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
> >>>
> >>>   typedef __SIZE_TYPE__ size_t;
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> >>> index d6201b068b6..808bf87c386 100644
> >>> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> >>> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
> >>> @@ -2,7 +2,7 @@
> >>>      types than char are diagnosed.
> >>>      { dg-do compile }
> >>>      { dg-require-effective-target int32plus }
> >>> -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> >>> +   { dg-options "-O2 -fno-tree-vectorize -Wall -Wno-array-bounds" } */
> >>>
> >>>   typedef __INT16_TYPE__  int16_t;
> >>>   typedef __INT32_TYPE__  int32_t;
> >>> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> >>> index 3a27460220c..f418a17ca93 100644
> >>> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> >>> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
> >>> @@ -1,7 +1,7 @@
> >>>   /* PR middle-end/92312 - bogus -Wstringop-overflow storing into a trailing
> >>>      array backed by larger buffer
> >>>      { dg-do compile }
> >>> -   { dg-options "-O2 -Wall -Wno-array-bounds" } */
> >>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-tree-vectorize" } */
> >>>
> >>>   struct S0 { char a, b[0]; };
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> >>> index 6bcba274541..7cc1012130c 100644
> >>> --- a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> >>> +++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
> >>> @@ -2,7 +2,7 @@
> >>>      a larger scalar into a smaller array
> >>>      Verify overflow by aggregate stores.
> >>>      { dg-do compile }
> >>> -   { dg-options "-O2" } */
> >>> +   { dg-options "-O2 -fno-tree-vectorize" } */
> >>>
> >>>   #define A(N) (A ## N)
> >>>   #define Ac1 (AC1){ 0 }
> >>> diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> >>> index e110880bd8e..2e562618489 100644
> >>> --- a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> >>> +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> >>>
> >>>   #define N 2
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> >>> index a4af7ec4a8a..da1ab487385 100644
> >>> --- a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> >>> +++ b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
> >>>
> >>>   #define N 2
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/gomp/simd-2.c b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> >>> index 85acb980f10..f4912127b81 100644
> >>> --- a/gcc/testsuite/gcc.dg/gomp/simd-2.c
> >>> +++ b/gcc/testsuite/gcc.dg/gomp/simd-2.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> >>> +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> >>>   /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> >>>   /* { dg-additional-options "-mavx" { target avx } } */
> >>>   /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> >>> diff --git a/gcc/testsuite/gcc.dg/gomp/simd-3.c b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> >>> index 86fee858673..c75060c07ae 100644
> >>> --- a/gcc/testsuite/gcc.dg/gomp/simd-3.c
> >>> +++ b/gcc/testsuite/gcc.dg/gomp/simd-3.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
> >>> +/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
> >>>   /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
> >>>   /* { dg-additional-options "-mavx" { target avx } } */
> >>>   /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
> >>> diff --git a/gcc/testsuite/gcc.dg/graphite/fuse-1.c b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> >>> index 527b6e5c415..61289d312c2 100644
> >>> --- a/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> >>> +++ b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* Check that the two loops are fused and that we manage to fold the two xor
> >>>      operations.  */
> >>> -/* { dg-options "-O2 -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
> >>>
> >>>   /* Make sure we fuse the loops like this:
> >>>   AST generated by isl:
> >>> diff --git a/gcc/testsuite/gcc.dg/pr67089-6.c b/gcc/testsuite/gcc.dg/pr67089-6.c
> >>> index db2ffdfeca4..b59d75b2318 100644
> >>> --- a/gcc/testsuite/gcc.dg/pr67089-6.c
> >>> +++ b/gcc/testsuite/gcc.dg/pr67089-6.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR target/67089 */
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -ftree-loop-if-convert -fdump-tree-widening_mul" } */
> >>>
> >>>   extern void abort (void);
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/pr82929-2.c b/gcc/testsuite/gcc.dg/pr82929-2.c
> >>> index 3442f91af02..b886f1cce76 100644
> >>> --- a/gcc/testsuite/gcc.dg/pr82929-2.c
> >>> +++ b/gcc/testsuite/gcc.dg/pr82929-2.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR tree-optimization/82929 */
> >>>   /* { dg-do compile { target store_merge } } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   void
> >>>   foo (short *p, short *q, short *r)
> >>> diff --git a/gcc/testsuite/gcc.dg/pr82929.c b/gcc/testsuite/gcc.dg/pr82929.c
> >>> index bb84f2b21a3..123e1919cec 100644
> >>> --- a/gcc/testsuite/gcc.dg/pr82929.c
> >>> +++ b/gcc/testsuite/gcc.dg/pr82929.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR tree-optimization/82929 */
> >>>   /* { dg-do compile { target store_merge } } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   void
> >>>   foo (short *p, short *q, short *r)
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_1.c b/gcc/testsuite/gcc.dg/store_merging_1.c
> >>> index 4cc43dfd9e1..91ca925be0e 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_1.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_1.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* { dg-do compile } */
> >>>   /* { dg-require-effective-target store_merge } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   struct bar {
> >>>     int a;
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_11.c b/gcc/testsuite/gcc.dg/store_merging_11.c
> >>> index 2ec2394afb9..60ed5cd8bf9 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_11.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_11.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* { dg-do run } */
> >>>   /* { dg-require-effective-target store_merge } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   struct S { unsigned char b[2]; unsigned short c; unsigned char d[4]; unsigned long e; };
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_15.c b/gcc/testsuite/gcc.dg/store_merging_15.c
> >>> index acd7de571f8..13fcca4aa11 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_15.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_15.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* { dg-do run } */
> >>>   /* { dg-require-effective-target store_merge } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   struct S { unsigned char a, b; unsigned short c; unsigned char d, e, f, g; unsigned long long h; };
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_16.c b/gcc/testsuite/gcc.dg/store_merging_16.c
> >>> index 9545dcce3de..cd83f1c0fe5 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_16.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_16.c
> >>> @@ -2,7 +2,7 @@
> >>>      are either big or little endian (not pdp endian).  */
> >>>   /* { dg-do run { target { lp64 && { i?86-*-* x86_64-*-* powerpc*-*-* aarch64*-*-* } } } } */
> >>>   /* { dg-require-effective-target store_merge } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   __attribute__((noipa)) void
> >>>   f1 (unsigned char *p, unsigned long long q)
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_19.c b/gcc/testsuite/gcc.dg/store_merging_19.c
> >>> index 0841bb4deee..0a2bbc4bfde 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_19.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_19.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR tree-optimization/83843 */
> >>>   /* { dg-do run } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>   /* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" { target store_merge } } } */
> >>>
> >>>   __attribute__((noipa)) void
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_24.c b/gcc/testsuite/gcc.dg/store_merging_24.c
> >>> index 744fe60e8e0..5291bb9e986 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_24.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_24.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR tree-optimization/87859 */
> >>>   /* { dg-do run } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> >>>   /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 19 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> >>>   /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_25.c b/gcc/testsuite/gcc.dg/store_merging_25.c
> >>> index cf182190e91..96611b5e57b 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_25.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_25.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR tree-optimization/87859 */
> >>>   /* { dg-do run } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> >>>   /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 14 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> >>>   /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_28.c b/gcc/testsuite/gcc.dg/store_merging_28.c
> >>> index 2d6cffc4694..fadb7fff993 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_28.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_28.c
> >>> @@ -1,7 +1,7 @@
> >>>   /* PR tree-optimization/88709 */
> >>>   /* { dg-do compile } */
> >>>   /* { dg-require-effective-target store_merge } */
> >>> -/* { dg-options "-O2 -fno-ipa-icf -fdump-tree-store-merging-details" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-ipa-icf -fdump-tree-store-merging-details" } */
> >>>   /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 16 stores" 8 "store-merging" { target { i?86-*-* x86_64-*-* } } } } */
> >>>   /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 6 stores" 1 "store-merging" { target { ! arm*-*-* } } } } */
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_30.c b/gcc/testsuite/gcc.dg/store_merging_30.c
> >>> index 694d560a621..baf94efe733 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_30.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_30.c
> >>> @@ -1,7 +1,7 @@
> >>>   /* PR tree-optimization/94573 */
> >>>   /* { dg-do compile } */
> >>>   /* { dg-require-effective-target store_merge } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
> >>>   /* { dg-final { scan-tree-dump "New sequence of 4 stores to replace old one of 8 stores" "store-merging" { target lp64 } } } */
> >>>
> >>>   int var[43][12];
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_5.c b/gcc/testsuite/gcc.dg/store_merging_5.c
> >>> index 6e7c72510ff..b0cb0da78e0 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_5.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_5.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* { dg-do compile } */
> >>>   /* { dg-require-effective-target store_merge } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   /* Make sure that non-aliasing non-constant interspersed stores do not
> >>>      stop chains.  */
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_7.c b/gcc/testsuite/gcc.dg/store_merging_7.c
> >>> index c744ece6407..dbe000a463e 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_7.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_7.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* { dg-do compile } */
> >>>   /* { dg-require-effective-target store_merge } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   /* Check that we can merge consecutive array members through the pointer.
> >>>      PR rtl-optimization/23684.  */
> >>> diff --git a/gcc/testsuite/gcc.dg/store_merging_8.c b/gcc/testsuite/gcc.dg/store_merging_8.c
> >>> index e710a544ff0..d719e0a2257 100644
> >>> --- a/gcc/testsuite/gcc.dg/store_merging_8.c
> >>> +++ b/gcc/testsuite/gcc.dg/store_merging_8.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* { dg-do compile } */
> >>>   /* { dg-require-effective-target store_merge } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   struct baz {
> >>>     struct bar {
> >>> diff --git a/gcc/testsuite/gcc.dg/strlenopt-85.c b/gcc/testsuite/gcc.dg/strlenopt-85.c
> >>> index e049e0c30e0..2ba1ee05700 100644
> >>> --- a/gcc/testsuite/gcc.dg/strlenopt-85.c
> >>> +++ b/gcc/testsuite/gcc.dg/strlenopt-85.c
> >>> @@ -4,7 +4,7 @@
> >>>      of memory allocated by calloc() even if one or more nul bytes are
> >>>      written into it.
> >>>      { dg-do compile }
> >>> -   { dg-options "-O2 -fdump-tree-optimized" } */
> >>> +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> >>>
> >>>   unsigned n0, n1;
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> >>> index 70659c00c0e..6c803908781 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR middle-end/90676 - default GIMPLE dumps lack information
> >>>      { dg-do compile }
> >>> -   { dg-options "-O2 -fdump-tree-store-merging" }
> >>> +   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" }
> >>>      { dg-require-effective-target int32plus }
> >>>      { dg-require-effective-target store_merge } */
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> >>> index 50d86a00485..b9e40e964c1 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fopt-info-loop-missed" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fopt-info-loop-missed" } */
> >>>   extern void g(void);
> >>>
> >>>   void
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> >>> index 9f9c61aa213..860cde12c0f 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-Os -fdump-tree-optimized" } */
> >>> +/* { dg-options "-Os -fno-tree-vectorize -fdump-tree-optimized" } */
> >>>
> >>>
> >>>   struct struct1
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> >>> index f216e83c7b3..c7ef73ad59e 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
> >>>
> >>>   void f (void*);
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> >>> index 7d6a724e4ad..0ddad573129 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-ccp1 -fdump-tree-store-merging" } */
> >>>
> >>>   void write64 (void *p)
> >>>   {
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> >>> index f68be2b3379..8c3d9a4fc58 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* { dg-do compile } */
> >>>   /* { dg-do run } */
> >>> -/* { dg-options "-O2 -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
> >>>
> >>>   void abort (void);
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> >>> index ec08d6c0318..1fc8f089345 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do run } */
> >>> -/* { dg-options "-O2 -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
> >>>
> >>>   int arr1[105] = {2, 3, 5, 7, 11, 13, 0};
> >>>   int arr2[105] = {2, 3, 5, 7, 11, 13, 0};
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> >>> index 467903bf3fc..46f0d0c2317 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
> >>> @@ -1,7 +1,7 @@
> >>>   /* Prefetching used to prefer nonsensical unroll factor of 5 in this testcase.  */
> >>>
> >>>   /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> >>> -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
> >>>
> >>>   #define N 1000000
> >>>
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> >>> index 12f09016943..3fa71685ace 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> >>> -/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
> >>>
> >>>   #define N 1000
> >>>   #define K 900
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> >>> index cbd6a80d345..00f41c3e4f4 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> >>> -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> >>>
> >>>   #define K 1000000
> >>>   int a[K];
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> >>> index da4847320b1..e8848c30acc 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
> >>> -/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
> >>>
> >>>   #define K 1000000
> >>>   int a[K], b[K];
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> >>> index 92b2df80ec8..2e7b5b496ea 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fdump-tree-optimized" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> >>>   int g(_Complex int*);
> >>>   int f(void)
> >>>   {
> >>> diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> >>> index 718b7466e50..7bb8d060631 100644
> >>> --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> >>> +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fdump-tree-optimized" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
> >>>   int g(_Complex int*);
> >>>   int f(void)
> >>>   {
> >>> diff --git a/gcc/testsuite/gcc.dg/uninit-40.c b/gcc/testsuite/gcc.dg/uninit-40.c
> >>> index c015191ca32..8708079d397 100644
> >>> --- a/gcc/testsuite/gcc.dg/uninit-40.c
> >>> +++ b/gcc/testsuite/gcc.dg/uninit-40.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR tree-optimization/98597 */
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -Wuninitialized" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -Wuninitialized" } */
> >>>
> >>>   union U { double d; int i; float f; };
> >>>   struct S { char a; int b; char c; unsigned d; union U e; int f[3]; unsigned g[3]; };
> >>> diff --git a/gcc/testsuite/gcc.dg/unroll-7.c b/gcc/testsuite/gcc.dg/unroll-7.c
> >>> index 055369bf8b1..695af5757cc 100644
> >>> --- a/gcc/testsuite/gcc.dg/unroll-7.c
> >>> +++ b/gcc/testsuite/gcc.dg/unroll-7.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fdump-rtl-loop2_unroll-details -funroll-loops" } */
> >>>   /* { dg-require-effective-target int32plus } */
> >>>
> >>>   extern int *a;
> >>> diff --git a/gcc/testsuite/gcc.misc-tests/help.exp b/gcc/testsuite/gcc.misc-tests/help.exp
> >>> index 5e034d26947..eb6d8686c6a 100644
> >>> --- a/gcc/testsuite/gcc.misc-tests/help.exp
> >>> +++ b/gcc/testsuite/gcc.misc-tests/help.exp
> >>> @@ -79,7 +79,7 @@ check_for_options c "--help=target,optimizers" "" "" ""
> >>>   check_for_options c "--help=warnings,^joined,^undocumented" "" "" ""
> >>>   check_for_options c "-Q -O2 --help=optimizers" {
> >>>   -O
> >>> --ftree-loop-vectorize[^\n]*disabled
> >>> +-ftree-loop-vectorize[^\n]*enabled
> >>>   } "  -g  " ""
> >>>   check_for_options c "-Q -O3 --help=optimizers" {
> >>>   -O
> >>> diff --git a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> >>> index 709cd21e671..a732bc466db 100644
> >>> --- a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> >>> +++ b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do run } */
> >>> -/* { dg-options "-O2 -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
> >>>   /* { dg-require-effective-target avx512vl } */
> >>>   /* { dg-require-effective-target avx512vpopcntdqvl } */
> >>>   /* { dg-require-effective-target avx512bw } */
> >>> diff --git a/gcc/testsuite/gcc.target/i386/pr22141.c b/gcc/testsuite/gcc.target/i386/pr22141.c
> >>> index 036422e8ccf..b68b97f3f72 100644
> >>> --- a/gcc/testsuite/gcc.target/i386/pr22141.c
> >>> +++ b/gcc/testsuite/gcc.target/i386/pr22141.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR middle-end/22141 */
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-Os" } */
> >>> +/* { dg-options "-Os -fno-tree-vectorize" } */
> >>>
> >>>   extern void abort (void);
> >>>
> >>> diff --git a/gcc/testsuite/gcc.target/i386/pr34012.c b/gcc/testsuite/gcc.target/i386/pr34012.c
> >>> index d0cffa05290..1c1f0eea52e 100644
> >>> --- a/gcc/testsuite/gcc.target/i386/pr34012.c
> >>> +++ b/gcc/testsuite/gcc.target/i386/pr34012.c
> >>> @@ -1,7 +1,7 @@
> >>>   /* PR rtl-optimization/34012 */
> >>>   /* { dg-do compile } */
> >>>   /* { dg-require-effective-target lp64 } */
> >>> -/* { dg-options "-O2 -fno-store-merging" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fno-store-merging" } */
> >>>
> >>>   void bar (long int *);
> >>>   void
> >>> diff --git a/gcc/testsuite/gcc.target/i386/pr49781-1.c b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> >>> index 60f9d50d866..d5a2e32db97 100644
> >>> --- a/gcc/testsuite/gcc.target/i386/pr49781-1.c
> >>> +++ b/gcc/testsuite/gcc.target/i386/pr49781-1.c
> >>> @@ -1,5 +1,5 @@
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -fpic -mtune=generic" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -fpic -mtune=generic" } */
> >>>   /* { dg-require-effective-target fpic } */
> >>>
> >>>   static int heap[2*(256 +1+29)+1];
> >>> diff --git a/gcc/testsuite/gcc.target/i386/pr95798-1.c b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> >>> index 9a7e32d6f2f..526f48921fd 100644
> >>> --- a/gcc/testsuite/gcc.target/i386/pr95798-1.c
> >>> +++ b/gcc/testsuite/gcc.target/i386/pr95798-1.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR target/95798 */
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> >>>   /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >>>   /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >>>   /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >>> diff --git a/gcc/testsuite/gcc.target/i386/pr95798-2.c b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> >>> index c670d3780e8..6b5c5a73e96 100644
> >>> --- a/gcc/testsuite/gcc.target/i386/pr95798-2.c
> >>> +++ b/gcc/testsuite/gcc.target/i386/pr95798-2.c
> >>> @@ -1,6 +1,6 @@
> >>>   /* PR target/95798 */
> >>>   /* { dg-do compile } */
> >>> -/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
> >>> +/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
> >>>   /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >>>   /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >>>   /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
> >>> diff --git a/gcc/testsuite/gfortran.dg/pr77498.f b/gcc/testsuite/gfortran.dg/pr77498.f
> >>> index f957b57bb00..a0fc8275a84 100644
> >>> --- a/gcc/testsuite/gfortran.dg/pr77498.f
> >>> +++ b/gcc/testsuite/gfortran.dg/pr77498.f
> >>> @@ -1,5 +1,5 @@
> >>>   ! { dg-do compile }
> >>> -! { dg-options "-O2 -ffast-math -fdump-tree-pre" }
> >>> +! { dg-options "-O2 -fno-tree-vectorize -ffast-math -fdump-tree-pre" }
> >>>
> >>>         subroutine foo(U,V,R,N,A)
> >>>         integer N
> >>>
> >>
> >> --
> >> Richard Biener <rguenther@suse.de>
> >> SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
> >> Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)
> >
> >
> >
>
Martin Sebor Sept. 22, 2021, 2:21 p.m. UTC | #9
On 9/21/21 7:38 PM, Hongtao Liu wrote:
> On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
...
>>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>> index 1d79930cd58..9351f7e7a1a 100644
>>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>> @@ -1,7 +1,7 @@
>>>>>    /* PR middle-end/91458 - inconsistent warning for writing past the end
>>>>>       of an array member
>>>>>       { dg-do compile }
>>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
>>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
>>>>
>>>> The testcase is large - what part requires this change?  Given the
>>>> testcase was added for inconsistent warnings do they now become
>>>> inconsistent again as we enable vectorization at -O2?
>>>>
>>>> That said, the testcase adjustments need some explaining - I suppose
>>>> you didn't just slap -fno-tree-vectorize to all of those changing
>>>> behavior?
>>>>
>>> void ga1_ (void)
>>> {
>>>     a1_.a[0] = 0;
>>>     a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
>>>     a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
>>>
>>>     struct A1 a;
>>>     a.a[0] = 0;
>>>     a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
>>>     a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
>>>     sink (&a);
>>> }
>>>
>>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
>>> there are 2 accesses, but after enabling vectorization, there's only
>>> one access, so one warning is missing which causes the failure.

With the stores vectorized, is the warning on the correct line or
does it point to the first store, the one that's in bounds, as
it does with -O3?  The latter would be a regression at -O2.

>>
>> I would find it preferable to change the test code over disabling
>> optimizations that are on by default.  My concern is that the test
>> would no longer exercise the default behavior.  (The same goes for
>> the -fno-ipa-icf option.)
> Hmm, it's a middle-end test, for some backend, it may not do
> vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
> relative cost model).

Yes, there are quite a few warning tests like that.  Their main
purpose is to verify that in common GCC invocations (i.e., without
any special options) warnings are a) issued when expected and b)
not issued when not expected.  Otherwise, middle end warnings are
known to have both false positives and false negatives in some
invocations, depending on what optimizations are in effect.
Indiscriminately disabling common optimizations for these large
tests and invoking them under artificial conditions would
compromise this goal and hide the problems.

If enabling vectorization at -O2 causes regressions in the quality
of diagnostics (as the test failure above indicates seems to be
happening) we should investigate these and open bugs for them so
they can be fixed.  We can then tweak the specific failing test
cases to avoid the failures until they are fixed.

Martin
Martin Sebor Sept. 22, 2021, 3:03 p.m. UTC | #10
On 9/22/21 8:21 AM, Martin Sebor wrote:
> On 9/21/21 7:38 PM, Hongtao Liu wrote:
>> On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
> ...
>>>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c 
>>>>>> b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>> index 1d79930cd58..9351f7e7a1a 100644
>>>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>> @@ -1,7 +1,7 @@
>>>>>>    /* PR middle-end/91458 - inconsistent warning for writing past 
>>>>>> the end
>>>>>>       of an array member
>>>>>>       { dg-do compile }
>>>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
>>>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf 
>>>>>> -fno-tree-vectorize" } */
>>>>>
>>>>> The testcase is large - what part requires this change?  Given the
>>>>> testcase was added for inconsistent warnings do they now become
>>>>> inconsistent again as we enable vectorization at -O2?
>>>>>
>>>>> That said, the testcase adjustments need some explaining - I suppose
>>>>> you didn't just slap -fno-tree-vectorize to all of those changing
>>>>> behavior?
>>>>>
>>>> void ga1_ (void)
>>>> {
>>>>     a1_.a[0] = 0;
>>>>     a1_.a[1] = 1;                 // { dg-warning 
>>>> "\\\[-Wstringop-overflow" }
>>>>     a1_.a[2] = 2;                 // { dg-warning 
>>>> "\\\[-Wstringop-overflow" }
>>>>
>>>>     struct A1 a;
>>>>     a.a[0] = 0;
>>>>     a.a[1] = 1;                   // { dg-warning 
>>>> "\\\[-Wstringop-overflow" }
>>>>     a.a[2] = 2;                   // { dg-warning 
>>>> "\\\[-Wstringop-overflow" }
>>>>     sink (&a);
>>>> }
>>>>
>>>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
>>>> there are 2 accesses, but after enabling vectorization, there's only
>>>> one access, so one warning is missing which causes the failure.
> 
> With the stores vectorized, is the warning on the correct line or
> does it point to the first store, the one that's in bounds, as
> it does with -O3?  The latter would be a regression at -O2.
> 
>>>
>>> I would find it preferable to change the test code over disabling
>>> optimizations that are on by default.  My concern is that the test
>>> would no longer exercise the default behavior.  (The same goes for
>>> the -fno-ipa-icf option.)
>> Hmm, it's a middle-end test, for some backend, it may not do
>> vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
>> relative cost model).
> 
> Yes, there are quite a few warning tests like that.  Their main
> purpose is to verify that in common GCC invocations (i.e., without
> any special options) warnings are a) issued when expected and b)
> not issued when not expected.  Otherwise, middle end warnings are
> known to have both false positives and false negatives in some
> invocations, depending on what optimizations are in effect.
> Indiscriminately disabling common optimizations for these large
> tests and invoking them under artificial conditions would
> compromise this goal and hide the problems.
> 
> If enabling vectorization at -O2 causes regressions in the quality
> of diagnostics (as the test failure above indicates seems to be
> happening) we should investigate these and open bugs for them so
> they can be fixed.  We can then tweak the specific failing test
> cases to avoid the failures until they are fixed.

To expand on the last part: in my tests with -O2 and -O3 the failure
is specific to char stores and doesn't affect stores of larger types
because they're not detected by -Wstringop-overflow.  Those accesses
are handled by -Warray-bounds.  The former runs as part of the strlen
and after vectorization, while the latter runs in vrp1 and before
vectorization.  So the "quick and dirty" solution here, to keep
the warnings on the right lines, might be to move the char store
handling from the strlen pass to vrp1.  A more robust solution is
to avoid vectorizing (or merging) out of bounds stores.

> 
> Martin
Hongtao Liu Sept. 23, 2021, 1:48 a.m. UTC | #11
On Wed, Sep 22, 2021 at 10:21 PM Martin Sebor <msebor@gmail.com> wrote:
>
> On 9/21/21 7:38 PM, Hongtao Liu wrote:
> > On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
> ...
> >>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> >>>>> index 1d79930cd58..9351f7e7a1a 100644
> >>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> >>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> >>>>> @@ -1,7 +1,7 @@
> >>>>>    /* PR middle-end/91458 - inconsistent warning for writing past the end
> >>>>>       of an array member
> >>>>>       { dg-do compile }
> >>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> >>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> >>>>
> >>>> The testcase is large - what part requires this change?  Given the
> >>>> testcase was added for inconsistent warnings do they now become
> >>>> inconsistent again as we enable vectorization at -O2?
> >>>>
> >>>> That said, the testcase adjustments need some explaining - I suppose
> >>>> you didn't just slap -fno-tree-vectorize to all of those changing
> >>>> behavior?
> >>>>
> >>> void ga1_ (void)
> >>> {
> >>>     a1_.a[0] = 0;
> >>>     a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
> >>>     a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> >>>
> >>>     struct A1 a;
> >>>     a.a[0] = 0;
> >>>     a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
> >>>     a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
> >>>     sink (&a);
> >>> }
> >>>
> >>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> >>> there are 2 accesses, but after enabling vectorization, there's only
> >>> one access, so one warning is missing which causes the failure.
>
> With the stores vectorized, is the warning on the correct line or
> does it point to the first store, the one that's in bounds, as
> it does with -O3?  The latter would be a regression at -O2.
For the upper case, It points to the second store which is out of
bounds, the third store warning is missing.
>
> >>
> >> I would find it preferable to change the test code over disabling
> >> optimizations that are on by default.  My concern is that the test
> >> would no longer exercise the default behavior.  (The same goes for
> >> the -fno-ipa-icf option.)
> > Hmm, it's a middle-end test, for some backend, it may not do
> > vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
> > relative cost model).
>
> Yes, there are quite a few warning tests like that.  Their main
> purpose is to verify that in common GCC invocations (i.e., without
> any special options) warnings are a) issued when expected and b)
> not issued when not expected.  Otherwise, middle end warnings are
> known to have both false positives and false negatives in some
> invocations, depending on what optimizations are in effect.
> Indiscriminately disabling common optimizations for these large
> tests and invoking them under artificial conditions would
> compromise this goal and hide the problems.
>
> If enabling vectorization at -O2 causes regressions in the quality
> of diagnostics (as the test failure above indicates seems to be
> happening) we should investigate these and open bugs for them so
> they can be fixed.  We can then tweak the specific failing test
> cases to avoid the failures until they are fixed.
There are indeed cases of false positives and false negatives
.i.e.
// Verify warning for access to a definition with an initializer that
// initializes the one-element array member.
struct A1 a1i_1 = { 0, { 1 } };

void ga1i_1 (void)
{
  a1i_1.a[0] = 0;
  a1i_1.a[1] = 1;               // { dg-warning "\\\[-Wstringop-overflow" }
  a1i_1.a[2] = 2;               // { dg-warning "\\\[-Wstringop-overflow" }

  struct A1 a = { 0, { 1 } }; --- false positive here.
  a.a[0] = 1;
  a.a[1] = 2;                   // { dg-warning
"\\\[-Wstringop-overflow" } false negative here.
  a.a[2] = 3;                   // { dg-warning
"\\\[-Wstringop-overflow" } false negative here.
  sink (&a);
}

the last 2 warnings are missing, and there's new warning on the line
*struct A1 a = { 0, { 1 } };
>
> Martin
Hongtao Liu Sept. 23, 2021, 2:08 a.m. UTC | #12
On Thu, Sep 23, 2021 at 9:48 AM Hongtao Liu <crazylht@gmail.com> wrote:
>
> On Wed, Sep 22, 2021 at 10:21 PM Martin Sebor <msebor@gmail.com> wrote:
> >
> > On 9/21/21 7:38 PM, Hongtao Liu wrote:
> > > On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
> > ...
> > >>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > >>>>> index 1d79930cd58..9351f7e7a1a 100644
> > >>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > >>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > >>>>> @@ -1,7 +1,7 @@
> > >>>>>    /* PR middle-end/91458 - inconsistent warning for writing past the end
> > >>>>>       of an array member
> > >>>>>       { dg-do compile }
> > >>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> > >>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> > >>>>
> > >>>> The testcase is large - what part requires this change?  Given the
> > >>>> testcase was added for inconsistent warnings do they now become
> > >>>> inconsistent again as we enable vectorization at -O2?
> > >>>>
> > >>>> That said, the testcase adjustments need some explaining - I suppose
> > >>>> you didn't just slap -fno-tree-vectorize to all of those changing
> > >>>> behavior?
> > >>>>
> > >>> void ga1_ (void)
> > >>> {
> > >>>     a1_.a[0] = 0;
> > >>>     a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > >>>     a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > >>>
> > >>>     struct A1 a;
> > >>>     a.a[0] = 0;
> > >>>     a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > >>>     a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > >>>     sink (&a);
> > >>> }
> > >>>
> > >>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> > >>> there are 2 accesses, but after enabling vectorization, there's only
> > >>> one access, so one warning is missing which causes the failure.
> >
> > With the stores vectorized, is the warning on the correct line or
> > does it point to the first store, the one that's in bounds, as
> > it does with -O3?  The latter would be a regression at -O2.
> For the upper case, It points to the second store which is out of
> bounds, the third store warning is missing.
> >
> > >>
> > >> I would find it preferable to change the test code over disabling
> > >> optimizations that are on by default.  My concern is that the test
> > >> would no longer exercise the default behavior.  (The same goes for
> > >> the -fno-ipa-icf option.)
> > > Hmm, it's a middle-end test, for some backend, it may not do
> > > vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
> > > relative cost model).
> >
> > Yes, there are quite a few warning tests like that.  Their main
> > purpose is to verify that in common GCC invocations (i.e., without
> > any special options) warnings are a) issued when expected and b)
> > not issued when not expected.  Otherwise, middle end warnings are
> > known to have both false positives and false negatives in some
> > invocations, depending on what optimizations are in effect.
> > Indiscriminately disabling common optimizations for these large
> > tests and invoking them under artificial conditions would
> > compromise this goal and hide the problems.
> >
> > If enabling vectorization at -O2 causes regressions in the quality
> > of diagnostics (as the test failure above indicates seems to be
> > happening) we should investigate these and open bugs for them so
> > they can be fixed.  We can then tweak the specific failing test
> > cases to avoid the failures until they are fixed.
> There are indeed cases of false positives and false negatives
> .i.e.
> // Verify warning for access to a definition with an initializer that
> // initializes the one-element array member.
> struct A1 a1i_1 = { 0, { 1 } };
>
> void ga1i_1 (void)
> {
>   a1i_1.a[0] = 0;
>   a1i_1.a[1] = 1;               // { dg-warning "\\\[-Wstringop-overflow" }
>   a1i_1.a[2] = 2;               // { dg-warning "\\\[-Wstringop-overflow" }
>
>   struct A1 a = { 0, { 1 } }; --- false positive here.
>   a.a[0] = 1;
>   a.a[1] = 2;                   // { dg-warning
> "\\\[-Wstringop-overflow" } false negative here.
>   a.a[2] = 3;                   // { dg-warning
> "\\\[-Wstringop-overflow" } false negative here.
>   sink (&a);
> }
Similar for
* gcc.dg/Warray-bounds-51.c.
* gcc.dg/Warray-parameter-3.c
* gcc.dg/Wstringop-overflow-14.c
* gcc.dg/Wstringop-overflow-21.c

So there're 3 situations.
1. All accesses are out of bound, and after vectorization, there are
some warnings missing.
2. Part of accesses are inbound, part of accesses are out of bound,
and after vectorization, the warning goes from out of bound line to
inbound line.
3. All access are out of bound, and after vectoriation, all warning
are missing, and goes to a false-positive line.
>
> the last 2 warnings are missing, and there's new warning on the line
> *struct A1 a = { 0, { 1 } };
> >
> > Martin
>
>
>
> --
> BR,
> Hongtao
Richard Biener Sept. 23, 2021, 6:30 a.m. UTC | #13
On Thu, 23 Sep 2021, Hongtao Liu wrote:

> On Thu, Sep 23, 2021 at 9:48 AM Hongtao Liu <crazylht@gmail.com> wrote:
> >
> > On Wed, Sep 22, 2021 at 10:21 PM Martin Sebor <msebor@gmail.com> wrote:
> > >
> > > On 9/21/21 7:38 PM, Hongtao Liu wrote:
> > > > On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
> > > ...
> > > >>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > >>>>> index 1d79930cd58..9351f7e7a1a 100644
> > > >>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > >>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > >>>>> @@ -1,7 +1,7 @@
> > > >>>>>    /* PR middle-end/91458 - inconsistent warning for writing past the end
> > > >>>>>       of an array member
> > > >>>>>       { dg-do compile }
> > > >>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> > > >>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> > > >>>>
> > > >>>> The testcase is large - what part requires this change?  Given the
> > > >>>> testcase was added for inconsistent warnings do they now become
> > > >>>> inconsistent again as we enable vectorization at -O2?
> > > >>>>
> > > >>>> That said, the testcase adjustments need some explaining - I suppose
> > > >>>> you didn't just slap -fno-tree-vectorize to all of those changing
> > > >>>> behavior?
> > > >>>>
> > > >>> void ga1_ (void)
> > > >>> {
> > > >>>     a1_.a[0] = 0;
> > > >>>     a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > > >>>     a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > > >>>
> > > >>>     struct A1 a;
> > > >>>     a.a[0] = 0;
> > > >>>     a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > > >>>     a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > > >>>     sink (&a);
> > > >>> }
> > > >>>
> > > >>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> > > >>> there are 2 accesses, but after enabling vectorization, there's only
> > > >>> one access, so one warning is missing which causes the failure.
> > >
> > > With the stores vectorized, is the warning on the correct line or
> > > does it point to the first store, the one that's in bounds, as
> > > it does with -O3?  The latter would be a regression at -O2.
> > For the upper case, It points to the second store which is out of
> > bounds, the third store warning is missing.
> > >
> > > >>
> > > >> I would find it preferable to change the test code over disabling
> > > >> optimizations that are on by default.  My concern is that the test
> > > >> would no longer exercise the default behavior.  (The same goes for
> > > >> the -fno-ipa-icf option.)
> > > > Hmm, it's a middle-end test, for some backend, it may not do
> > > > vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
> > > > relative cost model).
> > >
> > > Yes, there are quite a few warning tests like that.  Their main
> > > purpose is to verify that in common GCC invocations (i.e., without
> > > any special options) warnings are a) issued when expected and b)
> > > not issued when not expected.  Otherwise, middle end warnings are
> > > known to have both false positives and false negatives in some
> > > invocations, depending on what optimizations are in effect.
> > > Indiscriminately disabling common optimizations for these large
> > > tests and invoking them under artificial conditions would
> > > compromise this goal and hide the problems.
> > >
> > > If enabling vectorization at -O2 causes regressions in the quality
> > > of diagnostics (as the test failure above indicates seems to be
> > > happening) we should investigate these and open bugs for them so
> > > they can be fixed.  We can then tweak the specific failing test
> > > cases to avoid the failures until they are fixed.
> > There are indeed cases of false positives and false negatives
> > .i.e.
> > // Verify warning for access to a definition with an initializer that
> > // initializes the one-element array member.
> > struct A1 a1i_1 = { 0, { 1 } };
> >
> > void ga1i_1 (void)
> > {
> >   a1i_1.a[0] = 0;
> >   a1i_1.a[1] = 1;               // { dg-warning "\\\[-Wstringop-overflow" }
> >   a1i_1.a[2] = 2;               // { dg-warning "\\\[-Wstringop-overflow" }
> >
> >   struct A1 a = { 0, { 1 } }; --- false positive here.
> >   a.a[0] = 1;
> >   a.a[1] = 2;                   // { dg-warning
> > "\\\[-Wstringop-overflow" } false negative here.
> >   a.a[2] = 3;                   // { dg-warning
> > "\\\[-Wstringop-overflow" } false negative here.
> >   sink (&a);
> > }
> Similar for
> * gcc.dg/Warray-bounds-51.c.
> * gcc.dg/Warray-parameter-3.c
> * gcc.dg/Wstringop-overflow-14.c
> * gcc.dg/Wstringop-overflow-21.c
> 
> So there're 3 situations.
> 1. All accesses are out of bound, and after vectorization, there are
> some warnings missing.
> 2. Part of accesses are inbound, part of accesses are out of bound,
> and after vectorization, the warning goes from out of bound line to
> inbound line.
> 3. All access are out of bound, and after vectoriation, all warning
> are missing, and goes to a false-positive line.

I remember some of the warning code explicitely excuses itself from
even trying to deal with vectorized loads/stores, that might need to
be revisited.  It would also be useful to verify whether the line
info on the vectorized loads/stores is sensible (if you dump with
-lineno you get stmts with line numbers).

It is of course impossible to preserve the location of all original
scalar accesses exactly - it _might_ be possible to create a new
location range (not sure how they are exactly represented), but then
if we vectorize say

  a[0] = b[0];
  a[1] = b[1];

we'd somehow get a multi-line location range that covers unrelated
bits (the intermediate load or store).

So currently the vectorizer simply chooses the location of one of
the scalar loads or stores for the vectorized access (and it might do
so quite randomly).

Note I don't think it's feasible to not vectorize out-of-bound loads
or stores for the same reason that you'll say you can't do the
warnings all before vectorizing because the might expose themselves
only later.

So we simply have to cope with the reality that GCC is optimizing and
that the later we perform analysis for warnings the more the original
code is mangled.  As we moved array-bound warnings before unrolling
so we should move this particular warning to before vectorization
[loop optimization].

Richard.
Martin Sebor Sept. 23, 2021, 3:18 p.m. UTC | #14
On 9/23/21 12:30 AM, Richard Biener wrote:
> On Thu, 23 Sep 2021, Hongtao Liu wrote:
> 
>> On Thu, Sep 23, 2021 at 9:48 AM Hongtao Liu <crazylht@gmail.com> wrote:
>>>
>>> On Wed, Sep 22, 2021 at 10:21 PM Martin Sebor <msebor@gmail.com> wrote:
>>>>
>>>> On 9/21/21 7:38 PM, Hongtao Liu wrote:
>>>>> On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
>>>> ...
>>>>>>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>>>>> index 1d79930cd58..9351f7e7a1a 100644
>>>>>>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>>>>> @@ -1,7 +1,7 @@
>>>>>>>>>     /* PR middle-end/91458 - inconsistent warning for writing past the end
>>>>>>>>>        of an array member
>>>>>>>>>        { dg-do compile }
>>>>>>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
>>>>>>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
>>>>>>>>
>>>>>>>> The testcase is large - what part requires this change?  Given the
>>>>>>>> testcase was added for inconsistent warnings do they now become
>>>>>>>> inconsistent again as we enable vectorization at -O2?
>>>>>>>>
>>>>>>>> That said, the testcase adjustments need some explaining - I suppose
>>>>>>>> you didn't just slap -fno-tree-vectorize to all of those changing
>>>>>>>> behavior?
>>>>>>>>
>>>>>>> void ga1_ (void)
>>>>>>> {
>>>>>>>      a1_.a[0] = 0;
>>>>>>>      a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>      a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>
>>>>>>>      struct A1 a;
>>>>>>>      a.a[0] = 0;
>>>>>>>      a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>      a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>      sink (&a);
>>>>>>> }
>>>>>>>
>>>>>>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
>>>>>>> there are 2 accesses, but after enabling vectorization, there's only
>>>>>>> one access, so one warning is missing which causes the failure.
>>>>
>>>> With the stores vectorized, is the warning on the correct line or
>>>> does it point to the first store, the one that's in bounds, as
>>>> it does with -O3?  The latter would be a regression at -O2.
>>> For the upper case, It points to the second store which is out of
>>> bounds, the third store warning is missing.
>>>>
>>>>>>
>>>>>> I would find it preferable to change the test code over disabling
>>>>>> optimizations that are on by default.  My concern is that the test
>>>>>> would no longer exercise the default behavior.  (The same goes for
>>>>>> the -fno-ipa-icf option.)
>>>>> Hmm, it's a middle-end test, for some backend, it may not do
>>>>> vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
>>>>> relative cost model).
>>>>
>>>> Yes, there are quite a few warning tests like that.  Their main
>>>> purpose is to verify that in common GCC invocations (i.e., without
>>>> any special options) warnings are a) issued when expected and b)
>>>> not issued when not expected.  Otherwise, middle end warnings are
>>>> known to have both false positives and false negatives in some
>>>> invocations, depending on what optimizations are in effect.
>>>> Indiscriminately disabling common optimizations for these large
>>>> tests and invoking them under artificial conditions would
>>>> compromise this goal and hide the problems.
>>>>
>>>> If enabling vectorization at -O2 causes regressions in the quality
>>>> of diagnostics (as the test failure above indicates seems to be
>>>> happening) we should investigate these and open bugs for them so
>>>> they can be fixed.  We can then tweak the specific failing test
>>>> cases to avoid the failures until they are fixed.
>>> There are indeed cases of false positives and false negatives
>>> .i.e.
>>> // Verify warning for access to a definition with an initializer that
>>> // initializes the one-element array member.
>>> struct A1 a1i_1 = { 0, { 1 } };
>>>
>>> void ga1i_1 (void)
>>> {
>>>    a1i_1.a[0] = 0;
>>>    a1i_1.a[1] = 1;               // { dg-warning "\\\[-Wstringop-overflow" }
>>>    a1i_1.a[2] = 2;               // { dg-warning "\\\[-Wstringop-overflow" }
>>>
>>>    struct A1 a = { 0, { 1 } }; --- false positive here.
>>>    a.a[0] = 1;
>>>    a.a[1] = 2;                   // { dg-warning
>>> "\\\[-Wstringop-overflow" } false negative here.
>>>    a.a[2] = 3;                   // { dg-warning
>>> "\\\[-Wstringop-overflow" } false negative here.
>>>    sink (&a);
>>> }
>> Similar for
>> * gcc.dg/Warray-bounds-51.c.
>> * gcc.dg/Warray-parameter-3.c
>> * gcc.dg/Wstringop-overflow-14.c
>> * gcc.dg/Wstringop-overflow-21.c
>>
>> So there're 3 situations.
>> 1. All accesses are out of bound, and after vectorization, there are
>> some warnings missing.
>> 2. Part of accesses are inbound, part of accesses are out of bound,
>> and after vectorization, the warning goes from out of bound line to
>> inbound line.
>> 3. All access are out of bound, and after vectoriation, all warning
>> are missing, and goes to a false-positive line.
> 
> I remember some of the warning code explicitely excuses itself from
> even trying to deal with vectorized loads/stores, that might need to
> be revisited.  It would also be useful to verify whether the line
> info on the vectorized loads/stores is sensible (if you dump with
> -lineno you get stmts with line numbers).

Yes, it's this code in handle_mem_ref() in pointer-query.cc:

   if (VECTOR_TYPE_P (TREE_TYPE (mref)))
     {
       /* Hack: Handle MEM_REFs of vector types as those to complete
	 objects; those may be synthesized from multiple assignments
	 to consecutive data members (see PR 93200 and 96963).
	 FIXME: Vectorized assignments should only be present after
	 vectorization so this hack is only necessary after it has
	 run and could be avoided in calls from prior passes (e.g.,
	 tree-ssa-strlen.c).
	 FIXME: Deal with this more generally, e.g., by marking up
	 such MEM_REFs at the time they're created.  */
       ostype = 0;
     }

This code is used by both -Warray-bounds and -Wstringop-overflow
but because the former runs before vectorization the former isn't
affected by the auto-vectorization change.

> 
> It is of course impossible to preserve the location of all original
> scalar accesses exactly - it _might_ be possible to create a new
> location range (not sure how they are exactly represented), but then
> if we vectorize say
> 
>    a[0] = b[0];
>    a[1] = b[1];
> 
> we'd somehow get a multi-line location range that covers unrelated
> bits (the intermediate load or store).

This sounds like an interesting idea to explore, though I'm not
sure what we'd end up with if the stores were discontiguous (i.e.,
had unrelated statements in between).

> 
> So currently the vectorizer simply chooses the location of one of
> the scalar loads or stores for the vectorized access (and it might do
> so quite randomly).
> 
> Note I don't think it's feasible to not vectorize out-of-bound loads
> or stores for the same reason that you'll say you can't do the
> warnings all before vectorizing because the might expose themselves
> only later.

Sure, but it would be helpful to at least avoid vectorizing (as
well as store merging) the cases where the out-of-bounds access
is easily detectable.  As it is, the code I looked at makes no
effort to check.

> 
> So we simply have to cope with the reality that GCC is optimizing and
> that the later we perform analysis for warnings the more the original
> code is mangled.  As we moved array-bound warnings before unrolling
> so we should move this particular warning to before vectorization
> [loop optimization].

That makes sense.  See also my comment 7 on bug 102462 Hongtao
opened for this problem.  But just to be clear: I expect moving
these warnings won't be entirely straightforward.

Martin
Hongtao Liu Sept. 24, 2021, 3:32 a.m. UTC | #15
On Thu, Sep 23, 2021 at 11:18 PM Martin Sebor <msebor@gmail.com> wrote:
>
> On 9/23/21 12:30 AM, Richard Biener wrote:
> > On Thu, 23 Sep 2021, Hongtao Liu wrote:
> >
> >> On Thu, Sep 23, 2021 at 9:48 AM Hongtao Liu <crazylht@gmail.com> wrote:
> >>>
> >>> On Wed, Sep 22, 2021 at 10:21 PM Martin Sebor <msebor@gmail.com> wrote:
> >>>>
> >>>> On 9/21/21 7:38 PM, Hongtao Liu wrote:
> >>>>> On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
> >>>> ...
> >>>>>>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> >>>>>>>>> index 1d79930cd58..9351f7e7a1a 100644
> >>>>>>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> >>>>>>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> >>>>>>>>> @@ -1,7 +1,7 @@
> >>>>>>>>>     /* PR middle-end/91458 - inconsistent warning for writing past the end
> >>>>>>>>>        of an array member
> >>>>>>>>>        { dg-do compile }
> >>>>>>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> >>>>>>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> >>>>>>>>
> >>>>>>>> The testcase is large - what part requires this change?  Given the
> >>>>>>>> testcase was added for inconsistent warnings do they now become
> >>>>>>>> inconsistent again as we enable vectorization at -O2?
> >>>>>>>>
> >>>>>>>> That said, the testcase adjustments need some explaining - I suppose
> >>>>>>>> you didn't just slap -fno-tree-vectorize to all of those changing
> >>>>>>>> behavior?
> >>>>>>>>
> >>>>>>> void ga1_ (void)
> >>>>>>> {
> >>>>>>>      a1_.a[0] = 0;
> >>>>>>>      a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
> >>>>>>>      a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> >>>>>>>
> >>>>>>>      struct A1 a;
> >>>>>>>      a.a[0] = 0;
> >>>>>>>      a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
> >>>>>>>      a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
> >>>>>>>      sink (&a);
> >>>>>>> }
> >>>>>>>
> >>>>>>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> >>>>>>> there are 2 accesses, but after enabling vectorization, there's only
> >>>>>>> one access, so one warning is missing which causes the failure.
> >>>>
> >>>> With the stores vectorized, is the warning on the correct line or
> >>>> does it point to the first store, the one that's in bounds, as
> >>>> it does with -O3?  The latter would be a regression at -O2.
> >>> For the upper case, It points to the second store which is out of
> >>> bounds, the third store warning is missing.
> >>>>
> >>>>>>
> >>>>>> I would find it preferable to change the test code over disabling
> >>>>>> optimizations that are on by default.  My concern is that the test
> >>>>>> would no longer exercise the default behavior.  (The same goes for
> >>>>>> the -fno-ipa-icf option.)
> >>>>> Hmm, it's a middle-end test, for some backend, it may not do
> >>>>> vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
> >>>>> relative cost model).
> >>>>
> >>>> Yes, there are quite a few warning tests like that.  Their main
> >>>> purpose is to verify that in common GCC invocations (i.e., without
> >>>> any special options) warnings are a) issued when expected and b)
> >>>> not issued when not expected.  Otherwise, middle end warnings are
> >>>> known to have both false positives and false negatives in some
> >>>> invocations, depending on what optimizations are in effect.
> >>>> Indiscriminately disabling common optimizations for these large
> >>>> tests and invoking them under artificial conditions would
> >>>> compromise this goal and hide the problems.
> >>>>
> >>>> If enabling vectorization at -O2 causes regressions in the quality
> >>>> of diagnostics (as the test failure above indicates seems to be
> >>>> happening) we should investigate these and open bugs for them so
> >>>> they can be fixed.  We can then tweak the specific failing test
> >>>> cases to avoid the failures until they are fixed.
> >>> There are indeed cases of false positives and false negatives
> >>> .i.e.
> >>> // Verify warning for access to a definition with an initializer that
> >>> // initializes the one-element array member.
> >>> struct A1 a1i_1 = { 0, { 1 } };
> >>>
> >>> void ga1i_1 (void)
> >>> {
> >>>    a1i_1.a[0] = 0;
> >>>    a1i_1.a[1] = 1;               // { dg-warning "\\\[-Wstringop-overflow" }
> >>>    a1i_1.a[2] = 2;               // { dg-warning "\\\[-Wstringop-overflow" }
> >>>
> >>>    struct A1 a = { 0, { 1 } }; --- false positive here.
> >>>    a.a[0] = 1;
> >>>    a.a[1] = 2;                   // { dg-warning
> >>> "\\\[-Wstringop-overflow" } false negative here.
> >>>    a.a[2] = 3;                   // { dg-warning
> >>> "\\\[-Wstringop-overflow" } false negative here.
> >>>    sink (&a);
> >>> }
> >> Similar for
> >> * gcc.dg/Warray-bounds-51.c.
> >> * gcc.dg/Warray-parameter-3.c
> >> * gcc.dg/Wstringop-overflow-14.c
> >> * gcc.dg/Wstringop-overflow-21.c
> >>
> >> So there're 3 situations.
> >> 1. All accesses are out of bound, and after vectorization, there are
> >> some warnings missing.
> >> 2. Part of accesses are inbound, part of accesses are out of bound,
> >> and after vectorization, the warning goes from out of bound line to
> >> inbound line.
> >> 3. All access are out of bound, and after vectoriation, all warning
> >> are missing, and goes to a false-positive line.
My mistake, there's no case3, just case 1 and case2.
So i'm going to install the patch, ok?
> >
> > I remember some of the warning code explicitely excuses itself from
> > even trying to deal with vectorized loads/stores, that might need to
> > be revisited.  It would also be useful to verify whether the line
> > info on the vectorized loads/stores is sensible (if you dump with
> > -lineno you get stmts with line numbers).
>
> Yes, it's this code in handle_mem_ref() in pointer-query.cc:
>
>    if (VECTOR_TYPE_P (TREE_TYPE (mref)))
>      {
>        /* Hack: Handle MEM_REFs of vector types as those to complete
>          objects; those may be synthesized from multiple assignments
>          to consecutive data members (see PR 93200 and 96963).
>          FIXME: Vectorized assignments should only be present after
>          vectorization so this hack is only necessary after it has
>          run and could be avoided in calls from prior passes (e.g.,
>          tree-ssa-strlen.c).
>          FIXME: Deal with this more generally, e.g., by marking up
>          such MEM_REFs at the time they're created.  */
>        ostype = 0;
>      }
>
> This code is used by both -Warray-bounds and -Wstringop-overflow
> but because the former runs before vectorization the former isn't
> affected by the auto-vectorization change.
>
> >
> > It is of course impossible to preserve the location of all original
> > scalar accesses exactly - it _might_ be possible to create a new
> > location range (not sure how they are exactly represented), but then
> > if we vectorize say
> >
> >    a[0] = b[0];
> >    a[1] = b[1];
> >
> > we'd somehow get a multi-line location range that covers unrelated
> > bits (the intermediate load or store).
>
> This sounds like an interesting idea to explore, though I'm not
> sure what we'd end up with if the stores were discontiguous (i.e.,
> had unrelated statements in between).
>
> >
> > So currently the vectorizer simply chooses the location of one of
> > the scalar loads or stores for the vectorized access (and it might do
> > so quite randomly).
> >
> > Note I don't think it's feasible to not vectorize out-of-bound loads
> > or stores for the same reason that you'll say you can't do the
> > warnings all before vectorizing because the might expose themselves
> > only later.
>
> Sure, but it would be helpful to at least avoid vectorizing (as
> well as store merging) the cases where the out-of-bounds access
> is easily detectable.  As it is, the code I looked at makes no
> effort to check.
>
> >
> > So we simply have to cope with the reality that GCC is optimizing and
> > that the later we perform analysis for warnings the more the original
> > code is mangled.  As we moved array-bound warnings before unrolling
> > so we should move this particular warning to before vectorization
> > [loop optimization].
>
> That makes sense.  See also my comment 7 on bug 102462 Hongtao
> opened for this problem.  But just to be clear: I expect moving
> these warnings won't be entirely straightforward.
>
> Martin
Martin Sebor Sept. 24, 2021, 2:27 p.m. UTC | #16
On 9/23/21 9:32 PM, Hongtao Liu wrote:
> On Thu, Sep 23, 2021 at 11:18 PM Martin Sebor <msebor@gmail.com> wrote:
>>
>> On 9/23/21 12:30 AM, Richard Biener wrote:
>>> On Thu, 23 Sep 2021, Hongtao Liu wrote:
>>>
>>>> On Thu, Sep 23, 2021 at 9:48 AM Hongtao Liu <crazylht@gmail.com> wrote:
>>>>>
>>>>> On Wed, Sep 22, 2021 at 10:21 PM Martin Sebor <msebor@gmail.com> wrote:
>>>>>>
>>>>>> On 9/21/21 7:38 PM, Hongtao Liu wrote:
>>>>>>> On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
>>>>>> ...
>>>>>>>>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>>>>>>> index 1d79930cd58..9351f7e7a1a 100644
>>>>>>>>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>>>>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>>>>>>> @@ -1,7 +1,7 @@
>>>>>>>>>>>      /* PR middle-end/91458 - inconsistent warning for writing past the end
>>>>>>>>>>>         of an array member
>>>>>>>>>>>         { dg-do compile }
>>>>>>>>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
>>>>>>>>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
>>>>>>>>>>
>>>>>>>>>> The testcase is large - what part requires this change?  Given the
>>>>>>>>>> testcase was added for inconsistent warnings do they now become
>>>>>>>>>> inconsistent again as we enable vectorization at -O2?
>>>>>>>>>>
>>>>>>>>>> That said, the testcase adjustments need some explaining - I suppose
>>>>>>>>>> you didn't just slap -fno-tree-vectorize to all of those changing
>>>>>>>>>> behavior?
>>>>>>>>>>
>>>>>>>>> void ga1_ (void)
>>>>>>>>> {
>>>>>>>>>       a1_.a[0] = 0;
>>>>>>>>>       a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>>>       a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>>>
>>>>>>>>>       struct A1 a;
>>>>>>>>>       a.a[0] = 0;
>>>>>>>>>       a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>>>       a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>>>       sink (&a);
>>>>>>>>> }
>>>>>>>>>
>>>>>>>>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
>>>>>>>>> there are 2 accesses, but after enabling vectorization, there's only
>>>>>>>>> one access, so one warning is missing which causes the failure.
>>>>>>
>>>>>> With the stores vectorized, is the warning on the correct line or
>>>>>> does it point to the first store, the one that's in bounds, as
>>>>>> it does with -O3?  The latter would be a regression at -O2.
>>>>> For the upper case, It points to the second store which is out of
>>>>> bounds, the third store warning is missing.
>>>>>>
>>>>>>>>
>>>>>>>> I would find it preferable to change the test code over disabling
>>>>>>>> optimizations that are on by default.  My concern is that the test
>>>>>>>> would no longer exercise the default behavior.  (The same goes for
>>>>>>>> the -fno-ipa-icf option.)
>>>>>>> Hmm, it's a middle-end test, for some backend, it may not do
>>>>>>> vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
>>>>>>> relative cost model).
>>>>>>
>>>>>> Yes, there are quite a few warning tests like that.  Their main
>>>>>> purpose is to verify that in common GCC invocations (i.e., without
>>>>>> any special options) warnings are a) issued when expected and b)
>>>>>> not issued when not expected.  Otherwise, middle end warnings are
>>>>>> known to have both false positives and false negatives in some
>>>>>> invocations, depending on what optimizations are in effect.
>>>>>> Indiscriminately disabling common optimizations for these large
>>>>>> tests and invoking them under artificial conditions would
>>>>>> compromise this goal and hide the problems.
>>>>>>
>>>>>> If enabling vectorization at -O2 causes regressions in the quality
>>>>>> of diagnostics (as the test failure above indicates seems to be
>>>>>> happening) we should investigate these and open bugs for them so
>>>>>> they can be fixed.  We can then tweak the specific failing test
>>>>>> cases to avoid the failures until they are fixed.
>>>>> There are indeed cases of false positives and false negatives
>>>>> .i.e.
>>>>> // Verify warning for access to a definition with an initializer that
>>>>> // initializes the one-element array member.
>>>>> struct A1 a1i_1 = { 0, { 1 } };
>>>>>
>>>>> void ga1i_1 (void)
>>>>> {
>>>>>     a1i_1.a[0] = 0;
>>>>>     a1i_1.a[1] = 1;               // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>     a1i_1.a[2] = 2;               // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>
>>>>>     struct A1 a = { 0, { 1 } }; --- false positive here.
>>>>>     a.a[0] = 1;
>>>>>     a.a[1] = 2;                   // { dg-warning
>>>>> "\\\[-Wstringop-overflow" } false negative here.
>>>>>     a.a[2] = 3;                   // { dg-warning
>>>>> "\\\[-Wstringop-overflow" } false negative here.
>>>>>     sink (&a);
>>>>> }
>>>> Similar for
>>>> * gcc.dg/Warray-bounds-51.c.
>>>> * gcc.dg/Warray-parameter-3.c
>>>> * gcc.dg/Wstringop-overflow-14.c
>>>> * gcc.dg/Wstringop-overflow-21.c
>>>>
>>>> So there're 3 situations.
>>>> 1. All accesses are out of bound, and after vectorization, there are
>>>> some warnings missing.
>>>> 2. Part of accesses are inbound, part of accesses are out of bound,
>>>> and after vectorization, the warning goes from out of bound line to
>>>> inbound line.
>>>> 3. All access are out of bound, and after vectoriation, all warning
>>>> are missing, and goes to a false-positive line.
> My mistake, there's no case3, just case 1 and case2.
> So i'm going to install the patch, ok?

Please don't add the -fno- option to the warning tests.  As I said,
I would prefer to either suppress the vectorization for the failing
cases by tweaking the test code or xfail them.  That way future
regressions won't be masked by the option.  Once we've moved
the warning to a more suitable pass we'll add a new test to verify
it works as intended or remove the xfails.

Thanks
Martin

>>>
>>> I remember some of the warning code explicitely excuses itself from
>>> even trying to deal with vectorized loads/stores, that might need to
>>> be revisited.  It would also be useful to verify whether the line
>>> info on the vectorized loads/stores is sensible (if you dump with
>>> -lineno you get stmts with line numbers).
>>
>> Yes, it's this code in handle_mem_ref() in pointer-query.cc:
>>
>>     if (VECTOR_TYPE_P (TREE_TYPE (mref)))
>>       {
>>         /* Hack: Handle MEM_REFs of vector types as those to complete
>>           objects; those may be synthesized from multiple assignments
>>           to consecutive data members (see PR 93200 and 96963).
>>           FIXME: Vectorized assignments should only be present after
>>           vectorization so this hack is only necessary after it has
>>           run and could be avoided in calls from prior passes (e.g.,
>>           tree-ssa-strlen.c).
>>           FIXME: Deal with this more generally, e.g., by marking up
>>           such MEM_REFs at the time they're created.  */
>>         ostype = 0;
>>       }
>>
>> This code is used by both -Warray-bounds and -Wstringop-overflow
>> but because the former runs before vectorization the former isn't
>> affected by the auto-vectorization change.
>>
>>>
>>> It is of course impossible to preserve the location of all original
>>> scalar accesses exactly - it _might_ be possible to create a new
>>> location range (not sure how they are exactly represented), but then
>>> if we vectorize say
>>>
>>>     a[0] = b[0];
>>>     a[1] = b[1];
>>>
>>> we'd somehow get a multi-line location range that covers unrelated
>>> bits (the intermediate load or store).
>>
>> This sounds like an interesting idea to explore, though I'm not
>> sure what we'd end up with if the stores were discontiguous (i.e.,
>> had unrelated statements in between).
>>
>>>
>>> So currently the vectorizer simply chooses the location of one of
>>> the scalar loads or stores for the vectorized access (and it might do
>>> so quite randomly).
>>>
>>> Note I don't think it's feasible to not vectorize out-of-bound loads
>>> or stores for the same reason that you'll say you can't do the
>>> warnings all before vectorizing because the might expose themselves
>>> only later.
>>
>> Sure, but it would be helpful to at least avoid vectorizing (as
>> well as store merging) the cases where the out-of-bounds access
>> is easily detectable.  As it is, the code I looked at makes no
>> effort to check.
>>
>>>
>>> So we simply have to cope with the reality that GCC is optimizing and
>>> that the later we perform analysis for warnings the more the original
>>> code is mangled.  As we moved array-bound warnings before unrolling
>>> so we should move this particular warning to before vectorization
>>> [loop optimization].
>>
>> That makes sense.  See also my comment 7 on bug 102462 Hongtao
>> opened for this problem.  But just to be clear: I expect moving
>> these warnings won't be entirely straightforward.
>>
>> Martin
> 
> 
>
Aldy Hernandez Oct. 8, 2021, 10:49 a.m. UTC | #17
On Thu, Sep 23, 2021 at 8:32 AM Richard Biener via Gcc-patches
<gcc-patches@gcc.gnu.org> wrote:
>
> On Thu, 23 Sep 2021, Hongtao Liu wrote:
>
> > On Thu, Sep 23, 2021 at 9:48 AM Hongtao Liu <crazylht@gmail.com> wrote:
> > >
> > > On Wed, Sep 22, 2021 at 10:21 PM Martin Sebor <msebor@gmail.com> wrote:
> > > >
> > > > On 9/21/21 7:38 PM, Hongtao Liu wrote:
> > > > > On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
> > > > ...
> > > > >>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > >>>>> index 1d79930cd58..9351f7e7a1a 100644
> > > > >>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > >>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
> > > > >>>>> @@ -1,7 +1,7 @@
> > > > >>>>>    /* PR middle-end/91458 - inconsistent warning for writing past the end
> > > > >>>>>       of an array member
> > > > >>>>>       { dg-do compile }
> > > > >>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
> > > > >>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
> > > > >>>>
> > > > >>>> The testcase is large - what part requires this change?  Given the
> > > > >>>> testcase was added for inconsistent warnings do they now become
> > > > >>>> inconsistent again as we enable vectorization at -O2?
> > > > >>>>
> > > > >>>> That said, the testcase adjustments need some explaining - I suppose
> > > > >>>> you didn't just slap -fno-tree-vectorize to all of those changing
> > > > >>>> behavior?
> > > > >>>>
> > > > >>> void ga1_ (void)
> > > > >>> {
> > > > >>>     a1_.a[0] = 0;
> > > > >>>     a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > > > >>>     a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
> > > > >>>
> > > > >>>     struct A1 a;
> > > > >>>     a.a[0] = 0;
> > > > >>>     a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > > > >>>     a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
> > > > >>>     sink (&a);
> > > > >>> }
> > > > >>>
> > > > >>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
> > > > >>> there are 2 accesses, but after enabling vectorization, there's only
> > > > >>> one access, so one warning is missing which causes the failure.
> > > >
> > > > With the stores vectorized, is the warning on the correct line or
> > > > does it point to the first store, the one that's in bounds, as
> > > > it does with -O3?  The latter would be a regression at -O2.
> > > For the upper case, It points to the second store which is out of
> > > bounds, the third store warning is missing.
> > > >
> > > > >>
> > > > >> I would find it preferable to change the test code over disabling
> > > > >> optimizations that are on by default.  My concern is that the test
> > > > >> would no longer exercise the default behavior.  (The same goes for
> > > > >> the -fno-ipa-icf option.)
> > > > > Hmm, it's a middle-end test, for some backend, it may not do
> > > > > vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
> > > > > relative cost model).
> > > >
> > > > Yes, there are quite a few warning tests like that.  Their main
> > > > purpose is to verify that in common GCC invocations (i.e., without
> > > > any special options) warnings are a) issued when expected and b)
> > > > not issued when not expected.  Otherwise, middle end warnings are
> > > > known to have both false positives and false negatives in some
> > > > invocations, depending on what optimizations are in effect.
> > > > Indiscriminately disabling common optimizations for these large
> > > > tests and invoking them under artificial conditions would
> > > > compromise this goal and hide the problems.
> > > >
> > > > If enabling vectorization at -O2 causes regressions in the quality
> > > > of diagnostics (as the test failure above indicates seems to be
> > > > happening) we should investigate these and open bugs for them so
> > > > they can be fixed.  We can then tweak the specific failing test
> > > > cases to avoid the failures until they are fixed.
> > > There are indeed cases of false positives and false negatives
> > > .i.e.
> > > // Verify warning for access to a definition with an initializer that
> > > // initializes the one-element array member.
> > > struct A1 a1i_1 = { 0, { 1 } };
> > >
> > > void ga1i_1 (void)
> > > {
> > >   a1i_1.a[0] = 0;
> > >   a1i_1.a[1] = 1;               // { dg-warning "\\\[-Wstringop-overflow" }
> > >   a1i_1.a[2] = 2;               // { dg-warning "\\\[-Wstringop-overflow" }
> > >
> > >   struct A1 a = { 0, { 1 } }; --- false positive here.
> > >   a.a[0] = 1;
> > >   a.a[1] = 2;                   // { dg-warning
> > > "\\\[-Wstringop-overflow" } false negative here.
> > >   a.a[2] = 3;                   // { dg-warning
> > > "\\\[-Wstringop-overflow" } false negative here.
> > >   sink (&a);
> > > }
> > Similar for
> > * gcc.dg/Warray-bounds-51.c.
> > * gcc.dg/Warray-parameter-3.c
> > * gcc.dg/Wstringop-overflow-14.c
> > * gcc.dg/Wstringop-overflow-21.c
> >
> > So there're 3 situations.
> > 1. All accesses are out of bound, and after vectorization, there are
> > some warnings missing.
> > 2. Part of accesses are inbound, part of accesses are out of bound,
> > and after vectorization, the warning goes from out of bound line to
> > inbound line.
> > 3. All access are out of bound, and after vectoriation, all warning
> > are missing, and goes to a false-positive line.
>
> I remember some of the warning code explicitely excuses itself from
> even trying to deal with vectorized loads/stores, that might need to
> be revisited.  It would also be useful to verify whether the line
> info on the vectorized loads/stores is sensible (if you dump with
> -lineno you get stmts with line numbers).
>
> It is of course impossible to preserve the location of all original
> scalar accesses exactly - it _might_ be possible to create a new
> location range (not sure how they are exactly represented), but then
> if we vectorize say
>
>   a[0] = b[0];
>   a[1] = b[1];
>
> we'd somehow get a multi-line location range that covers unrelated
> bits (the intermediate load or store).
>
> So currently the vectorizer simply chooses the location of one of
> the scalar loads or stores for the vectorized access (and it might do
> so quite randomly).
>
> Note I don't think it's feasible to not vectorize out-of-bound loads
> or stores for the same reason that you'll say you can't do the
> warnings all before vectorizing because the might expose themselves
> only later.
>
> So we simply have to cope with the reality that GCC is optimizing and
> that the later we perform analysis for warnings the more the original
> code is mangled.  As we moved array-bound warnings before unrolling
> so we should move this particular warning to before vectorization
> [loop optimization].

Sorry I'm late to the party here...

Couldn't we run warnings earlier?

A while back, I converted the array bounds checker to the generic
range_query API, so it could be used either with the vr_values object
from the VRP pass, or with a ranger.  There's no reason it should be
tied to VRP.  We could make it its own pass and move it somewhere more
sensible.

Aldy
Martin Sebor Oct. 8, 2021, 11:43 p.m. UTC | #18
On 10/8/21 4:49 AM, Aldy Hernandez via Gcc-patches wrote:
> On Thu, Sep 23, 2021 at 8:32 AM Richard Biener via Gcc-patches
> <gcc-patches@gcc.gnu.org> wrote:
>>
>> On Thu, 23 Sep 2021, Hongtao Liu wrote:
>>
>>> On Thu, Sep 23, 2021 at 9:48 AM Hongtao Liu <crazylht@gmail.com> wrote:
>>>>
>>>> On Wed, Sep 22, 2021 at 10:21 PM Martin Sebor <msebor@gmail.com> wrote:
>>>>>
>>>>> On 9/21/21 7:38 PM, Hongtao Liu wrote:
>>>>>> On Mon, Sep 20, 2021 at 4:13 AM Martin Sebor <msebor@gmail.com> wrote:
>>>>> ...
>>>>>>>>>> diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>>>>>> index 1d79930cd58..9351f7e7a1a 100644
>>>>>>>>>> --- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>>>>>> +++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
>>>>>>>>>> @@ -1,7 +1,7 @@
>>>>>>>>>>     /* PR middle-end/91458 - inconsistent warning for writing past the end
>>>>>>>>>>        of an array member
>>>>>>>>>>        { dg-do compile }
>>>>>>>>>> -   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
>>>>>>>>>> +   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
>>>>>>>>>
>>>>>>>>> The testcase is large - what part requires this change?  Given the
>>>>>>>>> testcase was added for inconsistent warnings do they now become
>>>>>>>>> inconsistent again as we enable vectorization at -O2?
>>>>>>>>>
>>>>>>>>> That said, the testcase adjustments need some explaining - I suppose
>>>>>>>>> you didn't just slap -fno-tree-vectorize to all of those changing
>>>>>>>>> behavior?
>>>>>>>>>
>>>>>>>> void ga1_ (void)
>>>>>>>> {
>>>>>>>>      a1_.a[0] = 0;
>>>>>>>>      a1_.a[1] = 1;                 // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>>      a1_.a[2] = 2;                 // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>>
>>>>>>>>      struct A1 a;
>>>>>>>>      a.a[0] = 0;
>>>>>>>>      a.a[1] = 1;                   // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>>      a.a[2] = 2;                   // { dg-warning "\\\[-Wstringop-overflow" }
>>>>>>>>      sink (&a);
>>>>>>>> }
>>>>>>>>
>>>>>>>> It's supposed to be 2 warning for a.a[1] = 1 and a.a[2] = 1 since
>>>>>>>> there are 2 accesses, but after enabling vectorization, there's only
>>>>>>>> one access, so one warning is missing which causes the failure.
>>>>>
>>>>> With the stores vectorized, is the warning on the correct line or
>>>>> does it point to the first store, the one that's in bounds, as
>>>>> it does with -O3?  The latter would be a regression at -O2.
>>>> For the upper case, It points to the second store which is out of
>>>> bounds, the third store warning is missing.
>>>>>
>>>>>>>
>>>>>>> I would find it preferable to change the test code over disabling
>>>>>>> optimizations that are on by default.  My concern is that the test
>>>>>>> would no longer exercise the default behavior.  (The same goes for
>>>>>>> the -fno-ipa-icf option.)
>>>>>> Hmm, it's a middle-end test, for some backend, it may not do
>>>>>> vectorization(it depends on TARGET_VECTOR_MODE_SUPPORTED_P and
>>>>>> relative cost model).
>>>>>
>>>>> Yes, there are quite a few warning tests like that.  Their main
>>>>> purpose is to verify that in common GCC invocations (i.e., without
>>>>> any special options) warnings are a) issued when expected and b)
>>>>> not issued when not expected.  Otherwise, middle end warnings are
>>>>> known to have both false positives and false negatives in some
>>>>> invocations, depending on what optimizations are in effect.
>>>>> Indiscriminately disabling common optimizations for these large
>>>>> tests and invoking them under artificial conditions would
>>>>> compromise this goal and hide the problems.
>>>>>
>>>>> If enabling vectorization at -O2 causes regressions in the quality
>>>>> of diagnostics (as the test failure above indicates seems to be
>>>>> happening) we should investigate these and open bugs for them so
>>>>> they can be fixed.  We can then tweak the specific failing test
>>>>> cases to avoid the failures until they are fixed.
>>>> There are indeed cases of false positives and false negatives
>>>> .i.e.
>>>> // Verify warning for access to a definition with an initializer that
>>>> // initializes the one-element array member.
>>>> struct A1 a1i_1 = { 0, { 1 } };
>>>>
>>>> void ga1i_1 (void)
>>>> {
>>>>    a1i_1.a[0] = 0;
>>>>    a1i_1.a[1] = 1;               // { dg-warning "\\\[-Wstringop-overflow" }
>>>>    a1i_1.a[2] = 2;               // { dg-warning "\\\[-Wstringop-overflow" }
>>>>
>>>>    struct A1 a = { 0, { 1 } }; --- false positive here.
>>>>    a.a[0] = 1;
>>>>    a.a[1] = 2;                   // { dg-warning
>>>> "\\\[-Wstringop-overflow" } false negative here.
>>>>    a.a[2] = 3;                   // { dg-warning
>>>> "\\\[-Wstringop-overflow" } false negative here.
>>>>    sink (&a);
>>>> }
>>> Similar for
>>> * gcc.dg/Warray-bounds-51.c.
>>> * gcc.dg/Warray-parameter-3.c
>>> * gcc.dg/Wstringop-overflow-14.c
>>> * gcc.dg/Wstringop-overflow-21.c
>>>
>>> So there're 3 situations.
>>> 1. All accesses are out of bound, and after vectorization, there are
>>> some warnings missing.
>>> 2. Part of accesses are inbound, part of accesses are out of bound,
>>> and after vectorization, the warning goes from out of bound line to
>>> inbound line.
>>> 3. All access are out of bound, and after vectoriation, all warning
>>> are missing, and goes to a false-positive line.
>>
>> I remember some of the warning code explicitely excuses itself from
>> even trying to deal with vectorized loads/stores, that might need to
>> be revisited.  It would also be useful to verify whether the line
>> info on the vectorized loads/stores is sensible (if you dump with
>> -lineno you get stmts with line numbers).
>>
>> It is of course impossible to preserve the location of all original
>> scalar accesses exactly - it _might_ be possible to create a new
>> location range (not sure how they are exactly represented), but then
>> if we vectorize say
>>
>>    a[0] = b[0];
>>    a[1] = b[1];
>>
>> we'd somehow get a multi-line location range that covers unrelated
>> bits (the intermediate load or store).
>>
>> So currently the vectorizer simply chooses the location of one of
>> the scalar loads or stores for the vectorized access (and it might do
>> so quite randomly).
>>
>> Note I don't think it's feasible to not vectorize out-of-bound loads
>> or stores for the same reason that you'll say you can't do the
>> warnings all before vectorizing because the might expose themselves
>> only later.
>>
>> So we simply have to cope with the reality that GCC is optimizing and
>> that the later we perform analysis for warnings the more the original
>> code is mangled.  As we moved array-bound warnings before unrolling
>> so we should move this particular warning to before vectorization
>> [loop optimization].
> 
> Sorry I'm late to the party here...
> 
> Couldn't we run warnings earlier?

Yes, we could.

> 
> A while back, I converted the array bounds checker to the generic
> range_query API, so it could be used either with the vr_values object
> from the VRP pass, or with a ranger.  There's no reason it should be
> tied to VRP.  We could make it its own pass and move it somewhere more
> sensible.

The warning here (-Wstringop-overflow) comes from the strlen pass
which runs after vectorization which is why we lose the accurate
location for individual stores.  VRP runs before it, so
-Warray-bounds doesn't suffer from the same problem.

Running the strlen subset of -Wstringop-overflow earlier will avoid
the problem:
https://gcc.gnu.org/pipermail/gcc-patches/2021-September/580040.html

It shouldn't even be necessary to move it -- -Warray-bounds should
be enough.  I think the only difference is that -Wstringop-overflow
for plain char assignments respects subobject boundaries while
-Warray-bounds does not (for accesses of any type).  That's a hack
to avoid some false positives so if we can find some other way to
avoid those we can improve -Warray-bounds and get rid of
-Wstringop-overflow for direct char stores (the warning was
meant for built-in string functions but it has grown to encompass
direct stores as well).

That said, it is useful to distinguish out-of-bounds reads from
out-of-bounds writes.  -Wstringop-overflow and -Wstringop-overread
make that possible.  -Warray-bounds doesn't.  So maybe we also need
to enhance -Warry-bounds and add the corresponding modes.

Martin

> 
> Aldy
>
diff mbox series

Patch

diff --git a/gcc/common.opt b/gcc/common.opt
index b921f5e3b25..4f2c0294c29 100644
--- a/gcc/common.opt
+++ b/gcc/common.opt
@@ -3031,7 +3031,7 @@  Perform variable tracking and also tag variables that are uninitialized.
 
 ; Alias to enable both -ftree-loop-vectorize and -ftree-slp-vectorize.
 ftree-vectorize
-Common Optimization
+Common Var(flag_tree_vectorize) Optimization
 Enable vectorization on trees.
 
 ftree-vectorizer-verbose=
diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
index 78cfc100ac2..be022ef8024 100644
--- a/gcc/doc/invoke.texi
+++ b/gcc/doc/invoke.texi
@@ -10409,9 +10409,13 @@  also turns on the following optimization flags:
 -fstrict-aliasing @gol
 -fthread-jumps @gol
 -ftree-builtin-call-dce @gol
+-ftree-loop-vectorize @gol
 -ftree-pre @gol
+-ftree-slp-vectorize @gol
 -ftree-switch-conversion  -ftree-tail-merge @gol
--ftree-vrp}
+-ftree-vrp @gol
+-fvect-cost-model @gol
+-fvect-cost-model=very-cheap}
 
 Please note the warning under @option{-fgcse} about
 invoking @option{-O2} on programs that use computed gotos.
@@ -10431,9 +10435,7 @@  by @option{-O2} and also turns on the following optimization flags:
 -fsplit-loops @gol
 -fsplit-paths @gol
 -ftree-loop-distribution @gol
--ftree-loop-vectorize @gol
 -ftree-partial-pre @gol
--ftree-slp-vectorize @gol
 -funswitch-loops @gol
 -fvect-cost-model @gol
 -fvect-cost-model=dynamic @gol
diff --git a/gcc/opts.c b/gcc/opts.c
index 1d2d22d7a3f..cee372a3235 100644
--- a/gcc/opts.c
+++ b/gcc/opts.c
@@ -634,7 +634,8 @@  static const struct default_options default_options_table[] =
     { OPT_LEVELS_2_PLUS, OPT_ftree_switch_conversion, NULL, 1 },
     { OPT_LEVELS_2_PLUS, OPT_ftree_tail_merge, NULL, 1 },
     { OPT_LEVELS_2_PLUS, OPT_ftree_vrp, NULL, 1 },
-    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_CHEAP },
+    { OPT_LEVELS_2_PLUS, OPT_fvect_cost_model_, NULL,
+      VECT_COST_MODEL_VERY_CHEAP },
     { OPT_LEVELS_2_PLUS, OPT_finline_functions, NULL, 1 },
     { OPT_LEVELS_2_PLUS, OPT_ftree_loop_distribute_patterns, NULL, 1 },
 
@@ -646,6 +647,9 @@  static const struct default_options default_options_table[] =
     { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_foptimize_strlen, NULL, 1 },
     { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_freorder_blocks_algorithm_, NULL,
       REORDER_BLOCKS_ALGORITHM_STC },
+    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_loop_vectorize, NULL, 1 },
+    { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_ftree_slp_vectorize, NULL, 1 },
+
 #ifdef INSN_SCHEDULING
   /* Only run the pre-regalloc scheduling pass if optimizing for speed.  */
     { OPT_LEVELS_2_PLUS_SPEED_ONLY, OPT_fschedule_insns, NULL, 1 },
@@ -663,9 +667,7 @@  static const struct default_options default_options_table[] =
     { OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
     { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
     { OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
-    { OPT_LEVELS_3_PLUS, OPT_ftree_loop_vectorize, NULL, 1 },
     { OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
-    { OPT_LEVELS_3_PLUS, OPT_ftree_slp_vectorize, NULL, 1 },
     { OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
     { OPT_LEVELS_3_PLUS, OPT_fvect_cost_model_, NULL, VECT_COST_MODEL_DYNAMIC },
     { OPT_LEVELS_3_PLUS, OPT_fversion_loops_for_strides, NULL, 1 },
@@ -1331,6 +1333,16 @@  finish_options (struct gcc_options *opts, struct gcc_options *opts_set,
       = (opts->x_flag_unroll_loops
          || opts->x_flag_peel_loops
          || opts->x_optimize >= 3);
+
+  /* Use -fvect-cost-model=cheap instead of -fvect-cost-mode=very-cheap
+     by default with explicit -ftree-{loop,slp}-vectorize.  */
+  if (opts->x_optimize == 2
+      && (opts_set->x_flag_tree_loop_vectorize
+	  || opts_set->x_flag_tree_vectorize))
+    SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
+			 VECT_COST_MODEL_CHEAP);
+
+
 }
 
 #define LEFT_COLUMN	27
diff --git a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
index 1d79930cd58..9351f7e7a1a 100644
--- a/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
+++ b/gcc/testsuite/c-c++-common/Wstringop-overflow-2.c
@@ -1,7 +1,7 @@ 
 /* PR middle-end/91458 - inconsistent warning for writing past the end
    of an array member
    { dg-do compile }
-   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf" } */
+   { dg-options "-O2 -Wall -Wno-array-bounds -fno-ipa-icf -fno-tree-vectorize" } */
 
 void sink (void*);
 
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
index 39e32fd4bc9..bc14309480c 100644
--- a/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr81408.C
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed" } */
+/* { dg-options "-O2 -std=gnu++11 -fopt-info-loop-missed -fno-tree-vectorize" } */
 struct p
 {
   char *ay;
diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
index 49ee878806a..60e8dd4f0e2 100644
--- a/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
+++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-13.C
@@ -1,6 +1,6 @@ 
 /* PR c/98597 - ICE in -Wuninitialized printing a MEM_REF
    { dg-do compile }
-   { dg-options "-O2 -Wall" } */
+   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
 
 struct shared_count {
   shared_count () { }
diff --git a/gcc/testsuite/gcc.dg/Warray-bounds-51.c b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
index 6028b11637c..8b81a0ccfa7 100644
--- a/gcc/testsuite/gcc.dg/Warray-bounds-51.c
+++ b/gcc/testsuite/gcc.dg/Warray-bounds-51.c
@@ -1,7 +1,7 @@ 
 /* PR middle-end/92333 - missing variable name referencing VLA in warnings
    PR middle-end/82608 - missing -Warray-bounds on an out-of-bounds VLA index
    { dg-do compile }
-   { dg-options "-O2 -Wall" } */
+   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
 
 void sink (void*);
 
diff --git a/gcc/testsuite/gcc.dg/Warray-parameter-3.c b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
index cbf3e9339f5..fbef715aa99 100644
--- a/gcc/testsuite/gcc.dg/Warray-parameter-3.c
+++ b/gcc/testsuite/gcc.dg/Warray-parameter-3.c
@@ -59,7 +59,7 @@  void fas1 (int[static 2]);    // { dg-warning "\\\[-Warray-parameter=" }
 
 /* Also verify that -Warray-bounds doesn't trigger for ordinary array
    parameters...  */
-#pragma GCC optimize "2"
+#pragma GCC optimize ("2,-fno-tree-vectorize")
 
 __attribute__ ((noipa)) void
 gca3 (char a[3])
diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
index bd513151cea..a78242bf26e 100644
--- a/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
+++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-13.c
@@ -3,7 +3,7 @@ 
    PR middle-end/89911 - ICE on a call with no arguments to strnlen
    declared with no prototype
    { dg-do compile }
-   { dg-options "-O2 -Wall" } */
+   { dg-options "-O2 -Wall -fno-tree-vectorize" } */
 
 typedef __SIZE_TYPE__ size_t;
 
diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
index d6201b068b6..808bf87c386 100644
--- a/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
+++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-14.c
@@ -2,7 +2,7 @@ 
    types than char are diagnosed.
    { dg-do compile }
    { dg-require-effective-target int32plus }
-   { dg-options "-O2 -Wall -Wno-array-bounds" } */
+   { dg-options "-O2 -fno-tree-vectorize -Wall -Wno-array-bounds" } */
 
 typedef __INT16_TYPE__  int16_t;
 typedef __INT32_TYPE__  int32_t;
diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
index 3a27460220c..f418a17ca93 100644
--- a/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
+++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-21.c
@@ -1,7 +1,7 @@ 
 /* PR middle-end/92312 - bogus -Wstringop-overflow storing into a trailing
    array backed by larger buffer
    { dg-do compile }
-   { dg-options "-O2 -Wall -Wno-array-bounds" } */
+   { dg-options "-O2 -Wall -Wno-array-bounds -fno-tree-vectorize" } */
 
 struct S0 { char a, b[0]; };
 
diff --git a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
index 6bcba274541..7cc1012130c 100644
--- a/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
+++ b/gcc/testsuite/gcc.dg/Wstringop-overflow-68.c
@@ -2,7 +2,7 @@ 
    a larger scalar into a smaller array
    Verify overflow by aggregate stores.
    { dg-do compile }
-   { dg-options "-O2" } */
+   { dg-options "-O2 -fno-tree-vectorize" } */
 
 #define A(N) (A ## N)
 #define Ac1 (AC1){ 0 }
diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
index e110880bd8e..2e562618489 100644
--- a/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
+++ b/gcc/testsuite/gcc.dg/gomp/pr46032-2.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
 
 #define N 2
 
diff --git a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
index a4af7ec4a8a..da1ab487385 100644
--- a/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
+++ b/gcc/testsuite/gcc.dg/gomp/pr46032-3.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fopenmp -std=c99 -fipa-pta -fdump-tree-optimized" } */
 
 #define N 2
 
diff --git a/gcc/testsuite/gcc.dg/gomp/simd-2.c b/gcc/testsuite/gcc.dg/gomp/simd-2.c
index 85acb980f10..f4912127b81 100644
--- a/gcc/testsuite/gcc.dg/gomp/simd-2.c
+++ b/gcc/testsuite/gcc.dg/gomp/simd-2.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
+/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
 /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
 /* { dg-additional-options "-mavx" { target avx } } */
 /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
diff --git a/gcc/testsuite/gcc.dg/gomp/simd-3.c b/gcc/testsuite/gcc.dg/gomp/simd-3.c
index 86fee858673..c75060c07ae 100644
--- a/gcc/testsuite/gcc.dg/gomp/simd-3.c
+++ b/gcc/testsuite/gcc.dg/gomp/simd-3.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fopenmp -fdump-tree-vect-details" } */
+/* { dg-options "-O2 -fopenmp -fvect-cost-model=cheap -fdump-tree-vect-details" } */
 /* { dg-additional-options "-msse2" { target { i?86-*-* x86_64-*-* } } } */
 /* { dg-additional-options "-mavx" { target avx } } */
 /* { dg-final { scan-tree-dump-times "vectorized \[1-9]\[0-9]* loops in function" 5 "vect" { target i?86-*-* x86_64-*-* aarch64-*-* } } } */
diff --git a/gcc/testsuite/gcc.dg/graphite/fuse-1.c b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
index 527b6e5c415..61289d312c2 100644
--- a/gcc/testsuite/gcc.dg/graphite/fuse-1.c
+++ b/gcc/testsuite/gcc.dg/graphite/fuse-1.c
@@ -1,6 +1,6 @@ 
 /* Check that the two loops are fused and that we manage to fold the two xor
    operations.  */
-/* { dg-options "-O2 -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
+/* { dg-options "-O2 -fno-tree-vectorize -floop-nest-optimize -fdump-tree-forwprop4 -fdump-tree-graphite-all" } */
 
 /* Make sure we fuse the loops like this:
 AST generated by isl:
diff --git a/gcc/testsuite/gcc.dg/pr67089-6.c b/gcc/testsuite/gcc.dg/pr67089-6.c
index db2ffdfeca4..b59d75b2318 100644
--- a/gcc/testsuite/gcc.dg/pr67089-6.c
+++ b/gcc/testsuite/gcc.dg/pr67089-6.c
@@ -1,6 +1,6 @@ 
 /* PR target/67089 */
 /* { dg-do compile } */
-/* { dg-options "-O2 -ftree-loop-if-convert -fdump-tree-widening_mul" } */
+/* { dg-options "-O2 -fno-tree-vectorize -ftree-loop-if-convert -fdump-tree-widening_mul" } */
 
 extern void abort (void);
 
diff --git a/gcc/testsuite/gcc.dg/pr82929-2.c b/gcc/testsuite/gcc.dg/pr82929-2.c
index 3442f91af02..b886f1cce76 100644
--- a/gcc/testsuite/gcc.dg/pr82929-2.c
+++ b/gcc/testsuite/gcc.dg/pr82929-2.c
@@ -1,6 +1,6 @@ 
 /* PR tree-optimization/82929 */
 /* { dg-do compile { target store_merge } } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 void
 foo (short *p, short *q, short *r)
diff --git a/gcc/testsuite/gcc.dg/pr82929.c b/gcc/testsuite/gcc.dg/pr82929.c
index bb84f2b21a3..123e1919cec 100644
--- a/gcc/testsuite/gcc.dg/pr82929.c
+++ b/gcc/testsuite/gcc.dg/pr82929.c
@@ -1,6 +1,6 @@ 
 /* PR tree-optimization/82929 */
 /* { dg-do compile { target store_merge } } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 void
 foo (short *p, short *q, short *r)
diff --git a/gcc/testsuite/gcc.dg/store_merging_1.c b/gcc/testsuite/gcc.dg/store_merging_1.c
index 4cc43dfd9e1..91ca925be0e 100644
--- a/gcc/testsuite/gcc.dg/store_merging_1.c
+++ b/gcc/testsuite/gcc.dg/store_merging_1.c
@@ -1,6 +1,6 @@ 
 /* { dg-do compile } */
 /* { dg-require-effective-target store_merge } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 struct bar {
   int a;
diff --git a/gcc/testsuite/gcc.dg/store_merging_11.c b/gcc/testsuite/gcc.dg/store_merging_11.c
index 2ec2394afb9..60ed5cd8bf9 100644
--- a/gcc/testsuite/gcc.dg/store_merging_11.c
+++ b/gcc/testsuite/gcc.dg/store_merging_11.c
@@ -1,6 +1,6 @@ 
 /* { dg-do run } */
 /* { dg-require-effective-target store_merge } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 struct S { unsigned char b[2]; unsigned short c; unsigned char d[4]; unsigned long e; };
 
diff --git a/gcc/testsuite/gcc.dg/store_merging_15.c b/gcc/testsuite/gcc.dg/store_merging_15.c
index acd7de571f8..13fcca4aa11 100644
--- a/gcc/testsuite/gcc.dg/store_merging_15.c
+++ b/gcc/testsuite/gcc.dg/store_merging_15.c
@@ -1,6 +1,6 @@ 
 /* { dg-do run } */
 /* { dg-require-effective-target store_merge } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 struct S { unsigned char a, b; unsigned short c; unsigned char d, e, f, g; unsigned long long h; };
 
diff --git a/gcc/testsuite/gcc.dg/store_merging_16.c b/gcc/testsuite/gcc.dg/store_merging_16.c
index 9545dcce3de..cd83f1c0fe5 100644
--- a/gcc/testsuite/gcc.dg/store_merging_16.c
+++ b/gcc/testsuite/gcc.dg/store_merging_16.c
@@ -2,7 +2,7 @@ 
    are either big or little endian (not pdp endian).  */
 /* { dg-do run { target { lp64 && { i?86-*-* x86_64-*-* powerpc*-*-* aarch64*-*-* } } } } */
 /* { dg-require-effective-target store_merge } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 __attribute__((noipa)) void
 f1 (unsigned char *p, unsigned long long q)
diff --git a/gcc/testsuite/gcc.dg/store_merging_19.c b/gcc/testsuite/gcc.dg/store_merging_19.c
index 0841bb4deee..0a2bbc4bfde 100644
--- a/gcc/testsuite/gcc.dg/store_merging_19.c
+++ b/gcc/testsuite/gcc.dg/store_merging_19.c
@@ -1,6 +1,6 @@ 
 /* PR tree-optimization/83843 */
 /* { dg-do run } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 /* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" { target store_merge } } } */
 
 __attribute__((noipa)) void
diff --git a/gcc/testsuite/gcc.dg/store_merging_24.c b/gcc/testsuite/gcc.dg/store_merging_24.c
index 744fe60e8e0..5291bb9e986 100644
--- a/gcc/testsuite/gcc.dg/store_merging_24.c
+++ b/gcc/testsuite/gcc.dg/store_merging_24.c
@@ -1,6 +1,6 @@ 
 /* PR tree-optimization/87859 */
 /* { dg-do run } */
-/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
 /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 19 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
 /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
 
diff --git a/gcc/testsuite/gcc.dg/store_merging_25.c b/gcc/testsuite/gcc.dg/store_merging_25.c
index cf182190e91..96611b5e57b 100644
--- a/gcc/testsuite/gcc.dg/store_merging_25.c
+++ b/gcc/testsuite/gcc.dg/store_merging_25.c
@@ -1,6 +1,6 @@ 
 /* PR tree-optimization/87859 */
 /* { dg-do run } */
-/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
 /* { dg-final { scan-tree-dump "New sequence of \[23] stores to replace old one of 14 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
 /* { dg-final { scan-tree-dump "New sequence of 1 stores to replace old one of 6 stores" "store-merging" { target i?86-*-* x86_64-*-* } } } */
 
diff --git a/gcc/testsuite/gcc.dg/store_merging_28.c b/gcc/testsuite/gcc.dg/store_merging_28.c
index 2d6cffc4694..fadb7fff993 100644
--- a/gcc/testsuite/gcc.dg/store_merging_28.c
+++ b/gcc/testsuite/gcc.dg/store_merging_28.c
@@ -1,7 +1,7 @@ 
 /* PR tree-optimization/88709 */
 /* { dg-do compile } */
 /* { dg-require-effective-target store_merge } */
-/* { dg-options "-O2 -fno-ipa-icf -fdump-tree-store-merging-details" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fno-ipa-icf -fdump-tree-store-merging-details" } */
 /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 16 stores" 8 "store-merging" { target { i?86-*-* x86_64-*-* } } } } */
 /* { dg-final { scan-tree-dump-times "New sequence of \[24] stores to replace old one of 6 stores" 1 "store-merging" { target { ! arm*-*-* } } } } */
 
diff --git a/gcc/testsuite/gcc.dg/store_merging_30.c b/gcc/testsuite/gcc.dg/store_merging_30.c
index 694d560a621..baf94efe733 100644
--- a/gcc/testsuite/gcc.dg/store_merging_30.c
+++ b/gcc/testsuite/gcc.dg/store_merging_30.c
@@ -1,7 +1,7 @@ 
 /* PR tree-optimization/94573 */
 /* { dg-do compile } */
 /* { dg-require-effective-target store_merge } */
-/* { dg-options "-O2 -fdump-tree-store-merging-details" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging-details" } */
 /* { dg-final { scan-tree-dump "New sequence of 4 stores to replace old one of 8 stores" "store-merging" { target lp64 } } } */
 
 int var[43][12];
diff --git a/gcc/testsuite/gcc.dg/store_merging_5.c b/gcc/testsuite/gcc.dg/store_merging_5.c
index 6e7c72510ff..b0cb0da78e0 100644
--- a/gcc/testsuite/gcc.dg/store_merging_5.c
+++ b/gcc/testsuite/gcc.dg/store_merging_5.c
@@ -1,6 +1,6 @@ 
 /* { dg-do compile } */
 /* { dg-require-effective-target store_merge } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 /* Make sure that non-aliasing non-constant interspersed stores do not
    stop chains.  */
diff --git a/gcc/testsuite/gcc.dg/store_merging_7.c b/gcc/testsuite/gcc.dg/store_merging_7.c
index c744ece6407..dbe000a463e 100644
--- a/gcc/testsuite/gcc.dg/store_merging_7.c
+++ b/gcc/testsuite/gcc.dg/store_merging_7.c
@@ -1,6 +1,6 @@ 
 /* { dg-do compile } */
 /* { dg-require-effective-target store_merge } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 /* Check that we can merge consecutive array members through the pointer.
    PR rtl-optimization/23684.  */
diff --git a/gcc/testsuite/gcc.dg/store_merging_8.c b/gcc/testsuite/gcc.dg/store_merging_8.c
index e710a544ff0..d719e0a2257 100644
--- a/gcc/testsuite/gcc.dg/store_merging_8.c
+++ b/gcc/testsuite/gcc.dg/store_merging_8.c
@@ -1,6 +1,6 @@ 
 /* { dg-do compile } */
 /* { dg-require-effective-target store_merge } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 struct baz {
   struct bar {
diff --git a/gcc/testsuite/gcc.dg/strlenopt-85.c b/gcc/testsuite/gcc.dg/strlenopt-85.c
index e049e0c30e0..2ba1ee05700 100644
--- a/gcc/testsuite/gcc.dg/strlenopt-85.c
+++ b/gcc/testsuite/gcc.dg/strlenopt-85.c
@@ -4,7 +4,7 @@ 
    of memory allocated by calloc() even if one or more nul bytes are
    written into it.
    { dg-do compile }
-   { dg-options "-O2 -fdump-tree-optimized" } */
+   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
 
 unsigned n0, n1;
 
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
index 70659c00c0e..6c803908781 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/dump-6.c
@@ -1,6 +1,6 @@ 
 /* PR middle-end/90676 - default GIMPLE dumps lack information
    { dg-do compile }
-   { dg-options "-O2 -fdump-tree-store-merging" }
+   { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" }
    { dg-require-effective-target int32plus }
    { dg-require-effective-target store_merge } */
 
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
index 50d86a00485..b9e40e964c1 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/pr19210-1.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fopt-info-loop-missed" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fopt-info-loop-missed" } */
 extern void g(void);
 
 void
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
index 9f9c61aa213..860cde12c0f 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/pr47059.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-Os -fdump-tree-optimized" } */
+/* { dg-options "-Os -fno-tree-vectorize -fdump-tree-optimized" } */
 
 
 struct struct1
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
index f216e83c7b3..c7ef73ad59e 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/pr86017.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-store-merging" } */
 
 void f (void*);
 
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
index 7d6a724e4ad..0ddad573129 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/pr91482.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fdump-tree-ccp1 -fdump-tree-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-ccp1 -fdump-tree-store-merging" } */
 
 void write64 (void *p)
 {
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
index f68be2b3379..8c3d9a4fc58 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-1.c
@@ -1,6 +1,6 @@ 
 /* { dg-do compile } */
 /* { dg-do run } */
-/* { dg-options "-O2 -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
+/* { dg-options "-O2 -fno-tree-vectorize -funroll-loops --param max-unroll-times=8 -fpredictive-commoning -fdump-tree-pcom-details" } */
 
 void abort (void);
 
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
index ec08d6c0318..1fc8f089345 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/predcom-dse-3.c
@@ -1,5 +1,5 @@ 
 /* { dg-do run } */
-/* { dg-options "-O2 -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fno-inline -fno-tree-loop-distribute-patterns -fpredictive-commoning -fdump-tree-pcom-details" } */
 
 int arr1[105] = {2, 3, 5, 7, 11, 13, 0};
 int arr2[105] = {2, 3, 5, 7, 11, 13, 0};
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
index 467903bf3fc..46f0d0c2317 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-3.c
@@ -1,7 +1,7 @@ 
 /* Prefetching used to prefer nonsensical unroll factor of 5 in this testcase.  */
 
 /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
-/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 -fdump-tree-aprefetch-details" } */
 
 #define N 1000000
 
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
index 12f09016943..3fa71685ace 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-6.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
-/* { dg-options "-O2 -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 --param min-insn-to-prefetch-ratio=6 -fdump-tree-aprefetch-details" } */
 
 #define N 1000
 #define K 900
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
index cbd6a80d345..00f41c3e4f4 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-8.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
-/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
 
 #define K 1000000
 int a[K];
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
index da4847320b1..e8848c30acc 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/prefetch-9.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */
-/* { dg-options "-O2 -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fno-tree-loop-distribute-patterns -fprefetch-loop-arrays -march=amdfam10 --param simultaneous-prefetches=100 -fdump-tree-aprefetch-details -fdump-tree-optimized" } */
 
 #define K 1000000
 int a[K], b[K];
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
index 92b2df80ec8..2e7b5b496ea 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-18.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fdump-tree-optimized" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
 int g(_Complex int*);
 int f(void)
 {
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
index 718b7466e50..7bb8d060631 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
+++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dse-19.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fdump-tree-optimized" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-optimized" } */
 int g(_Complex int*);
 int f(void)
 {
diff --git a/gcc/testsuite/gcc.dg/uninit-40.c b/gcc/testsuite/gcc.dg/uninit-40.c
index c015191ca32..8708079d397 100644
--- a/gcc/testsuite/gcc.dg/uninit-40.c
+++ b/gcc/testsuite/gcc.dg/uninit-40.c
@@ -1,6 +1,6 @@ 
 /* PR tree-optimization/98597 */
 /* { dg-do compile } */
-/* { dg-options "-O2 -Wuninitialized" } */
+/* { dg-options "-O2 -fno-tree-vectorize -Wuninitialized" } */
 
 union U { double d; int i; float f; };
 struct S { char a; int b; char c; unsigned d; union U e; int f[3]; unsigned g[3]; };
diff --git a/gcc/testsuite/gcc.dg/unroll-7.c b/gcc/testsuite/gcc.dg/unroll-7.c
index 055369bf8b1..695af5757cc 100644
--- a/gcc/testsuite/gcc.dg/unroll-7.c
+++ b/gcc/testsuite/gcc.dg/unroll-7.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fdump-rtl-loop2_unroll-details -funroll-loops" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-rtl-loop2_unroll-details -funroll-loops" } */
 /* { dg-require-effective-target int32plus } */
 
 extern int *a;
diff --git a/gcc/testsuite/gcc.misc-tests/help.exp b/gcc/testsuite/gcc.misc-tests/help.exp
index 5e034d26947..eb6d8686c6a 100644
--- a/gcc/testsuite/gcc.misc-tests/help.exp
+++ b/gcc/testsuite/gcc.misc-tests/help.exp
@@ -79,7 +79,7 @@  check_for_options c "--help=target,optimizers" "" "" ""
 check_for_options c "--help=warnings,^joined,^undocumented" "" "" ""
 check_for_options c "-Q -O2 --help=optimizers" {
 -O
--ftree-loop-vectorize[^\n]*disabled
+-ftree-loop-vectorize[^\n]*enabled
 } "  -g  " ""
 check_for_options c "-Q -O3 --help=optimizers" {
 -O
diff --git a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
index 709cd21e671..a732bc466db 100644
--- a/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
+++ b/gcc/testsuite/gcc.target/i386/avx512vpopcntdqvl-vpopcntd-1.c
@@ -1,5 +1,5 @@ 
 /* { dg-do run } */
-/* { dg-options "-O2 -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
+/* { dg-options "-O2 -fno-tree-vectorize -mavx512vpopcntdq -mavx512bw -mavx512vl" } */
 /* { dg-require-effective-target avx512vl } */
 /* { dg-require-effective-target avx512vpopcntdqvl } */
 /* { dg-require-effective-target avx512bw } */
diff --git a/gcc/testsuite/gcc.target/i386/pr22141.c b/gcc/testsuite/gcc.target/i386/pr22141.c
index 036422e8ccf..b68b97f3f72 100644
--- a/gcc/testsuite/gcc.target/i386/pr22141.c
+++ b/gcc/testsuite/gcc.target/i386/pr22141.c
@@ -1,6 +1,6 @@ 
 /* PR middle-end/22141 */
 /* { dg-do compile } */
-/* { dg-options "-Os" } */
+/* { dg-options "-Os -fno-tree-vectorize" } */
 
 extern void abort (void);
 
diff --git a/gcc/testsuite/gcc.target/i386/pr34012.c b/gcc/testsuite/gcc.target/i386/pr34012.c
index d0cffa05290..1c1f0eea52e 100644
--- a/gcc/testsuite/gcc.target/i386/pr34012.c
+++ b/gcc/testsuite/gcc.target/i386/pr34012.c
@@ -1,7 +1,7 @@ 
 /* PR rtl-optimization/34012 */
 /* { dg-do compile } */
 /* { dg-require-effective-target lp64 } */
-/* { dg-options "-O2 -fno-store-merging" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fno-store-merging" } */
 
 void bar (long int *);
 void
diff --git a/gcc/testsuite/gcc.target/i386/pr49781-1.c b/gcc/testsuite/gcc.target/i386/pr49781-1.c
index 60f9d50d866..d5a2e32db97 100644
--- a/gcc/testsuite/gcc.target/i386/pr49781-1.c
+++ b/gcc/testsuite/gcc.target/i386/pr49781-1.c
@@ -1,5 +1,5 @@ 
 /* { dg-do compile } */
-/* { dg-options "-O2 -fpic -mtune=generic" } */
+/* { dg-options "-O2 -fno-tree-vectorize -fpic -mtune=generic" } */
 /* { dg-require-effective-target fpic } */
 
 static int heap[2*(256 +1+29)+1];
diff --git a/gcc/testsuite/gcc.target/i386/pr95798-1.c b/gcc/testsuite/gcc.target/i386/pr95798-1.c
index 9a7e32d6f2f..526f48921fd 100644
--- a/gcc/testsuite/gcc.target/i386/pr95798-1.c
+++ b/gcc/testsuite/gcc.target/i386/pr95798-1.c
@@ -1,6 +1,6 @@ 
 /* PR target/95798 */
 /* { dg-do compile } */
-/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
+/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
 /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
 /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
 /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
diff --git a/gcc/testsuite/gcc.target/i386/pr95798-2.c b/gcc/testsuite/gcc.target/i386/pr95798-2.c
index c670d3780e8..6b5c5a73e96 100644
--- a/gcc/testsuite/gcc.target/i386/pr95798-2.c
+++ b/gcc/testsuite/gcc.target/i386/pr95798-2.c
@@ -1,6 +1,6 @@ 
 /* PR target/95798 */
 /* { dg-do compile } */
-/* { dg-options "-O2 -masm=att -fomit-frame-pointer" } */
+/* { dg-options "-O2 -fno-tree-vectorize -masm=att -fomit-frame-pointer" } */
 /* { dg-final { scan-assembler "1, 8\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
 /* { dg-final { scan-assembler "2, 16\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
 /* { dg-final { scan-assembler "3, 24\\\(%rsp,%r\[a-z0-9]*,8\\\)" { target lp64 } } } */
diff --git a/gcc/testsuite/gfortran.dg/pr77498.f b/gcc/testsuite/gfortran.dg/pr77498.f
index f957b57bb00..a0fc8275a84 100644
--- a/gcc/testsuite/gfortran.dg/pr77498.f
+++ b/gcc/testsuite/gfortran.dg/pr77498.f
@@ -1,5 +1,5 @@ 
 ! { dg-do compile }
-! { dg-options "-O2 -ffast-math -fdump-tree-pre" }
+! { dg-options "-O2 -fno-tree-vectorize -ffast-math -fdump-tree-pre" }
 
       subroutine foo(U,V,R,N,A)
       integer N