lib: sbi_misaligned_ldst: Fix handling of C.SWSP and C.SDSP
authorAmanieu d'Antras <amanieu@gmail.com>
Sun, 1 Oct 2023 09:12:02 +0000 (10:12 +0100)
committerAnup Patel <anup@brainfault.org>
Mon, 9 Oct 2023 08:23:20 +0000 (13:53 +0530)
Unlike C.LWSP/C.LDSP, these encodings can be used with the zero
register, so checking that the rs2 field is non-zero is unnecessary.

Additionally, the previous check was incorrect since it was checking
the immediate field of the instruction instead of the rs2 field.

Signed-off-by: Amanieu d'Antras <amanieu@gmail.com>
Reviewed-by: Anup Patel <anup@brainfault.org>
lib/sbi/sbi_misaligned_ldst.c

index 4b91e072c6481674029036f788d8cadb2b4a5883..aa512de3985920be51dfb57f02e35994defb0edb 100644 (file)
@@ -211,16 +211,14 @@ int sbi_misaligned_store_handler(ulong addr, ulong tval2, ulong tinst,
        } else if ((insn & INSN_MASK_C_SD) == INSN_MATCH_C_SD) {
                len            = 8;
                val.data_ulong = GET_RS2S(insn, regs);
-       } else if ((insn & INSN_MASK_C_SDSP) == INSN_MATCH_C_SDSP &&
-                  ((insn >> SH_RD) & 0x1f)) {
+       } else if ((insn & INSN_MASK_C_SDSP) == INSN_MATCH_C_SDSP) {
                len            = 8;
                val.data_ulong = GET_RS2C(insn, regs);
 #endif
        } else if ((insn & INSN_MASK_C_SW) == INSN_MATCH_C_SW) {
                len            = 4;
                val.data_ulong = GET_RS2S(insn, regs);
-       } else if ((insn & INSN_MASK_C_SWSP) == INSN_MATCH_C_SWSP &&
-                  ((insn >> SH_RD) & 0x1f)) {
+       } else if ((insn & INSN_MASK_C_SWSP) == INSN_MATCH_C_SWSP) {
                len            = 4;
                val.data_ulong = GET_RS2C(insn, regs);
 #ifdef __riscv_flen