diff options
author | xuli <xuli1@eswincomputing.com> | 2024-11-12 02:31:28 +0000 |
---|---|---|
committer | xuli <xuli1@eswincomputing.com> | 2024-11-13 04:12:18 +0000 |
commit | 445d8bb6a89eb2275c4930ec87a98d5123e5abdd (patch) | |
tree | 5476901adaed04ee46f0eb7ab11801352746381c /fixincludes | |
parent | eeb5c6acf7198f057419b4d4bce34b58b12c2287 (diff) | |
download | gcc-445d8bb6a89eb2275c4930ec87a98d5123e5abdd.zip gcc-445d8bb6a89eb2275c4930ec87a98d5123e5abdd.tar.gz gcc-445d8bb6a89eb2275c4930ec87a98d5123e5abdd.tar.bz2 |
RISC-V: Bugfix for max_sew_overlap_and_next_ratio_valid_for_prev_sew_p[pr117483]
This patch fixs https://gcc.gnu.org/bugzilla/show_bug.cgi?id=117483
If prev and next satisfy the following rules, we should forbid the case
(next.get_sew() < prev.get_sew() && (!next.get_ta() || !next.get_ma()))
in the compatible function max_sew_overlap_and_next_ratio_valid_for_prev_sew_p.
Otherwise, the tail elements of next will be polluted.
DEF_SEW_LMUL_RULE (ge_sew, ratio_and_ge_sew, ratio_and_ge_sew,
max_sew_overlap_and_next_ratio_valid_for_prev_sew_p,
always_false, use_max_sew_and_lmul_with_next_ratio)
Passed the rv64gcv full regression test.
Signed-off-by: Li Xu <xuli1@eswincomputing.com>
PR target/117483
gcc/ChangeLog:
* config/riscv/riscv-vsetvl.cc: Fix bug.
gcc/testsuite/ChangeLog:
* gcc.target/riscv/pr117483.c: New test.
Diffstat (limited to 'fixincludes')
0 files changed, 0 insertions, 0 deletions