summaryrefslogtreecommitdiffstats
path: root/MdePkg/Include/Register/RiscV64/RiscVEncoding.h
blob: 8ccdea2f4fcdc7ecee7ce9e9f4e0749c721cc3f7 (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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/** @file
  RISC-V CSR encodings

  Copyright (c) 2019, Western Digital Corporation or its affiliates. All rights reserved.<BR>
  Copyright (c) 2022, Ventana Micro Systems Inc. All rights reserved.<BR>
  SPDX-License-Identifier: BSD-2-Clause-Patent

**/

#ifndef RISCV_ENCODING_H_
#define RISCV_ENCODING_H_

#define MSTATUS_SIE         0x00000002UL
#define MSTATUS_MIE         0x00000008UL
#define MSTATUS_SPIE_SHIFT  5
#define MSTATUS_SPIE        (1UL << MSTATUS_SPIE_SHIFT)
#define MSTATUS_UBE         0x00000040UL
#define MSTATUS_MPIE        0x00000080UL
#define MSTATUS_SPP_SHIFT   8
#define MSTATUS_SPP         (1UL << MSTATUS_SPP_SHIFT)
#define MSTATUS_MPP_SHIFT   11
#define MSTATUS_MPP         (3UL << MSTATUS_MPP_SHIFT)

#define SSTATUS_SIE         MSTATUS_SIE
#define SSTATUS_SPIE_SHIFT  MSTATUS_SPIE_SHIFT
#define SSTATUS_SPIE        MSTATUS_SPIE
#define SSTATUS_SPP_SHIFT   MSTATUS_SPP_SHIFT
#define SSTATUS_SPP         MSTATUS_SPP

#define IRQ_S_SOFT    1
#define IRQ_VS_SOFT   2
#define IRQ_M_SOFT    3
#define IRQ_S_TIMER   5
#define IRQ_VS_TIMER  6
#define IRQ_M_TIMER   7
#define IRQ_S_EXT     9
#define IRQ_VS_EXT    10
#define IRQ_M_EXT     11
#define IRQ_S_GEXT    12
#define IRQ_PMU_OVF   13

#define MIP_SSIP    (1UL << IRQ_S_SOFT)
#define MIP_VSSIP   (1UL << IRQ_VS_SOFT)
#define MIP_MSIP    (1UL << IRQ_M_SOFT)
#define MIP_STIP    (1UL << IRQ_S_TIMER)
#define MIP_VSTIP   (1UL << IRQ_VS_TIMER)
#define MIP_MTIP    (1UL << IRQ_M_TIMER)
#define MIP_SEIP    (1UL << IRQ_S_EXT)
#define MIP_VSEIP   (1UL << IRQ_VS_EXT)
#define MIP_MEIP    (1UL << IRQ_M_EXT)
#define MIP_SGEIP   (1UL << IRQ_S_GEXT)
#define MIP_LCOFIP  (1UL << IRQ_PMU_OVF)

#define SIP_SSIP  MIP_SSIP
#define SIP_STIP  MIP_STIP

#define PRV_U  0UL
#define PRV_S  1UL
#define PRV_M  3UL

#define SATP64_MODE        0xF000000000000000ULL
#define SATP64_MODE_SHIFT  60
#define SATP64_ASID        0x0FFFF00000000000ULL
#define SATP64_PPN         0x00000FFFFFFFFFFFULL

#define SATP_MODE_OFF   0UL
#define SATP_MODE_SV32  1UL
#define SATP_MODE_SV39  8UL
#define SATP_MODE_SV48  9UL
#define SATP_MODE_SV57  10UL
#define SATP_MODE_SV64  11UL

#define SATP_MODE  SATP64_MODE

/* User Counters/Timers */
#define CSR_CYCLE  0xc00
#define CSR_TIME   0xc01

/* Supervisor Trap Setup */
#define CSR_SSTATUS  0x100
#define CSR_SEDELEG  0x102
#define CSR_SIDELEG  0x103
#define CSR_SIE      0x104
#define CSR_STVEC    0x105

/* Supervisor Configuration */
#define CSR_SENVCFG  0x10a

/* Supervisor Trap Handling */
#define CSR_SSCRATCH  0x140
#define CSR_SEPC      0x141
#define CSR_SCAUSE    0x142
#define CSR_STVAL     0x143
#define CSR_SIP       0x144

/* Supervisor Protection and Translation */
#define CSR_SATP  0x180

/* Sstc extension */
#define CSR_STIMECMP  0x14D

/* Trap/Exception Causes */
#define CAUSE_MISALIGNED_FETCH          0x0
#define CAUSE_FETCH_ACCESS              0x1
#define CAUSE_ILLEGAL_INSTRUCTION       0x2
#define CAUSE_BREAKPOINT                0x3
#define CAUSE_MISALIGNED_LOAD           0x4
#define CAUSE_LOAD_ACCESS               0x5
#define CAUSE_MISALIGNED_STORE          0x6
#define CAUSE_STORE_ACCESS              0x7
#define CAUSE_USER_ECALL                0x8
#define CAUSE_SUPERVISOR_ECALL          0x9
#define CAUSE_VIRTUAL_SUPERVISOR_ECALL  0xa
#define CAUSE_MACHINE_ECALL             0xb
#define CAUSE_FETCH_PAGE_FAULT          0xc
#define CAUSE_LOAD_PAGE_FAULT           0xd
#define CAUSE_STORE_PAGE_FAULT          0xf
#define CAUSE_FETCH_GUEST_PAGE_FAULT    0x14
#define CAUSE_LOAD_GUEST_PAGE_FAULT     0x15
#define CAUSE_VIRTUAL_INST_FAULT        0x16
#define CAUSE_STORE_GUEST_PAGE_FAULT    0x17

#endif