added better debugging environment

This commit is contained in:
Anton Lydike 2021-04-18 09:32:37 +02:00
parent baaaa881bc
commit d56dca3ff4
3 changed files with 31 additions and 12 deletions

View File

@ -6,6 +6,7 @@ from .helpers import *
from .Config import RunConfig
from .Registers import Registers
from .Syscall import SyscallInterface, Syscall
from .debug import launch_debug_session
import typing
@ -48,9 +49,12 @@ class CPU:
self.pc += 1
self.__run_instruction(ins)
except RiscemuBaseException as ex:
print(FMT_ERROR + "[CPU] excpetion caught at {}:".format(ins) + FMT_NONE)
print(FMT_ERROR + "[CPU] excpetion caught at 0x{:08X}: {}:".format(self.pc-1, ins) + FMT_NONE)
print(" " + ex.message())
traceback.print_exception(type(ex), ex, ex.__traceback__)
if self.conf.debug_on_exception:
launch_debug_session(self, self.mmu, self.regs,
"Exception encountered, launching debug:".format(self.pc-1))
print("Program exited with code {}".format(self.exit_code))
@ -358,17 +362,7 @@ class CPU:
self.syscall_int.handle_syscall(syscall)
def instruction_sbreak(self, ins: 'LoadedInstruction'):
if self.conf.debug_instruction:
import code
import readline
import rlcompleter
vars = globals()
vars.update(locals())
readline.set_completer(rlcompleter.Completer(vars).complete)
readline.parse_and_bind("tab: complete")
code.InteractiveConsole(vars).interact()
launch_debug_session(self, self.mmu, self.regs, "Debug instruction encountered at 0x{:08X}".format(self.pc))
def instruction_nop(self, ins: 'LoadedInstruction'):
pass

View File

@ -6,7 +6,9 @@ from typing import Optional
class RunConfig:
color: bool = True
preffered_stack_size: Optional[int] = None
# debugging
debug_instruction: bool = True
debug_on_exception = True
# allowed syscalls
scall_input: bool = True
scall_fs: bool = False

23
riscemu/debug.py Normal file
View File

@ -0,0 +1,23 @@
import typing
if typing.TYPE_CHECKING:
from . import *
def launch_debug_session(cpu: 'CPU', mmu: 'MMU', reg: 'Registers', prompt=""):
if not cpu.conf.debug_instruction:
return
import code
import readline
import rlcompleter
# setup some aliases
registers = reg
memory = mmu
mem = mmu
vars = globals()
vars.update(locals())
readline.set_completer(rlcompleter.Completer(vars).complete)
readline.parse_and_bind("tab: complete")
code.InteractiveConsole(vars).interact(banner=prompt, exitmsg="Resuming simulation")