kernel-mode #1
@ -1,17 +1,21 @@
|
|||||||
from typing import Optional, NewType
|
from typing import Optional, NewType
|
||||||
from enum import Enum
|
from enum import Enum
|
||||||
from .privmodes import PrivModes
|
from .privmodes import PrivModes
|
||||||
|
from .CSRConsts import MCAUSE_TRANSLATION
|
||||||
|
|
||||||
import typing
|
import typing
|
||||||
|
|
||||||
if typing.TYPE_CHECKING:
|
if typing.TYPE_CHECKING:
|
||||||
from .ElfLoader import ElfInstruction
|
from .ElfLoader import ElfInstruction
|
||||||
|
|
||||||
|
|
||||||
class CpuTrapType(Enum):
|
class CpuTrapType(Enum):
|
||||||
TIMER = 1
|
TIMER = 1
|
||||||
SOFTWARE = 2
|
SOFTWARE = 2
|
||||||
EXTERNAL = 3
|
EXTERNAL = 3
|
||||||
EXCEPTION = 4
|
EXCEPTION = 4
|
||||||
|
|
||||||
|
|
||||||
class CpuTrap(BaseException):
|
class CpuTrap(BaseException):
|
||||||
code: int
|
code: int
|
||||||
"""
|
"""
|
||||||
@ -48,6 +52,16 @@ class CpuTrap(BaseException):
|
|||||||
def mcause(self):
|
def mcause(self):
|
||||||
return (self.code << 31) + self.interrupt
|
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):
|
class IllegalInstructionTrap(CpuTrap):
|
||||||
def __init__(self, ins: 'ElfInstruction'):
|
def __init__(self, ins: 'ElfInstruction'):
|
||||||
|
Loading…
Reference in New Issue
Block a user