added correct instruction printing

This commit is contained in:
Anton Lydike 2021-11-16 08:02:27 +01:00
parent 0b34aea520
commit e9c11e9a41
3 changed files with 59 additions and 12 deletions

View File

@ -1 +1,2 @@
from .decoder import decode, RISCV_REGS
from .formatter import format_ins

View File

@ -0,0 +1,39 @@
from .formats import INSTRUCTION_ARGS_DECODER, op, decode_i, decode_r, decode_u, decode_b, decode_j, decode_s, \
decode_i_shamt, decode_i_unsigned
from .regs import RISCV_REGS
def int_to_hex(num: int):
if num < 0:
return f"-0x{-num:x}"
return f"0x{num:x}"
def format_ins(ins: int, name: str, fmt: str = 'int'):
opcode = op(ins)
if fmt == 'hex':
fmt = int_to_hex
else:
fmt = str
if opcode not in INSTRUCTION_ARGS_DECODER:
return f"{name} <unknown op>"
decoder = INSTRUCTION_ARGS_DECODER[opcode]
if name in ('ecall', 'ebreak'):
return name
if opcode in (0x8, 0x0):
r1, r2, imm = decoder(ins)
return f"{name:<7} {r1}, {imm}({r2})"
elif decoder in (decode_i, decode_i_unsigned, decode_b, decode_i_shamt, decode_s):
r1, r2, imm = decoder(ins)
r1, r2 = RISCV_REGS[r1], RISCV_REGS[r2]
return f"{name:<7} {r1}, {r2}, {fmt(imm)}"
elif decoder in (decode_r,):
rd, rs1, rs2 = [RISCV_REGS[x] for x in decoder(ins)]
return f"{name:<7} {rd}, {rs1}, {rs2}"
elif decoder in (decode_j, decode_u):
r1, imm = decoder(ins)
return f"{name:<7} {RISCV_REGS[r1]}, {fmt(imm)}"
return f"{name} <unknown decoder>"

View File

@ -4,7 +4,7 @@ from typing import List, Dict, Tuple
from .Exceptions import *
from ..Exceptions import RiscemuBaseException
from ..Executable import MemoryFlags, LoadedMemorySection
from ..decoder import decode, RISCV_REGS
from ..decoder import decode, RISCV_REGS, format_ins
from ..helpers import FMT_PARSE, FMT_NONE, FMT_GREEN, FMT_BOLD
FMT_ELF = FMT_GREEN + FMT_BOLD
@ -118,17 +118,24 @@ class ElfInstruction:
def __repr__(self) -> str:
if self.name == 'jal' and self.args[0] == 0:
return "j {}".format(self.args[1])
elif self.name in ('lw', 'lh', 'lb', 'lbu', 'lhu', 'sw', 'sh', 'sb'):
args = "{}, {}({})".format(
RISCV_REGS[self.args[0]], self.args[2], RISCV_REGS[self.args[1]]
)
else:
args = ", ".join(map(str, self.args))
return "{:<8} {}".format(
self.name,
args
)
return "j {}".format(self.args[1])
if self.name == 'addi' and self.args[2] == 0:
return "mv {}, {}".format(self.get_reg(0), self.get_reg(1))
if self.name == 'addi' and self.args[1] == 0:
return "li {}, {}".format(self.get_reg(0), self.args[2])
if self.name == 'ret' and len(self.args) == 0:
return "ret"
return format_ins(self.encoded, self.name)
# if self.name in ('lw', 'lh', 'lb', 'lbu', 'lhu', 'sw', 'sh', 'sb'):
# args = "{}, {}({})".format(
# RISCV_REGS[self.args[0]], self.args[2], RISCV_REGS[self.args[1]]
# )
# else:
# args = ", ".join(map(str, self.args))
# return "{:<8} {}".format(
# self.name,
# args
# )
class ElfLoadedMemorySection(LoadedMemorySection):