aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-vect-patterns.cc
diff options
context:
space:
mode:
authorPan Li <pan2.li@intel.com>2023-06-13 23:19:14 +0800
committerPan Li <pan2.li@intel.com>2023-06-15 09:05:18 +0800
commit8a3a4fb273f9c69b8f9f6c303508610d34b3ebf1 (patch)
treed6e3c489a2def4a83d466df9829b786d58956cef /gcc/tree-vect-patterns.cc
parentc1c5edef33e3307296af244f50f9256472c69c09 (diff)
downloadgcc-8a3a4fb273f9c69b8f9f6c303508610d34b3ebf1.zip
gcc-8a3a4fb273f9c69b8f9f6c303508610d34b3ebf1.tar.gz
gcc-8a3a4fb273f9c69b8f9f6c303508610d34b3ebf1.tar.bz2
RISC-V: Bugfix for vec_init repeating auto vectorization in RV32
When constructing a vector mask from individual elements we wrongly assumed that we can broadcast BITS_PER_WORD (i.e. XLEN). The maximum is actually the vector element length (i.e. ELEN). This patch fixes this. After this patch, below failures on RV32 will be fixed. FAIL: gcc.target/riscv/rvv/autovec/partial/multiple_rgroup_run-2.c execution test FAIL: gcc.target/riscv/rvv/autovec/partial/multiple_rgroup_run-2.c execution test FAIL: gcc.target/riscv/rvv/autovec/partial/multiple_rgroup_run-2.c execution test FAIL: gcc.target/riscv/rvv/autovec/partial/multiple_rgroup_run-2.c execution test FAIL: gcc.target/riscv/rvv/autovec/vls-vlmax/repeat_run-3.c -std=c99 -O3 -ftree-vectorize --param riscv-autovec-preference=fixed-vlmax execution test Signed-off-by: Pan Li <pan2.li@intel.com> gcc/ChangeLog: * config/riscv/riscv-v.cc (rvv_builder::get_merge_scalar_mask): Take elen instead of scalar BITS_PER_WORD. (expand_vector_init_merge_repeating_sequence): Use inner_bits_size instead of scaler BITS_PER_WORD.
Diffstat (limited to 'gcc/tree-vect-patterns.cc')
0 files changed, 0 insertions, 0 deletions