Some work on CSR
This commit is contained in:
33
emulator/csr_unpriv_counter_timer.c
Normal file
33
emulator/csr_unpriv_counter_timer.c
Normal file
@ -0,0 +1,33 @@
|
||||
#include "emulator/csr.h"
|
||||
|
||||
#include "emulator/hart.h"
|
||||
|
||||
static uint32_t csr_cycle(Hart* hart, uint32_t v, enum CsrAction a)
|
||||
{
|
||||
return hart->instret & 0xFFFFFFFF;
|
||||
}
|
||||
|
||||
static uint32_t csr_cycleh(Hart* hart, uint32_t v, enum CsrAction a)
|
||||
{
|
||||
return hart->instret >> 32;
|
||||
}
|
||||
|
||||
static uint32_t csr_time(Hart* hart, uint32_t v, enum CsrAction a)
|
||||
{
|
||||
return hart->time & 0xFFFFFFFF;
|
||||
}
|
||||
|
||||
static uint32_t csr_timeh(Hart* hart, uint32_t v, enum CsrAction a)
|
||||
{
|
||||
return hart->time >> 32;
|
||||
}
|
||||
|
||||
void csr_init_unpriv_counter_timer(Hart* hart)
|
||||
{
|
||||
hart->csrs[CSR_CYCLE].action = csr_cycle;
|
||||
hart->csrs[CSR_CYCLEH].action = csr_cycleh;
|
||||
hart->csrs[CSR_INSTRET].action = csr_cycle;
|
||||
hart->csrs[CSR_INSTRETH].action = csr_cycleh;
|
||||
hart->csrs[CSR_TIME].action = csr_time;
|
||||
hart->csrs[CSR_TIMEH].action = csr_timeh;
|
||||
}
|
Reference in New Issue
Block a user