vect: Restore optab_vector argument [PR106250]
In g:76c3041b856cb0 I'd removed a "C ? optab_vector : optab_mixed_sign" argument from a call to directly_supported_p, thinking that the argument only existed because of the condition (which I was removing). But the difference between the scalar and vector forms matters for shifts, so we do still need the argument. gcc/ PR tree-optimization/106250 * tree-vect-loop.cc (vectorizable_reduction): Reinstate final argument to directly_supported_p.
This commit is contained in:
parent
cb7b01db7a
commit
e7a7fed818
2 changed files with 18 additions and 1 deletions
17
gcc/testsuite/gcc.dg/vect/pr106250.c
Normal file
17
gcc/testsuite/gcc.dg/vect/pr106250.c
Normal file
|
@ -0,0 +1,17 @@
|
|||
/* { dg-do compile } */
|
||||
|
||||
int
|
||||
foo (unsigned long int x, int y, int z)
|
||||
{
|
||||
int ret = 0;
|
||||
|
||||
while (y < 1)
|
||||
{
|
||||
x *= 2;
|
||||
ret = x == z;
|
||||
z = y;
|
||||
++y;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
|
@ -7369,7 +7369,7 @@ vectorizable_reduction (loop_vec_info loop_vinfo,
|
|||
dot-products. */
|
||||
machine_mode vec_mode = TYPE_MODE (vectype_in);
|
||||
if (!lane_reduc_code_p
|
||||
&& !directly_supported_p (op.code, vectype_in))
|
||||
&& !directly_supported_p (op.code, vectype_in, optab_vector))
|
||||
{
|
||||
if (dump_enabled_p ())
|
||||
dump_printf (MSG_NOTE, "op not supported by target.\n");
|
||||
|
|
Loading…
Add table
Reference in a new issue