aboutsummaryrefslogtreecommitdiff
path: root/gcc/expr.cc
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2024-01-10 14:54:10 +0100
committerRichard Biener <rguenther@suse.de>2024-01-11 09:09:46 +0100
commite1f2d58a1e2536f13d3f2ea2d7373ae62cec9125 (patch)
tree7ee4abd90951906b38825b0bc5f95e2c913a3bcc /gcc/expr.cc
parent1a51886a79c97e53ba945c1926ab215ed6a9f5ed (diff)
downloadgcc-e1f2d58a1e2536f13d3f2ea2d7373ae62cec9125.zip
gcc-e1f2d58a1e2536f13d3f2ea2d7373ae62cec9125.tar.gz
gcc-e1f2d58a1e2536f13d3f2ea2d7373ae62cec9125.tar.bz2
middle-end/112740 - vector boolean CTOR expansion issue
The optimization to expand uniform boolean vectors by sign-extension works only for dense masks but it failed to check that. PR middle-end/112740 * expr.cc (store_constructor): Check the integer vector mask has a single bit per element before using sign-extension to expand an uniform vector. * gcc.dg/pr112740.c: New testcase.
Diffstat (limited to 'gcc/expr.cc')
-rw-r--r--gcc/expr.cc8
1 files changed, 5 insertions, 3 deletions
diff --git a/gcc/expr.cc b/gcc/expr.cc
index dc816bc..0bf8083 100644
--- a/gcc/expr.cc
+++ b/gcc/expr.cc
@@ -7841,10 +7841,12 @@ store_constructor (tree exp, rtx target, int cleared, poly_int64 size,
break;
}
/* Use sign-extension for uniform boolean vectors with
- integer modes. Effectively "vec_duplicate" for bitmasks. */
- if (!TREE_SIDE_EFFECTS (exp)
+ integer modes and single-bit mask entries.
+ Effectively "vec_duplicate" for bitmasks. */
+ if (elt_size == 1
+ && !TREE_SIDE_EFFECTS (exp)
&& VECTOR_BOOLEAN_TYPE_P (type)
- && SCALAR_INT_MODE_P (mode)
+ && SCALAR_INT_MODE_P (TYPE_MODE (type))
&& (elt = uniform_vector_p (exp))
&& !VECTOR_TYPE_P (TREE_TYPE (elt)))
{