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