From: Kito Cheng <kito.ch...@sifive.com> Signed-off-by: Kito Cheng <kito.ch...@sifive.com> --- target/riscv/insn32-64.decode | 7 +++++ target/riscv/insn_trans/trans_rvb.c.inc | 38 +++++++++++++++++++++++++ target/riscv/translate.c | 18 ++++++++++++ 3 files changed, 63 insertions(+)
diff --git a/target/riscv/insn32-64.decode b/target/riscv/insn32-64.decode index 42bafbc03a0..5df10cd3066 100644 --- a/target/riscv/insn32-64.decode +++ b/target/riscv/insn32-64.decode @@ -107,6 +107,9 @@ gorcw 0010100 .......... 101 ..... 0111011 @r sh1addu_w 0010000 .......... 010 ..... 0111011 @r sh2addu_w 0010000 .......... 100 ..... 0111011 @r sh3addu_w 0010000 .......... 110 ..... 0111011 @r +addwu 0000101 .......... 000 ..... 0111011 @r +subwu 0100101 .......... 000 ..... 0111011 @r +addu_w 0000100 .......... 000 ..... 0111011 @r sbsetiw 0010100 .......... 001 ..... 0011011 @sh5 sbclriw 0100100 .......... 001 ..... 0011011 @sh5 @@ -116,3 +119,7 @@ sroiw 0010000 .......... 101 ..... 0011011 @sh5 roriw 0110000 .......... 101 ..... 0011011 @sh5 greviw 0110100 .......... 101 ..... 0011011 @sh5 gorciw 0010100 .......... 101 ..... 0011011 @sh5 + +addiwu ................. 100 ..... 0011011 @i + +slliu_w 000010 ........... 001 ..... 0011011 @sh diff --git a/target/riscv/insn_trans/trans_rvb.c.inc b/target/riscv/insn_trans/trans_rvb.c.inc index 31d791236d9..c6fcdc5f0c1 100644 --- a/target/riscv/insn_trans/trans_rvb.c.inc +++ b/target/riscv/insn_trans/trans_rvb.c.inc @@ -434,4 +434,42 @@ GEN_TRANS_SHADDU_W(1) GEN_TRANS_SHADDU_W(2) GEN_TRANS_SHADDU_W(3) +static bool trans_addwu(DisasContext *ctx, arg_addwu *a) +{ + REQUIRE_EXT(ctx, RVB); + return gen_arith(ctx, a, &gen_addwu); +} + +static bool trans_addiwu(DisasContext *ctx, arg_addiwu *a) +{ + REQUIRE_EXT(ctx, RVB); + return gen_arith_imm_tl(ctx, a, &gen_addwu); +} + +static bool trans_subwu(DisasContext *ctx, arg_subwu *a) +{ + REQUIRE_EXT(ctx, RVB); + return gen_arith(ctx, a, &gen_subwu); +} + +static bool trans_addu_w(DisasContext *ctx, arg_addu_w *a) +{ + REQUIRE_EXT(ctx, RVB); + return gen_arith(ctx, a, &gen_addu_w); +} + +static bool trans_slliu_w(DisasContext *ctx, arg_slliu_w *a) +{ + TCGv source1; + source1 = tcg_temp_new(); + gen_get_gpr(source1, a->rs1); + + tcg_gen_ext32u_tl(source1, source1); + tcg_gen_shli_tl(source1, source1, a->shamt); + gen_set_gpr(a->rd, source1); + + tcg_temp_free(source1); + return true; +} + #endif diff --git a/target/riscv/translate.c b/target/riscv/translate.c index 584550a9db2..9d36d2bd685 100644 --- a/target/riscv/translate.c +++ b/target/riscv/translate.c @@ -672,12 +672,24 @@ static void gen_addw(TCGv ret, TCGv arg1, TCGv arg2) tcg_gen_ext32s_tl(ret, ret); } +static void gen_addwu(TCGv ret, TCGv arg1, TCGv arg2) +{ + tcg_gen_add_tl(ret, arg1, arg2); + tcg_gen_ext32u_tl(ret, ret); +} + static void gen_subw(TCGv ret, TCGv arg1, TCGv arg2) { tcg_gen_sub_tl(ret, arg1, arg2); tcg_gen_ext32s_tl(ret, ret); } +static void gen_subwu(TCGv ret, TCGv arg1, TCGv arg2) +{ + tcg_gen_sub_tl(ret, arg1, arg2); + tcg_gen_ext32u_tl(ret, ret); +} + static void gen_mulw(TCGv ret, TCGv arg1, TCGv arg2) { tcg_gen_mul_tl(ret, arg1, arg2); @@ -1252,6 +1264,12 @@ GEN_SHADDU_W(1) GEN_SHADDU_W(2) GEN_SHADDU_W(3) +static void gen_addu_w(TCGv ret, TCGv arg1, TCGv arg2) +{ + tcg_gen_ext32u_tl(arg1, arg1); + tcg_gen_add_tl(ret, arg1, arg2); +} + #endif static bool gen_arith(DisasContext *ctx, arg_r *a, -- 2.17.1