Commit 414fef4e by Richard Biener Committed by Richard Biener

re PR target/84278 (claims initv4sfv2sf is available but inits through stack)

2018-02-08  Richard Biener  <rguenther@suse.de>

	PR tree-optimization/84278
	* tree-vect-stmts.c (vectorizable_store): When looking for
	smaller vector types to perform grouped strided loads/stores
	make sure the mode is supported by the target.
	(vectorizable_load): Likewise.

	* gcc.target/i386/pr84278.c: New testcase.

From-SVN: r257483
parent 3f26f054
2018-02-08 Richard Biener <rguenther@suse.de>
PR tree-optimization/84278
* tree-vect-stmts.c (vectorizable_store): When looking for
smaller vector types to perform grouped strided loads/stores
make sure the mode is supported by the target.
(vectorizable_load): Likewise.
2018-02-08 Wilco Dijkstra <wdijkstr@arm.com> 2018-02-08 Wilco Dijkstra <wdijkstr@arm.com>
* config/aarch64/aarch64.c (aarch64_components_for_bb): * config/aarch64/aarch64.c (aarch64_components_for_bb):
......
2018-02-08 Richard Biener <rguenther@suse.de>
PR tree-optimization/84278
* gcc.target/i386/pr84278.c: New testcase.
2018-02-08 Wilco Dijkstra <wdijkstr@arm.com> 2018-02-08 Wilco Dijkstra <wdijkstr@arm.com>
PR rtl-optimization/84068 PR rtl-optimization/84068
......
/* { dg-do compile } */
/* { dg-options "-O3 -msse2" } */
float A[1024];
float B[1024];
int s;
void foo(void)
{
int i;
for (i = 0; i < 128; i++)
{
B[i*2+0] = A[i*s+0];
B[i*2+1] = A[i*s+1];
}
}
/* { dg-final { scan-assembler-not "\(%.sp\)" } } */
...@@ -6510,6 +6510,7 @@ vectorizable_store (gimple *stmt, gimple_stmt_iterator *gsi, gimple **vec_stmt, ...@@ -6510,6 +6510,7 @@ vectorizable_store (gimple *stmt, gimple_stmt_iterator *gsi, gimple **vec_stmt,
machine_mode vmode; machine_mode vmode;
if (!mode_for_vector (elmode, group_size).exists (&vmode) if (!mode_for_vector (elmode, group_size).exists (&vmode)
|| !VECTOR_MODE_P (vmode) || !VECTOR_MODE_P (vmode)
|| !targetm.vector_mode_supported_p (vmode)
|| (convert_optab_handler (vec_extract_optab, || (convert_optab_handler (vec_extract_optab,
TYPE_MODE (vectype), vmode) TYPE_MODE (vectype), vmode)
== CODE_FOR_nothing)) == CODE_FOR_nothing))
...@@ -6528,6 +6529,7 @@ vectorizable_store (gimple *stmt, gimple_stmt_iterator *gsi, gimple **vec_stmt, ...@@ -6528,6 +6529,7 @@ vectorizable_store (gimple *stmt, gimple_stmt_iterator *gsi, gimple **vec_stmt,
element size stores. */ element size stores. */
if (mode_for_vector (elmode, lnunits).exists (&vmode) if (mode_for_vector (elmode, lnunits).exists (&vmode)
&& VECTOR_MODE_P (vmode) && VECTOR_MODE_P (vmode)
&& targetm.vector_mode_supported_p (vmode)
&& (convert_optab_handler (vec_extract_optab, && (convert_optab_handler (vec_extract_optab,
vmode, elmode) vmode, elmode)
!= CODE_FOR_nothing)) != CODE_FOR_nothing))
...@@ -7573,6 +7575,7 @@ vectorizable_load (gimple *stmt, gimple_stmt_iterator *gsi, gimple **vec_stmt, ...@@ -7573,6 +7575,7 @@ vectorizable_load (gimple *stmt, gimple_stmt_iterator *gsi, gimple **vec_stmt,
machine_mode vmode; machine_mode vmode;
if (mode_for_vector (elmode, group_size).exists (&vmode) if (mode_for_vector (elmode, group_size).exists (&vmode)
&& VECTOR_MODE_P (vmode) && VECTOR_MODE_P (vmode)
&& targetm.vector_mode_supported_p (vmode)
&& (convert_optab_handler (vec_init_optab, && (convert_optab_handler (vec_init_optab,
TYPE_MODE (vectype), vmode) TYPE_MODE (vectype), vmode)
!= CODE_FOR_nothing)) != CODE_FOR_nothing))
...@@ -7598,6 +7601,7 @@ vectorizable_load (gimple *stmt, gimple_stmt_iterator *gsi, gimple **vec_stmt, ...@@ -7598,6 +7601,7 @@ vectorizable_load (gimple *stmt, gimple_stmt_iterator *gsi, gimple **vec_stmt,
element loads of the original vector type. */ element loads of the original vector type. */
if (mode_for_vector (elmode, lnunits).exists (&vmode) if (mode_for_vector (elmode, lnunits).exists (&vmode)
&& VECTOR_MODE_P (vmode) && VECTOR_MODE_P (vmode)
&& targetm.vector_mode_supported_p (vmode)
&& (convert_optab_handler (vec_init_optab, vmode, elmode) && (convert_optab_handler (vec_init_optab, vmode, elmode)
!= CODE_FOR_nothing)) != CODE_FOR_nothing))
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment