[CSR, PrivCPU] Added csr callback registration through decorator

This commit is contained in:
Anton Lydike 2021-05-24 15:51:05 +02:00
parent 504407c0d9
commit c4cd83701f
3 changed files with 30 additions and 9 deletions

View File

@ -47,8 +47,8 @@ class CPU:
# setup CPU states
self.pc = 0
self.cycle = 0
self.exit = False
self.exit_code = 0
self.exit: bool = False
self.exit_code: int = 0
self.conf = conf
self.active_debug = False # if a debugging session is currently runnign

View File

@ -1,5 +1,6 @@
from typing import Dict, Union, Callable
from collections import defaultdict
from functools import wraps
MSTATUS_OFFSETS = {
'uie': 0,
@ -54,6 +55,7 @@ class CSR:
'mhartid': 0xF14,
'time': 0xc01,
'timeh': 0xc81,
'halt': 0x789
}
"""
Translation for named registers
@ -112,3 +114,9 @@ class CSR:
off = MSTATUS_OFFSETS[name]
mask = (2**size - 1) << off
return (self.get('mstatus') & mask) >> off
def callback(self, addr: Union[str, int]):
def inner(func: Callable[[int, int], None]):
self.set_listener(addr, func)
return func
return inner

View File

@ -49,13 +49,8 @@ class PrivCPU(CPU):
self.pc = exec.run_ptr
self.syscall_int = None
# set up CSR
self.csr = CSR()
# TODO: Actually populate the CSR with real data (vendorID, heartID, machine implementation etc)
self.csr.set('mhartid', 0) # core id
self.csr.set('mimpid', 1) # implementation id
# TODO: set correct misa
self.csr.set('misa', 1) # available ISA
# init csr
self._init_csr()
def _run(self, verbose=False):
if self.pc <= 0:
@ -133,3 +128,21 @@ class PrivCPU(CPU):
print(FMT_CPU + '[CPU] Started running from 0x{:08X} ({})'.format(self.pc, "kernel") + FMT_NONE)
self._run(True)
def _init_csr(self):
# set up CSR
self.csr = CSR()
# TODO: Actually populate the CSR with real data (vendorID, heartID, machine implementation etc)
self.csr.set('mhartid', 0) # core id
self.csr.set('mimpid', 1) # implementation id
# TODO: set correct misa
self.csr.set('misa', 1) # available ISA
@self.csr.callback('halt')
def halt(old: int, new: int):
if new != 0:
self.exit = True
self.exit_code = new
@self.csr.callback('mstatus')
def mstatus(old: int, new: int):
pass