aboutsummaryrefslogtreecommitdiff
path: root/gcc/range-op-float.cc
diff options
context:
space:
mode:
authorJia-Wei Chen <jiawei@iscas.ac.cn>2022-11-16 22:58:54 -0500
committerJeff Law <jeffreyalaw@gmail.com>2022-11-16 23:00:52 -0500
commita62d957342e3e9ee9bda812f737279f1166e03ba (patch)
treea59ee47de8a820f4386d88764b0e428a7947590d /gcc/range-op-float.cc
parente214cab68cb34e77622b91113f7698cf137bbdd6 (diff)
downloadgcc-a62d957342e3e9ee9bda812f737279f1166e03ba.zip
gcc-a62d957342e3e9ee9bda812f737279f1166e03ba.tar.gz
gcc-a62d957342e3e9ee9bda812f737279f1166e03ba.tar.bz2
RISC-V: Optimize RVV epilogue logic.
Sometimes "step1 -= scalable_frame" will cause adjust equal to zero. And it will generate additional redundant instruction "addi sp,sp,0". Add checking segement to skip that case. This testcase mix exist spill-1.c and adding new fun to check if there have redundant addi intructions. Idea provided by Jeff Law. gcc/ChangeLog: * config/riscv/riscv.cc (riscv_expand_epilogue): Do not emit useless add sp, sp, 0 instrutions. gcc/testsuite/ChangeLog: * gcc.target/riscv/rvv/base/spill-sp-adjust.c: New test.
Diffstat (limited to 'gcc/range-op-float.cc')
0 files changed, 0 insertions, 0 deletions