xref: /openbmc/qemu/target/loongarch/cpu-csr.h (revision 6328d8ffa6cb9d750e4bfcfd73ac25d3a39ceb63)
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
2 /*
3  * QEMU LoongArch CSRs
4  *
5  * Copyright (c) 2021 Loongson Technology Corporation Limited
6  */
7 
8 #ifndef LOONGARCH_CPU_CSR_H
9 #define LOONGARCH_CPU_CSR_H
10 
11 #include "hw/registerfields.h"
12 
13 /* Based on kernel definitions: arch/loongarch/include/asm/loongarch.h */
14 
15 /* Basic CSRs */
16 #define LOONGARCH_CSR_CRMD           0x0 /* Current mode info */
17 
18 #define LOONGARCH_CSR_PRMD           0x1 /* Prev-exception mode info */
19 FIELD(CSR_PRMD, PPLV, 0, 2)
20 FIELD(CSR_PRMD, PIE, 2, 1)
21 FIELD(CSR_PRMD, PWE, 3, 1)
22 
23 #define LOONGARCH_CSR_EUEN           0x2 /* Extended unit enable */
24 FIELD(CSR_EUEN, FPE, 0, 1)
25 FIELD(CSR_EUEN, SXE, 1, 1)
26 FIELD(CSR_EUEN, ASXE, 2, 1)
27 FIELD(CSR_EUEN, BTE, 3, 1)
28 
29 #define LOONGARCH_CSR_MISC           0x3 /* Misc config */
30 FIELD(CSR_MISC, VA32, 0, 4)
31 FIELD(CSR_MISC, DRDTL, 4, 4)
32 FIELD(CSR_MISC, RPCNTL, 8, 4)
33 FIELD(CSR_MISC, ALCL, 12, 4)
34 FIELD(CSR_MISC, DWPL, 16, 3)
35 
36 #define LOONGARCH_CSR_ECFG           0x4 /* Exception config */
37 FIELD(CSR_ECFG, LIE, 0, 13)
38 FIELD(CSR_ECFG, VS, 16, 3)
39 
40 #define LOONGARCH_CSR_ESTAT          0x5 /* Exception status */
41 FIELD(CSR_ESTAT, IS, 0, 13)
42 FIELD(CSR_ESTAT, ECODE, 16, 6)
43 FIELD(CSR_ESTAT, ESUBCODE, 22, 9)
44 
45 #define LOONGARCH_CSR_ERA            0x6 /* Exception return address */
46 
47 #define LOONGARCH_CSR_BADV           0x7 /* Bad virtual address */
48 
49 #define LOONGARCH_CSR_BADI           0x8 /* Bad instruction */
50 
51 #define LOONGARCH_CSR_EENTRY         0xc /* Exception entry address */
52 
53 /* TLB related CSRs */
54 #define LOONGARCH_CSR_TLBIDX         0x10 /* TLB Index, EHINV, PageSize, NP */
55 FIELD(CSR_TLBIDX, INDEX, 0, 12)
56 FIELD(CSR_TLBIDX, PS, 24, 6)
57 FIELD(CSR_TLBIDX, NE, 31, 1)
58 
59 #define LOONGARCH_CSR_TLBEHI         0x11 /* TLB EntryHi */
60 FIELD(CSR_TLBEHI_32, VPPN, 13, 19)
61 FIELD(CSR_TLBEHI_64, VPPN, 13, 35)
62 
63 #define LOONGARCH_CSR_TLBELO0        0x12 /* TLB EntryLo0 */
64 #define LOONGARCH_CSR_TLBELO1        0x13 /* TLB EntryLo1 */
65 FIELD(TLBENTRY, V, 0, 1)
66 FIELD(TLBENTRY, D, 1, 1)
67 FIELD(TLBENTRY, PLV, 2, 2)
68 FIELD(TLBENTRY, MAT, 4, 2)
69 FIELD(TLBENTRY, G, 6, 1)
70 FIELD(TLBENTRY, HUGE, 6, 1)
71 FIELD(TLBENTRY, HGLOBAL, 12, 1)
72 FIELD(TLBENTRY, LEVEL, 13, 2)
73 FIELD(TLBENTRY_32, PPN, 8, 24)
74 FIELD(TLBENTRY_64, PPN, 12, 36)
75 FIELD(TLBENTRY_64, NR, 61, 1)
76 FIELD(TLBENTRY_64, NX, 62, 1)
77 FIELD(TLBENTRY_64, RPLV, 63, 1)
78 
79 #define LOONGARCH_CSR_ASID           0x18 /* Address space identifier */
80 FIELD(CSR_ASID, ASID, 0, 10)
81 FIELD(CSR_ASID, ASIDBITS, 16, 8)
82 
83 /* Page table base address when badv[47] = 0 */
84 #define LOONGARCH_CSR_PGDL           0x19
85 /* Page table base address when badv[47] = 1 */
86 #define LOONGARCH_CSR_PGDH           0x1a
87 
88 #define LOONGARCH_CSR_PGD            0x1b /* Page table base address */
89 
90 /* Page walk controller's low addr */
91 #define LOONGARCH_CSR_PWCL           0x1c
92 FIELD(CSR_PWCL, PTBASE, 0, 5)
93 FIELD(CSR_PWCL, PTWIDTH, 5, 5)
94 FIELD(CSR_PWCL, DIR1_BASE, 10, 5)
95 FIELD(CSR_PWCL, DIR1_WIDTH, 15, 5)
96 FIELD(CSR_PWCL, DIR2_BASE, 20, 5)
97 FIELD(CSR_PWCL, DIR2_WIDTH, 25, 5)
98 FIELD(CSR_PWCL, PTEWIDTH, 30, 2)
99 
100 /* Page walk controller's high addr */
101 #define LOONGARCH_CSR_PWCH           0x1d
102 FIELD(CSR_PWCH, DIR3_BASE, 0, 6)
103 FIELD(CSR_PWCH, DIR3_WIDTH, 6, 6)
104 FIELD(CSR_PWCH, DIR4_BASE, 12, 6)
105 FIELD(CSR_PWCH, DIR4_WIDTH, 18, 6)
106 
107 #define LOONGARCH_CSR_STLBPS         0x1e /* Stlb page size */
108 FIELD(CSR_STLBPS, PS, 0, 5)
109 
110 #define LOONGARCH_CSR_RVACFG         0x1f /* Reduced virtual address config */
111 FIELD(CSR_RVACFG, RBITS, 0, 4)
112 
113 /* Config CSRs */
114 #define LOONGARCH_CSR_CPUID          0x20 /* CPU core id */
115 
116 #define LOONGARCH_CSR_PRCFG1         0x21 /* Config1 */
117 FIELD(CSR_PRCFG1, SAVE_NUM, 0, 4)
118 FIELD(CSR_PRCFG1, TIMER_BITS, 4, 8)
119 FIELD(CSR_PRCFG1, VSMAX, 12, 3)
120 
121 #define LOONGARCH_CSR_PRCFG2         0x22 /* Config2 */
122 
123 #define LOONGARCH_CSR_PRCFG3         0x23 /* Config3 */
124 FIELD(CSR_PRCFG3, TLB_TYPE, 0, 4)
125 FIELD(CSR_PRCFG3, MTLB_ENTRY, 4, 8)
126 FIELD(CSR_PRCFG3, STLB_WAYS, 12, 8)
127 FIELD(CSR_PRCFG3, STLB_SETS, 20, 8)
128 
129 /*
130  * Save registers count can read from PRCFG1.SAVE_NUM
131  * The Min count is 1. Max count is 15.
132  */
133 #define LOONGARCH_CSR_SAVE(N)        (0x30 + N)
134 
135 /* Timer CSRs */
136 #define LOONGARCH_CSR_TID            0x40 /* Timer ID */
137 
138 #define LOONGARCH_CSR_TCFG           0x41 /* Timer config */
139 FIELD(CSR_TCFG, EN, 0, 1)
140 FIELD(CSR_TCFG, PERIODIC, 1, 1)
141 FIELD(CSR_TCFG, INIT_VAL, 2, 46)
142 
143 #define LOONGARCH_CSR_TVAL           0x42 /* Timer ticks remain */
144 
145 #define LOONGARCH_CSR_CNTC           0x43 /* Timer offset */
146 
147 #define LOONGARCH_CSR_TICLR          0x44 /* Timer interrupt clear */
148 
149 /* LLBCTL CSRs */
150 #define LOONGARCH_CSR_LLBCTL         0x60 /* LLBit control */
151 FIELD(CSR_LLBCTL, ROLLB, 0, 1)
152 FIELD(CSR_LLBCTL, WCLLB, 1, 1)
153 FIELD(CSR_LLBCTL, KLO, 2, 1)
154 
155 /* Implement dependent */
156 #define LOONGARCH_CSR_IMPCTL1        0x80 /* LoongArch config1 */
157 
158 #define LOONGARCH_CSR_IMPCTL2        0x81 /* LoongArch config2*/
159 
160 /* TLB Refill CSRs */
161 #define LOONGARCH_CSR_TLBRENTRY      0x88 /* TLB refill exception address */
162 #define LOONGARCH_CSR_TLBRBADV       0x89 /* TLB refill badvaddr */
163 #define LOONGARCH_CSR_TLBRERA        0x8a /* TLB refill ERA */
164 #define LOONGARCH_CSR_TLBRSAVE       0x8b /* KScratch for TLB refill */
165 FIELD(CSR_TLBRERA, ISTLBR, 0, 1)
166 FIELD(CSR_TLBRERA, PC, 2, 62)
167 #define LOONGARCH_CSR_TLBRELO0       0x8c /* TLB refill entrylo0 */
168 #define LOONGARCH_CSR_TLBRELO1       0x8d /* TLB refill entrylo1 */
169 #define LOONGARCH_CSR_TLBREHI        0x8e /* TLB refill entryhi */
170 FIELD(CSR_TLBREHI, PS, 0, 6)
171 FIELD(CSR_TLBREHI_32, VPPN, 13, 19)
172 FIELD(CSR_TLBREHI_64, VPPN, 13, 35)
173 #define LOONGARCH_CSR_TLBRPRMD       0x8f /* TLB refill mode info */
174 FIELD(CSR_TLBRPRMD, PPLV, 0, 2)
175 FIELD(CSR_TLBRPRMD, PIE, 2, 1)
176 FIELD(CSR_TLBRPRMD, PWE, 4, 1)
177 
178 /* Machine Error CSRs */
179 #define LOONGARCH_CSR_MERRCTL        0x90 /* ERRCTL */
180 FIELD(CSR_MERRCTL, ISMERR, 0, 1)
181 #define LOONGARCH_CSR_MERRINFO1      0x91
182 #define LOONGARCH_CSR_MERRINFO2      0x92
183 #define LOONGARCH_CSR_MERRENTRY      0x93 /* MError exception base */
184 #define LOONGARCH_CSR_MERRERA        0x94 /* MError exception PC */
185 #define LOONGARCH_CSR_MERRSAVE       0x95 /* KScratch for error exception */
186 
187 #define LOONGARCH_CSR_CTAG           0x98 /* TagLo + TagHi */
188 
189 /* Direct map windows CSRs*/
190 #define LOONGARCH_CSR_DMW(N)         (0x180 + N)
191 FIELD(CSR_DMW, PLV0, 0, 1)
192 FIELD(CSR_DMW, PLV1, 1, 1)
193 FIELD(CSR_DMW, PLV2, 2, 1)
194 FIELD(CSR_DMW, PLV3, 3, 1)
195 FIELD(CSR_DMW, MAT, 4, 2)
196 FIELD(CSR_DMW_32, PSEG, 25, 3)
197 FIELD(CSR_DMW_32, VSEG, 29, 3)
198 FIELD(CSR_DMW_64, VSEG, 60, 4)
199 
200 /* Debug CSRs */
201 #define LOONGARCH_CSR_DBG            0x500 /* debug config */
202 FIELD(CSR_DBG, DST, 0, 1)
203 FIELD(CSR_DBG, DREV, 1, 7)
204 FIELD(CSR_DBG, DEI, 8, 1)
205 FIELD(CSR_DBG, DCL, 9, 1)
206 FIELD(CSR_DBG, DFW, 10, 1)
207 FIELD(CSR_DBG, DMW, 11, 1)
208 FIELD(CSR_DBG, ECODE, 16, 6)
209 
210 #define LOONGARCH_CSR_DERA           0x501 /* Debug era */
211 #define LOONGARCH_CSR_DSAVE          0x502 /* Debug save */
212 
213 #endif /* LOONGARCH_CPU_CSR_H */
214