summaryrefslogtreecommitdiff
path: root/emulator/csr_machine_information.c
blob: 38a33a1c4045053cc6e2c96b44f3d9af1f6f3f5b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include "emulator/csr.h"

#include "emulator/hart.h"

static uint32_t csr_minfo_zero(Hart* hart, uint32_t v, enum CsrAction a)
{
    return 0;
}

static uint32_t csr_mhartid(Hart* hart, uint32_t v, enum CsrAction a)
{
    return hart->hartid;
}

void csr_init_machine_information(Hart* hart)
{
    hart->csrs[CSR_MVENDORID].action = csr_minfo_zero;
    hart->csrs[CSR_MARCHID].action = csr_minfo_zero;
    hart->csrs[CSR_MIMPID].action = csr_minfo_zero;
    hart->csrs[CSR_MHARTID].action = csr_mhartid;
}