From 62814109390b358e5190bd4789dc1a0cfc3e7253 Mon Sep 17 00:00:00 2001 From: Chih-Min Chao Date: Mon, 18 May 2020 21:19:28 -0700 Subject: rvv: fix unit/stride emul calculation Signed-off-by: Chih-Min Chao --- riscv/decode.h | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'riscv/decode.h') diff --git a/riscv/decode.h b/riscv/decode.h index f547ec8..5731ae1 100644 --- a/riscv/decode.h +++ b/riscv/decode.h @@ -474,7 +474,7 @@ static inline bool is_overlapped(const int astart, const int asize, #define VI_CHECK_STORE \ require_vector; \ - reg_t emul = (eew / P.VU.vsew * P.VU.vlmul) + 0.75; \ + reg_t emul = (eew / P.VU.vsew * P.VU.vlmul) + 0.875; \ require(emul >= 1 && emul <= 8); \ require((insn.rd() & (emul - 1)) == 0); \ require((nf * emul) <= (NVPR / 4) && \ @@ -1610,7 +1610,7 @@ for (reg_t i = 0; i < P.VU.vlmax && P.VU.vl != 0; ++i) { \ const reg_t vl = P.VU.vl; \ const reg_t baseAddr = RS1; \ const reg_t vs3 = insn.rd(); \ - const reg_t eew = sizeof(st_width##_t) * 8; \ + const float eew = sizeof(st_width##_t) * 8; \ VI_CHECK_STORE; \ for (reg_t i = 0; i < vl; ++i) { \ VI_STRIP(i) \ @@ -1666,7 +1666,7 @@ for (reg_t i = 0; i < P.VU.vlmax && P.VU.vl != 0; ++i) { \ const reg_t vl = p->VU.vl; \ const reg_t baseAddr = RS1; \ const reg_t rd_num = insn.rd(); \ - const reg_t eew = sizeof(ld_type##_t) * 8; \ + const float eew = sizeof(ld_type##_t) * 8; \ VI_CHECK_LOAD; \ bool early_stop = false; \ for (reg_t i = p->VU.vstart; i < vl; ++i) { \ -- cgit v1.1