[Priv Exceptions] added __repr__ to CpuTrap class

This commit is contained in:
Anton Lydike 2021-06-05 09:29:20 +02:00
parent ca3b4099d4
commit 198d14d5fb

View File

@ -1,17 +1,21 @@
from typing import Optional, NewType
from enum import Enum
from .privmodes import PrivModes
from .CSRConsts import MCAUSE_TRANSLATION
import typing
if typing.TYPE_CHECKING:
from .ElfLoader import ElfInstruction
class CpuTrapType(Enum):
TIMER = 1
SOFTWARE = 2
EXTERNAL = 3
EXCEPTION = 4
class CpuTrap(BaseException):
code: int
"""
@ -48,6 +52,16 @@ class CpuTrap(BaseException):
def mcause(self):
return (self.code << 31) + self.interrupt
def __repr__(self):
name = "Reserved interrupt({}, {})".format(self.interrupt, self.code)
if (self.interrupt, self.code) in MCAUSE_TRANSLATION:
name = MCAUSE_TRANSLATION[(self.interrupt, self.code)] + "({}, {})".format(self.interrupt, self.code)
return "{} {{priv={}, type={}, mtval={}}}".format(
name, self.priv.name, self.type.name, self.mtval
)
class IllegalInstructionTrap(CpuTrap):
def __init__(self, ins: 'ElfInstruction'):