https://gcc.gnu.org/bugzilla/show_bug.cgi?id=103485
Richard Biener <rguenth at gcc dot gnu.org> changed:
What |Removed |Added
----------------------------------------------------------------------------
Last reconfirmed| |2021-11-30
Status|UNCONFIRMED |ASSIGNED
Priority|P3 |P1
Ever confirmed|0 |1
Target| |x86_64-*-*
Assignee|unassigned at gcc dot gnu.org |rguenth at gcc dot
gnu.org
Target Milestone|--- |12.0
--- Comment #1 from Richard Biener <rguenth at gcc dot gnu.org> ---
Confirmed.
(gdb) p debug_gimple_stmt (stmt)
_12 = (vector(8) signed int) foo_v256u8_0.0_1;
$1 = void
(gdb) p debug_tree (gimple_assign_lhs (stmt))
<ssa_name 0x7ffff66ab3a8
type <vector_type 0x7ffff66a5348
type <integer_type 0x7ffff66a52a0 SI
size <integer_cst 0x7ffff6543f90 constant 32>
unit-size <integer_cst 0x7ffff6543fa8 constant 4>
align:32 warn_if_not_align:0 symtab:0 alias-set 2 canonical-type
0x7ffff66a52a0 precision:32 min <integer_cst 0x7ffff6562438 -2147483648> max
<integer_cst 0x7ffff66b0570 2147483647>>
BLK
size <integer_cst 0x7ffff65620c0 constant 256>
unit-size <integer_cst 0x7ffff65621b0 constant 32>
align:256 warn_if_not_align:0 symtab:0 alias-set 2 canonical-type
0x7ffff66a5348 nunits:8>
visited
def_stmt _12 = (vector(8) signed int) foo_v256u8_0.0_1;
version:12>
$2 = void
(gdb) p debug_tree (gimple_assign_rhs1 (stmt))
<ssa_name 0x7ffff654ed80
type <vector_type 0x7ffff667abd0
type <integer_type 0x7ffff655e690 unsigned int public unsigned SI
size <integer_cst 0x7ffff6543f90 constant 32>
unit-size <integer_cst 0x7ffff6543fa8 constant 4>
align:32 warn_if_not_align:0 symtab:0 alias-set -1 canonical-type
0x7ffff655e690 precision:32 min <integer_cst 0x7ffff6543fc0 0> max <integer_cst
0x7ffff6543f78 4294967295>
pointer_to_this <pointer_type 0x7ffff656e1f8>>
unsigned BLK
size <integer_cst 0x7ffff65620c0 constant 256>
unit-size <integer_cst 0x7ffff65621b0 constant 32>
align:256 warn_if_not_align:0 symtab:0 alias-set 1 canonical-type
0x7ffff667abd0 nunits:8
pointer_to_this <pointer_type 0x7ffff66a51f8>>
visited
def_stmt foo_v256u8_0.0_1 = foo_v256u8_0;
version:1>
$3 = void
the issue is that we introduce a non-V_C_E vector conversion in
forwprop3 that is not supported by the target and vector lowering is
not supporting lowering of such conversions.
/* Fold -((int)x >> (prec - 1)) into (unsigned)x >> (prec - 1). */
(simplify
(negate (convert? (rshift @0 INTEGER_CST@1)))
(if (tree_nop_conversion_p (type, TREE_TYPE (@0))
&& wi::to_wide (@1) == element_precision (type) - 1)
(with { tree stype = TREE_TYPE (@0);
tree ntype = TYPE_UNSIGNED (stype) ? signed_type_for (stype)
: unsigned_type_for (stype); }
(convert (rshift:ntype (convert:ntype @0) @1)))))
is the pattern responsible. For vector types this needs to check availability
of (convert ...) support or alternatively use VIEW_CONVERT.