aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/trans-array.cc
diff options
context:
space:
mode:
authorJin Ma <jinma@linux.alibaba.com>2025-01-20 09:29:30 -0700
committerJeff Law <jlaw@ventanamicro.com>2025-01-20 09:30:01 -0700
commit9d869296f095a02c37d3721f546ce99663e5417c (patch)
treeccc6c9d374645bbf14e1699d204bc322b4d68e63 /gcc/fortran/trans-array.cc
parent0fe35e9b93a286de78dd5b80d8d58e9ef0591f03 (diff)
downloadgcc-9d869296f095a02c37d3721f546ce99663e5417c.zip
gcc-9d869296f095a02c37d3721f546ce99663e5417c.tar.gz
gcc-9d869296f095a02c37d3721f546ce99663e5417c.tar.bz2
RISC-V: Correct the mode that is causing the program to fail for XTheadCondMov
For XTheadCondMov, the bit width of rs2 should always be XLEN-sized, otherwise the program logic will be wrong. Reference form https://github.com/XUANTIE-RV/thead-extension-spec/releases/download/2.3.0/xthead-2023-11-10-2.3.0.pdf Synopsis Move if equal zero. Mnemonic th.mveqz rd, rs1, rs2 Description This instruction moves the content of register rs1 into rd if the content of rs2 is 0x0. Otherwise, the value of rd does not change. Operation if (reg[rs2] == 0x0) reg[rd] := reg[rs1] gcc/ChangeLog: * config/riscv/thead.md (*th_cond_mov<GPR:mode><GPR2:mode>): Change GPR2 to X. (*th_cond_mov<GPR:mode>): Likewise. gcc/testsuite/ChangeLog: * gcc.target/riscv/xtheadcondmov-bug.c: New test.
Diffstat (limited to 'gcc/fortran/trans-array.cc')
0 files changed, 0 insertions, 0 deletions