aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-ssa-phiopt.cc
diff options
context:
space:
mode:
authorJuzhe-Zhong <juzhe.zhong@rivai.ai>2023-07-18 14:27:39 +0800
committerLehua Ding <lehua.ding@rivai.ai>2023-07-18 18:53:24 +0800
commitbd93ef7f1a178079c6cdaccdf953f79a3365b028 (patch)
tree1f65f3c405808b85f4bb259e809800418ad37980 /gcc/tree-ssa-phiopt.cc
parent0a9f30c50a1ee539372fb4f6db3e8db229fc2ff8 (diff)
downloadgcc-bd93ef7f1a178079c6cdaccdf953f79a3365b028.zip
gcc-bd93ef7f1a178079c6cdaccdf953f79a3365b028.tar.gz
gcc-bd93ef7f1a178079c6cdaccdf953f79a3365b028.tar.bz2
RISC-V: Dynamic adjust size of VLA vector according to TARGET_MIN_VLEN
This patch is to dynamic adjust size of VLA vectors according to TARGET_MIN_VLEN (-march=*zvl*b). Currently, VNx16QImode is always [16,16] when TARGET_MINV_LEN >= 128. We are going to add a bunch of VLS modes (V16QI,V32QI,....etc), these modes should always be considered as having smaller size than VLA vectors. For example, the V32QImode is LMUL = 1 VLS mode when TARGET_MIN_VLEN = 256 and V16QImode is LMUL = 1 VLS mode when TARGET_MINV_LEN = 128. Since a LMUL = 1 VLA mode VNx16QI is always [16,16] before this patch, when TARGET_MIN_VLEN = 128, VNx16QImode ([16,16]) > V16QImode. when TARGET_MIN_VLEN = 256, VNx16QImode ([16,16]) possible < V32QImode. Then such inconsistency (TARGET_MIN_VLEN = 128, regno_reg_rtx[97] is VLA modes wheras it is VLS modes when TARGET_MIN_VLEN = 256). This patch now adjust VLA vector size accurately according to TARGET_MIN_VLEN which make things more reasonable: VNx16QI = [16,16] if TARGET_MIN_VLEN = 128. VNx16QI = [32,32] if TARGET_MIN_VLEN = 256. VNx16QI = [64,64] if TARGET_MIN_VLEN = 512. VNx16QI = [128,128] if TARGET_MIN_VLEN = 1024. VNx16QI = [256,256] if TARGET_MIN_VLEN = 2048. VNx16QI = [512,512] if TARGET_MIN_VLEN = 4096. gcc/ChangeLog: * config/riscv/riscv-selftests.cc (run_poly_int_selftests): Add more selftests. * config/riscv/riscv.cc (riscv_legitimize_poly_move): Dynamic adjust size of VLA vectors. (riscv_convert_vector_bits): Ditto. gcc/testsuite/ChangeLog: * gcc.target/riscv/rvv/autovec/zve32f_zvl1024b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve32f_zvl2048b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve32f_zvl256b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve32f_zvl4096b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve32f_zvl512b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve32x_zvl1024b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve32x_zvl2048b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve32x_zvl256b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve32x_zvl4096b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve32x_zvl512b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64d_zvl1024b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64d_zvl2048b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64d_zvl256b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64d_zvl4096b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64d_zvl512b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64f_zvl1024b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64f_zvl2048b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64f_zvl256b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64f_zvl4096b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64f_zvl512b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64x_zvl1024b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64x_zvl2048b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64x_zvl256b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64x_zvl4096b-1.c: New test. * gcc.target/riscv/rvv/autovec/zve64x_zvl512b-1.c: New test.
Diffstat (limited to 'gcc/tree-ssa-phiopt.cc')
0 files changed, 0 insertions, 0 deletions