aboutsummaryrefslogtreecommitdiff
path: root/riscv/decode.h
diff options
context:
space:
mode:
Diffstat (limited to 'riscv/decode.h')
-rw-r--r--riscv/decode.h25
1 files changed, 16 insertions, 9 deletions
diff --git a/riscv/decode.h b/riscv/decode.h
index 505cda5..bbcc37a 100644
--- a/riscv/decode.h
+++ b/riscv/decode.h
@@ -415,7 +415,7 @@ static inline bool is_overlapped(const int astart, const int asize,
if (insn.v_vm() == 0) \
require(insn.rd() != 0);
-#define VI_CHECK_LDST_INDEX \
+#define VI_CHECK_ST_INDEX \
require_vector; \
require((insn.rd() & (P.VU.vlmul - 1)) == 0); \
require((insn.rs2() & (P.VU.vlmul - 1)) == 0); \
@@ -424,6 +424,11 @@ static inline bool is_overlapped(const int astart, const int asize,
if (insn.v_vm() == 0 && (insn.v_nf() > 0 || P.VU.vlmul > 1)) \
require(insn.rd() != 0); \
+#define VI_CHECK_LD_INDEX \
+ VI_CHECK_ST_INDEX; \
+ if (insn.v_vm() == 0 && (insn.v_nf() > 0 || P.VU.vlmul > 1)) \
+ require(insn.rd() != 0); \
+
#define VI_CHECK_MSS(is_vs1) \
if (P.VU.vlmul > 1) { \
require(!is_overlapped(insn.rd(), 1, insn.rs2(), P.VU.vlmul)); \
@@ -445,12 +450,14 @@ static inline bool is_overlapped(const int astart, const int asize,
require(insn.rd() != 0); \
}
-#define VI_CHECK_SXX \
+#define VI_CHECK_STORE_SXX \
require_vector; \
- if (P.VU.vlmul > 1) { \
- require((insn.rd() & (P.VU.vlmul - 1)) == 0); \
- if (insn.v_vm() == 0) \
- require(insn.rd() != 0); \
+ require((insn.rd() & (P.VU.vlmul - 1)) == 0);
+
+#define VI_CHECK_SXX \
+ VI_CHECK_STORE_SXX; \
+ if (P.VU.vlmul > 1 && insn.v_vm() == 0) { \
+ require(insn.rd() != 0); \
}
#define VI_CHECK_DSS(is_vs1) \
@@ -1540,15 +1547,15 @@ for (reg_t i = 0; i < vlmax; ++i) { \
VI_LD_COMMON(stride, offset, ld_width, elt_byte)
#define VI_LD_INDEX(stride, offset, ld_width, elt_byte) \
- VI_CHECK_LDST_INDEX; \
+ VI_CHECK_LD_INDEX; \
VI_LD_COMMON(stride, offset, ld_width, elt_byte)
#define VI_ST(stride, offset, st_width, elt_byte) \
- VI_CHECK_SXX; \
+ VI_CHECK_STORE_SXX; \
VI_ST_COMMON(stride, offset, st_width, elt_byte) \
#define VI_ST_INDEX(stride, offset, st_width, elt_byte) \
- VI_CHECK_LDST_INDEX; \
+ VI_CHECK_ST_INDEX; \
VI_ST_COMMON(stride, offset, st_width, elt_byte) \
#define VI_LDST_FF(itype, tsew) \