mirror of https://gitee.com/openkylin/qemu.git
target/riscv: Convert RV64I load/store insns to decodetree
this splits the 64-bit only instructions into its own decode file such that we generate the decoder for these instructions only for the RISC-V 64 bit target. Acked-by: Alistair Francis <alistair.francis@wdc.com> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Bastian Koppelmann <kbastian@mail.uni-paderborn.de> Signed-off-by: Peer Adelt <peer.adelt@hni.uni-paderborn.de>
This commit is contained in:
parent
c1000d4e1b
commit
7e45a682ed
|
@ -2,10 +2,12 @@ obj-y += translate.o op_helper.o cpu_helper.o cpu.o csr.o fpu_helper.o gdbstub.o
|
|||
|
||||
DECODETREE = $(SRC_PATH)/scripts/decodetree.py
|
||||
|
||||
target/riscv/decode_insn32.inc.c: \
|
||||
$(SRC_PATH)/target/riscv/insn32.decode $(DECODETREE)
|
||||
decode32-y = $(SRC_PATH)/target/riscv/insn32.decode
|
||||
decode32-$(TARGET_RISCV64) += $(SRC_PATH)/target/riscv/insn32-64.decode
|
||||
|
||||
target/riscv/decode_insn32.inc.c: $(decode32-y) $(DECODETREE)
|
||||
$(call quiet-command, \
|
||||
$(PYTHON) $(DECODETREE) -o $@ --decode decode_insn32 $<, \
|
||||
$(PYTHON) $(DECODETREE) -o $@ --decode decode_insn32 $(decode32-y), \
|
||||
"GEN", $(TARGET_DIR)$@)
|
||||
|
||||
target/riscv/translate.o: target/riscv/decode_insn32.inc.c
|
||||
|
|
|
@ -0,0 +1,25 @@
|
|||
#
|
||||
# RISC-V translation routines for the RV Instruction Set.
|
||||
#
|
||||
# Copyright (c) 2018 Peer Adelt, peer.adelt@hni.uni-paderborn.de
|
||||
# Bastian Koppelmann, kbastian@mail.uni-paderborn.de
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify it
|
||||
# under the terms and conditions of the GNU General Public License,
|
||||
# version 2 or later, as published by the Free Software Foundation.
|
||||
#
|
||||
# This program is distributed in the hope it will be useful, but WITHOUT
|
||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||
# more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License along with
|
||||
# this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
# This is concatenated with insn32.decode for risc64 targets.
|
||||
# Most of the fields and formats are there.
|
||||
|
||||
# *** RV64I Base Instruction Set (in addition to RV32I) ***
|
||||
lwu ............ ..... 110 ..... 0000011 @i
|
||||
ld ............ ..... 011 ..... 0000011 @i
|
||||
sd ....... ..... ..... 011 ..... 0100011 @s
|
|
@ -130,3 +130,23 @@ static bool trans_sw(DisasContext *ctx, arg_sw *a)
|
|||
gen_store(ctx, OPC_RISC_SW, a->rs1, a->rs2, a->imm);
|
||||
return true;
|
||||
}
|
||||
|
||||
#ifdef TARGET_RISCV64
|
||||
static bool trans_lwu(DisasContext *ctx, arg_lwu *a)
|
||||
{
|
||||
gen_load(ctx, OPC_RISC_LWU, a->rd, a->rs1, a->imm);
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool trans_ld(DisasContext *ctx, arg_ld *a)
|
||||
{
|
||||
gen_load(ctx, OPC_RISC_LD, a->rd, a->rs1, a->imm);
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool trans_sd(DisasContext *ctx, arg_sd *a)
|
||||
{
|
||||
gen_store(ctx, OPC_RISC_SD, a->rs1, a->rs2, a->imm);
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
|
|
@ -1908,13 +1908,6 @@ static void decode_RV32_64G(DisasContext *ctx)
|
|||
imm = GET_IMM(ctx->opcode);
|
||||
|
||||
switch (op) {
|
||||
case OPC_RISC_LOAD:
|
||||
gen_load(ctx, MASK_OP_LOAD(ctx->opcode), rd, rs1, imm);
|
||||
break;
|
||||
case OPC_RISC_STORE:
|
||||
gen_store(ctx, MASK_OP_STORE(ctx->opcode), rs1, rs2,
|
||||
GET_STORE_IMM(ctx->opcode));
|
||||
break;
|
||||
case OPC_RISC_ARITH_IMM:
|
||||
#if defined(TARGET_RISCV64)
|
||||
case OPC_RISC_ARITH_IMM_W:
|
||||
|
|
Loading…
Reference in New Issue