summaryrefslogtreecommitdiff
path: root/emulator/csr_unpriv_counter_timer.c
blob: e47452034227e38909a68a35dc1ed8bf297cc1df (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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;
}