kernel-mode #1
@ -18,6 +18,7 @@ if typing.TYPE_CHECKING:
|
|||||||
from riscemu import Executable, LoadedExecutable, LoadedInstruction
|
from riscemu import Executable, LoadedExecutable, LoadedInstruction
|
||||||
from riscemu.instructions.InstructionSet import InstructionSet
|
from riscemu.instructions.InstructionSet import InstructionSet
|
||||||
|
|
||||||
|
|
||||||
class PrivCPU(CPU):
|
class PrivCPU(CPU):
|
||||||
"""
|
"""
|
||||||
This is a CPU that has different modes, instruction sets and registers.
|
This is a CPU that has different modes, instruction sets and registers.
|
||||||
@ -84,6 +85,7 @@ class PrivCPU(CPU):
|
|||||||
print(FMT_CPU + "Program exited with code {}".format(self.exit_code) + FMT_NONE)
|
print(FMT_CPU + "Program exited with code {}".format(self.exit_code) + FMT_NONE)
|
||||||
sys.exit(self.exit_code)
|
sys.exit(self.exit_code)
|
||||||
elif self.launch_debug:
|
elif self.launch_debug:
|
||||||
|
self.launch_debug = False
|
||||||
launch_debug_session(self, self.mmu, self.regs,
|
launch_debug_session(self, self.mmu, self.regs,
|
||||||
"Launching debugger:")
|
"Launching debugger:")
|
||||||
self._run(verbose)
|
self._run(verbose)
|
||||||
|
@ -132,6 +132,9 @@ class PrivRV32I(RV32I):
|
|||||||
self.regs.set(rd, self.pc)
|
self.regs.set(rd, self.pc)
|
||||||
self.pc = rs + imm - 4
|
self.pc = rs + imm - 4
|
||||||
|
|
||||||
|
def instruction_sbreak(self, ins: 'LoadedInstruction'):
|
||||||
|
raise LaunchDebuggerException()
|
||||||
|
|
||||||
def parse_crs_ins(self, ins: 'LoadedInstruction'):
|
def parse_crs_ins(self, ins: 'LoadedInstruction'):
|
||||||
ASSERT_LEN(ins.args, 3)
|
ASSERT_LEN(ins.args, 3)
|
||||||
return ins.get_reg(0), ins.get_reg(1), ins.get_imm(2)
|
return ins.get_reg(0), ins.get_reg(1), ins.get_imm(2)
|
||||||
|
Loading…
Reference in New Issue
Block a user