diff options
author | Fei Yang <felix.yang@huawei.com> | 2020-04-27 11:08:04 +0100 |
---|---|---|
committer | Richard Sandiford <richard.sandiford@arm.com> | 2020-04-27 11:08:04 +0100 |
commit | 5328710be314dee43da8027dbff547d48b85e35e (patch) | |
tree | 0f46d7f00baf8311a781d1d411cb858da977bab2 /gcc/tree-ssa-forwprop.c | |
parent | acdf733634745548c0167c40bad80e6140ac2eeb (diff) | |
download | gcc-5328710be314dee43da8027dbff547d48b85e35e.zip gcc-5328710be314dee43da8027dbff547d48b85e35e.tar.gz gcc-5328710be314dee43da8027dbff547d48b85e35e.tar.bz2 |
forwprop: Fix ICE when building an identity constructor [PR94784]
In the testcase for PR94784, we have two vectors with the same ABI identity
but with different TYPE_MODEs. It would be better to flip the assert around
so that it checks that the two vectors have equal TYPE_VECTOR_SUBPARTS and
that converting the corresponding element types is a useless_type_conversion_p.
2020-04-27 Felix Yang <felix.yang@huawei.com>
gcc/
PR tree-optimization/94784
* tree-ssa-forwprop.c (simplify_vector_constructor): Flip the
assert around so that it checks that the two vectors have equal
TYPE_VECTOR_SUBPARTS and that converting the corresponding element
types is a useless_type_conversion_p.
gcc/testsuite/
PR tree-optimization/94784
* gcc.dg/pr94784.c: New test.
Diffstat (limited to 'gcc/tree-ssa-forwprop.c')
-rw-r--r-- | gcc/tree-ssa-forwprop.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/gcc/tree-ssa-forwprop.c b/gcc/tree-ssa-forwprop.c index 8ee5450..4358732 100644 --- a/gcc/tree-ssa-forwprop.c +++ b/gcc/tree-ssa-forwprop.c @@ -2479,7 +2479,10 @@ simplify_vector_constructor (gimple_stmt_iterator *gsi) tree src_type = TREE_TYPE (orig[0]); if (!useless_type_conversion_p (type, src_type)) { - gcc_assert (!targetm.compatible_vector_types_p (type, src_type)); + gcc_assert (known_eq (TYPE_VECTOR_SUBPARTS (type), + TYPE_VECTOR_SUBPARTS (src_type)) + && useless_type_conversion_p (TREE_TYPE (type), + TREE_TYPE (src_type))); tree rhs = build1 (VIEW_CONVERT_EXPR, type, orig[0]); orig[0] = make_ssa_name (type); gassign *assign = gimple_build_assign (orig[0], rhs); @@ -2611,7 +2614,10 @@ simplify_vector_constructor (gimple_stmt_iterator *gsi) res = gimple_build (&stmts, conv_code, type, res); else if (!useless_type_conversion_p (type, TREE_TYPE (res))) { - gcc_assert (!targetm.compatible_vector_types_p (type, perm_type)); + gcc_assert (known_eq (TYPE_VECTOR_SUBPARTS (type), + TYPE_VECTOR_SUBPARTS (perm_type)) + && useless_type_conversion_p (TREE_TYPE (type), + TREE_TYPE (perm_type))); res = gimple_build (&stmts, VIEW_CONVERT_EXPR, type, res); } /* Blend in the actual constant. */ |