aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChih-Min Chao <chihmin.chao@sifive.com>2019-11-19 00:05:02 -0800
committerChih-Min Chao <chihmin.chao@sifive.com>2019-12-20 09:58:46 -0800
commitfd132e6214751c70a9aa332b26edbbba983561de (patch)
treec2874245277571f9eeb99106a29b04f0477720d2
parent08343bba3bd9f59cefa11ed59724908dfbe84967 (diff)
downloadspike-fd132e6214751c70a9aa332b26edbbba983561de.zip
spike-fd132e6214751c70a9aa332b26edbbba983561de.tar.gz
spike-fd132e6214751c70a9aa332b26edbbba983561de.tar.bz2
rvv: rename vfncvt suffix and add rod rouding type
1. vfncvt*.v -> vfncvt*.w 2. add vfncvt.rod.f.f.w Signed-off-by: Chih-Min Chao <chihmin.chao@sifive.com>
-rw-r--r--riscv/encoding.h36
-rw-r--r--riscv/insns/vfncvt_f_f_w.h (renamed from riscv/insns/vfncvt_f_f_v.h)2
-rw-r--r--riscv/insns/vfncvt_f_x_w.h (renamed from riscv/insns/vfncvt_f_x_v.h)2
-rw-r--r--riscv/insns/vfncvt_f_xu_w.h (renamed from riscv/insns/vfncvt_f_xu_v.h)2
-rw-r--r--riscv/insns/vfncvt_rod_f_f_w.h7
-rw-r--r--riscv/insns/vfncvt_x_f_w.h (renamed from riscv/insns/vfncvt_x_f_v.h)0
-rw-r--r--riscv/insns/vfncvt_xu_f_w.h (renamed from riscv/insns/vfncvt_xu_f_v.h)0
-rw-r--r--riscv/riscv.mk.in11
-rw-r--r--spike_main/disasm.cc36
9 files changed, 55 insertions, 41 deletions
diff --git a/riscv/encoding.h b/riscv/encoding.h
index 7216275..a08cd52 100644
--- a/riscv/encoding.h
+++ b/riscv/encoding.h
@@ -1002,18 +1002,18 @@
#define MASK_VFWCVT_F_X_V 0xfc0ff07f
#define MATCH_VFWCVT_F_F_V 0x88061057
#define MASK_VFWCVT_F_F_V 0xfc0ff07f
-#define MATCH_VFNCVT_XU_F_V 0x88081057
-#define MASK_VFNCVT_XU_F_V 0xfc0ff07f
-#define MATCH_VFNCVT_X_F_V 0x88089057
-#define MASK_VFNCVT_X_F_V 0xfc0ff07f
-#define MATCH_VFNCVT_F_XU_V 0x88091057
-#define MASK_VFNCVT_F_XU_V 0xfc0ff07f
-#define MATCH_VFNCVT_F_X_V 0x88099057
-#define MASK_VFNCVT_F_X_V 0xfc0ff07f
-#define MATCH_VFNCVT_F_F_V 0x880a1057
-#define MASK_VFNCVT_F_F_V 0xfc0ff07f
-#define MATCH_VFNCVT_ROD_F_F_V 0x880a9057
-#define MASK_VFNCVT_ROD_F_F_V 0xfc0ff07f
+#define MATCH_VFNCVT_XU_F_W 0x88081057
+#define MASK_VFNCVT_XU_F_W 0xfc0ff07f
+#define MATCH_VFNCVT_X_F_W 0x88089057
+#define MASK_VFNCVT_X_F_W 0xfc0ff07f
+#define MATCH_VFNCVT_F_XU_W 0x88091057
+#define MASK_VFNCVT_F_XU_W 0xfc0ff07f
+#define MATCH_VFNCVT_F_X_W 0x88099057
+#define MASK_VFNCVT_F_X_W 0xfc0ff07f
+#define MATCH_VFNCVT_F_F_W 0x880a1057
+#define MASK_VFNCVT_F_F_W 0xfc0ff07f
+#define MATCH_VFNCVT_ROD_F_F_W 0x880a9057
+#define MASK_VFNCVT_ROD_F_F_W 0xfc0ff07f
#define MATCH_VFSQRT_V 0x8c001057
#define MASK_VFSQRT_V 0xfc0ff07f
#define MATCH_VFCLASS_V 0x8c081057
@@ -2168,12 +2168,12 @@ DECLARE_INSN(vfwcvt_x_f_v, MATCH_VFWCVT_X_F_V, MASK_VFWCVT_X_F_V)
DECLARE_INSN(vfwcvt_f_xu_v, MATCH_VFWCVT_F_XU_V, MASK_VFWCVT_F_XU_V)
DECLARE_INSN(vfwcvt_f_x_v, MATCH_VFWCVT_F_X_V, MASK_VFWCVT_F_X_V)
DECLARE_INSN(vfwcvt_f_f_v, MATCH_VFWCVT_F_F_V, MASK_VFWCVT_F_F_V)
-DECLARE_INSN(vfncvt_xu_f_v, MATCH_VFNCVT_XU_F_V, MASK_VFNCVT_XU_F_V)
-DECLARE_INSN(vfncvt_x_f_v, MATCH_VFNCVT_X_F_V, MASK_VFNCVT_X_F_V)
-DECLARE_INSN(vfncvt_f_xu_v, MATCH_VFNCVT_F_XU_V, MASK_VFNCVT_F_XU_V)
-DECLARE_INSN(vfncvt_f_x_v, MATCH_VFNCVT_F_X_V, MASK_VFNCVT_F_X_V)
-DECLARE_INSN(vfncvt_f_f_v, MATCH_VFNCVT_F_F_V, MASK_VFNCVT_F_F_V)
-DECLARE_INSN(vfncvt_rod_f_f_v, MATCH_VFNCVT_ROD_F_F_V, MASK_VFNCVT_ROD_F_F_V)
+DECLARE_INSN(vfncvt_xu_f_w, MATCH_VFNCVT_XU_F_W, MASK_VFNCVT_XU_F_W)
+DECLARE_INSN(vfncvt_x_f_w, MATCH_VFNCVT_X_F_W, MASK_VFNCVT_X_F_W)
+DECLARE_INSN(vfncvt_f_xu_w, MATCH_VFNCVT_F_XU_W, MASK_VFNCVT_F_XU_W)
+DECLARE_INSN(vfncvt_f_x_w, MATCH_VFNCVT_F_X_W, MASK_VFNCVT_F_X_W)
+DECLARE_INSN(vfncvt_f_f_w, MATCH_VFNCVT_F_F_W, MASK_VFNCVT_F_F_W)
+DECLARE_INSN(vfncvt_rod_f_f_w, MATCH_VFNCVT_ROD_F_F_W, MASK_VFNCVT_ROD_F_F_W)
DECLARE_INSN(vfsqrt_v, MATCH_VFSQRT_V, MASK_VFSQRT_V)
DECLARE_INSN(vfclass_v, MATCH_VFCLASS_V, MASK_VFCLASS_V)
DECLARE_INSN(vfwadd_vv, MATCH_VFWADD_VV, MASK_VFWADD_VV)
diff --git a/riscv/insns/vfncvt_f_f_v.h b/riscv/insns/vfncvt_f_f_w.h
index b35cd60..42c18c7 100644
--- a/riscv/insns/vfncvt_f_f_v.h
+++ b/riscv/insns/vfncvt_f_f_w.h
@@ -1,6 +1,6 @@
// vfncvt.f.f.v vd, vs2, vm
+VI_CHECK_SD;
VI_VFP_LOOP_BASE
- VI_CHECK_SD;
auto vs2 = P.VU.elt<float64_t>(rs2_num, i);
P.VU.elt<float32_t>(rd_num, i) = f64_to_f32(vs2);
VI_VFP_LOOP_END
diff --git a/riscv/insns/vfncvt_f_x_v.h b/riscv/insns/vfncvt_f_x_w.h
index 69bdba8..80ebe00 100644
--- a/riscv/insns/vfncvt_f_x_v.h
+++ b/riscv/insns/vfncvt_f_x_w.h
@@ -1,6 +1,6 @@
// vfncvt.f.x.v vd, vs2, vm
+VI_CHECK_SD;
VI_VFP_LOOP_BASE
- VI_CHECK_SD;
auto vs2 = P.VU.elt<int64_t>(rs2_num, i);
P.VU.elt<float32_t>(rd_num, i) = i64_to_f32(vs2);
VI_VFP_LOOP_END
diff --git a/riscv/insns/vfncvt_f_xu_v.h b/riscv/insns/vfncvt_f_xu_w.h
index 6f37734..013f57c 100644
--- a/riscv/insns/vfncvt_f_xu_v.h
+++ b/riscv/insns/vfncvt_f_xu_w.h
@@ -1,6 +1,6 @@
// vfncvt.f.xu.v vd, vs2, vm
+VI_CHECK_SD;
VI_VFP_LOOP_BASE
- VI_CHECK_SD;
auto vs2 = P.VU.elt<uint64_t>(rs2_num, i);
P.VU.elt<float32_t>(rd_num, i) = ui64_to_f32(vs2);
VI_VFP_LOOP_END
diff --git a/riscv/insns/vfncvt_rod_f_f_w.h b/riscv/insns/vfncvt_rod_f_f_w.h
new file mode 100644
index 0000000..77a3873
--- /dev/null
+++ b/riscv/insns/vfncvt_rod_f_f_w.h
@@ -0,0 +1,7 @@
+// vfncvt.f.f.v vd, vs2, vm
+VI_CHECK_SD;
+VI_VFP_LOOP_BASE
+ softfloat_roundingMode = softfloat_round_odd;
+ auto vs2 = P.VU.elt<float64_t>(rs2_num, i);
+ P.VU.elt<float32_t>(rd_num, i) = f64_to_f32(vs2);
+VI_VFP_LOOP_END
diff --git a/riscv/insns/vfncvt_x_f_v.h b/riscv/insns/vfncvt_x_f_w.h
index 8985f1b..8985f1b 100644
--- a/riscv/insns/vfncvt_x_f_v.h
+++ b/riscv/insns/vfncvt_x_f_w.h
diff --git a/riscv/insns/vfncvt_xu_f_v.h b/riscv/insns/vfncvt_xu_f_w.h
index 2db8d82..2db8d82 100644
--- a/riscv/insns/vfncvt_xu_f_v.h
+++ b/riscv/insns/vfncvt_xu_f_w.h
diff --git a/riscv/riscv.mk.in b/riscv/riscv.mk.in
index 72e46a0..50e657b 100644
--- a/riscv/riscv.mk.in
+++ b/riscv/riscv.mk.in
@@ -526,11 +526,12 @@ riscv_insn_ext_v_alu_fp = \
vfmv_f_s \
vfmv_s_f \
vfmv_v_f \
- vfncvt_f_f_v \
- vfncvt_f_x_v \
- vfncvt_f_xu_v \
- vfncvt_x_f_v \
- vfncvt_xu_f_v \
+ vfncvt_f_f_w \
+ vfncvt_f_x_w \
+ vfncvt_f_xu_w \
+ vfncvt_rod_f_f_w \
+ vfncvt_x_f_w \
+ vfncvt_xu_f_w \
vfnmacc_vf \
vfnmacc_vv \
vfnmadd_vf \
diff --git a/spike_main/disasm.cc b/spike_main/disasm.cc
index ddf40a4..3082949 100644
--- a/spike_main/disasm.cc
+++ b/spike_main/disasm.cc
@@ -1029,15 +1029,23 @@ disassembler_t::disassembler_t(int xlen)
add_insn(new disasm_insn_t(#name ".vf", match_##name##_vf, mask_##name##_vf, \
{&vd, &vs2, &frs1, &opt, &vm})); \
- #define DISASM_VFUNARY0_INSN(name, extra) \
- add_insn(new disasm_insn_t(#name "cvt.xu.f.v", match_##name##cvt_xu_f_v, \
- mask_##name##cvt_xu_f_v, {&vd, &vs2, &opt, &vm})); \
- add_insn(new disasm_insn_t(#name "cvt.x.f.v", match_##name##cvt_x_f_v, \
- mask_##name##cvt_x_f_v, {&vd, &vs2, &opt, &vm})); \
- add_insn(new disasm_insn_t(#name "cvt.f.xu.v", match_##name##cvt_f_xu_v, \
- mask_##name##cvt_f_xu_v, {&vd, &vs2, &opt, &vm})); \
- add_insn(new disasm_insn_t(#name "cvt.f.x.v", match_##name##cvt_f_x_v, \
- mask_##name##cvt_f_x_v, {&vd, &vs2, &opt, &vm}));
+ #define DISASM_VFUNARY0_INSN(name, extra, suf) \
+ add_insn(new disasm_insn_t(#name "cvt.xu.f." #suf, \
+ match_##name##cvt_xu_f_##suf, mask_##name##cvt_xu_f_##suf, \
+ {&vd, &vs2, &opt, &vm})); \
+ add_insn(new disasm_insn_t(#name "cvt.x.f." #suf, \
+ match_##name##cvt_xu_f_##suf, mask_##name##cvt_xu_f_##suf, \
+ {&vd, &vs2, &opt, &vm})); \
+ add_insn(new disasm_insn_t(#name "cvt.f.xu." #suf, \
+ match_##name##cvt_xu_f_##suf, mask_##name##cvt_xu_f_##suf, \
+ {&vd, &vs2, &opt, &vm})); \
+ add_insn(new disasm_insn_t(#name "cvt.f.x." #suf, \
+ match_##name##cvt_xu_f_##suf, mask_##name##cvt_xu_f_##suf, \
+ {&vd, &vs2, &opt, &vm})); \
+ if (extra) \
+ add_insn(new disasm_insn_t(#name "cvt.f.f." #suf, \
+ match_##name##cvt_xu_f_##suf, mask_##name##cvt_xu_f_##suf, \
+ {&vd, &vs2, &opt, &vm})); \
//OPFVV/OPFVF
//0b01_0000
@@ -1070,14 +1078,12 @@ disassembler_t::disassembler_t(int xlen)
DISASM_OPIV__F_INSN(vfrdiv);
//vfunary0
- DISASM_VFUNARY0_INSN(vf, 0);
+ DISASM_VFUNARY0_INSN(vf, 0, v);
- DISASM_VFUNARY0_INSN(vfw, 1);
- DISASM_INSN("vfwcvt.f.f.v", vfwcvt_f_f_v, 0, {&vd, &vs2, &opt, &vm});
+ DISASM_VFUNARY0_INSN(vfw, 1, v);
- DISASM_VFUNARY0_INSN(vfn, 1);
- DISASM_INSN("vfncvt.f.f.v", vfncvt_f_f_v, 0, {&vd, &vs2, &opt, &vm});
- DISASM_INSN("vfncvt.rod.f.f.v", vfncvt_rod_f_f_v, 0, {&vd, &vs2, &opt, &vm});
+ DISASM_VFUNARY0_INSN(vfn, 1, w);
+ DISASM_INSN("vfncvt.rod.f.f.w", vfncvt_rod_f_f_w, 0, {&vd, &vs2, &opt, &vm});
//vfunary1
DISASM_INSN("vfsqrt.v", vfsqrt_v, 0, {&vd, &vs2, &opt, &vm});