1 | /* |
2 | * QEMU PowerPC XIVE interrupt controller model |
3 | * |
4 | * Copyright (c) 2017-2018, IBM Corporation. |
5 | * |
6 | * This code is licensed under the GPL version 2 or later. See the |
7 | * COPYING file in the top-level directory. |
8 | */ |
9 | |
10 | #ifndef PPC_PNV_XIVE_REGS_H |
11 | #define PPC_PNV_XIVE_REGS_H |
12 | |
13 | /* IC register offsets 0x0 - 0x400 */ |
14 | #define CQ_SWI_CMD_HIST 0x020 |
15 | #define CQ_SWI_CMD_POLL 0x028 |
16 | #define CQ_SWI_CMD_BCAST 0x030 |
17 | #define CQ_SWI_CMD_ASSIGN 0x038 |
18 | #define CQ_SWI_CMD_BLK_UPD 0x040 |
19 | #define CQ_SWI_RSP 0x048 |
20 | #define CQ_CFG_PB_GEN 0x050 |
21 | #define CQ_INT_ADDR_OPT PPC_BITMASK(14, 15) |
22 | #define CQ_MSGSND 0x058 |
23 | #define CQ_CNPM_SEL 0x078 |
24 | #define CQ_IC_BAR 0x080 |
25 | #define CQ_IC_BAR_VALID PPC_BIT(0) |
26 | #define CQ_IC_BAR_64K PPC_BIT(1) |
27 | #define CQ_TM1_BAR 0x90 |
28 | #define CQ_TM2_BAR 0x0a0 |
29 | #define CQ_TM_BAR_VALID PPC_BIT(0) |
30 | #define CQ_TM_BAR_64K PPC_BIT(1) |
31 | #define CQ_PC_BAR 0x0b0 |
32 | #define CQ_PC_BAR_VALID PPC_BIT(0) |
33 | #define CQ_PC_BARM 0x0b8 |
34 | #define CQ_PC_BARM_MASK PPC_BITMASK(26, 38) |
35 | #define CQ_VC_BAR 0x0c0 |
36 | #define CQ_VC_BAR_VALID PPC_BIT(0) |
37 | #define CQ_VC_BARM 0x0c8 |
38 | #define CQ_VC_BARM_MASK PPC_BITMASK(21, 37) |
39 | #define CQ_TAR 0x0f0 |
40 | #define CQ_TAR_TBL_AUTOINC PPC_BIT(0) |
41 | #define CQ_TAR_TSEL PPC_BITMASK(12, 15) |
42 | #define CQ_TAR_TSEL_BLK PPC_BIT(12) |
43 | #define CQ_TAR_TSEL_MIG PPC_BIT(13) |
44 | #define CQ_TAR_TSEL_VDT PPC_BIT(14) |
45 | #define CQ_TAR_TSEL_EDT PPC_BIT(15) |
46 | #define CQ_TAR_TSEL_INDEX PPC_BITMASK(26, 31) |
47 | #define CQ_TDR 0x0f8 |
48 | #define CQ_TDR_VDT_VALID PPC_BIT(0) |
49 | #define CQ_TDR_VDT_BLK PPC_BITMASK(11, 15) |
50 | #define CQ_TDR_VDT_INDEX PPC_BITMASK(28, 31) |
51 | #define CQ_TDR_EDT_TYPE PPC_BITMASK(0, 1) |
52 | #define CQ_TDR_EDT_INVALID 0 |
53 | #define CQ_TDR_EDT_IPI 1 |
54 | #define CQ_TDR_EDT_EQ 2 |
55 | #define CQ_TDR_EDT_BLK PPC_BITMASK(12, 15) |
56 | #define CQ_TDR_EDT_INDEX PPC_BITMASK(26, 31) |
57 | #define CQ_PBI_CTL 0x100 |
58 | #define CQ_PBI_PC_64K PPC_BIT(5) |
59 | #define CQ_PBI_VC_64K PPC_BIT(6) |
60 | #define CQ_PBI_LNX_TRIG PPC_BIT(7) |
61 | #define CQ_PBI_FORCE_TM_LOCAL PPC_BIT(22) |
62 | #define CQ_PBO_CTL 0x108 |
63 | #define CQ_AIB_CTL 0x110 |
64 | #define CQ_RST_CTL 0x118 |
65 | #define CQ_FIRMASK 0x198 |
66 | #define CQ_FIRMASK_AND 0x1a0 |
67 | #define CQ_FIRMASK_OR 0x1a8 |
68 | |
69 | /* PC LBS1 register offsets 0x400 - 0x800 */ |
70 | #define PC_TCTXT_CFG 0x400 |
71 | #define PC_TCTXT_CFG_BLKGRP_EN PPC_BIT(0) |
72 | #define PC_TCTXT_CFG_TARGET_EN PPC_BIT(1) |
73 | #define PC_TCTXT_CFG_LGS_EN PPC_BIT(2) |
74 | #define PC_TCTXT_CFG_STORE_ACK PPC_BIT(3) |
75 | #define PC_TCTXT_CFG_HARD_CHIPID_BLK PPC_BIT(8) |
76 | #define PC_TCTXT_CHIPID_OVERRIDE PPC_BIT(9) |
77 | #define PC_TCTXT_CHIPID PPC_BITMASK(12, 15) |
78 | #define PC_TCTXT_INIT_AGE PPC_BITMASK(30, 31) |
79 | #define PC_TCTXT_TRACK 0x408 |
80 | #define PC_TCTXT_TRACK_EN PPC_BIT(0) |
81 | #define PC_TCTXT_INDIR0 0x420 |
82 | #define PC_TCTXT_INDIR_VALID PPC_BIT(0) |
83 | #define PC_TCTXT_INDIR_THRDID PPC_BITMASK(9, 15) |
84 | #define PC_TCTXT_INDIR1 0x428 |
85 | #define PC_TCTXT_INDIR2 0x430 |
86 | #define PC_TCTXT_INDIR3 0x438 |
87 | #define PC_THREAD_EN_REG0 0x440 |
88 | #define PC_THREAD_EN_REG0_SET 0x448 |
89 | #define PC_THREAD_EN_REG0_CLR 0x450 |
90 | #define PC_THREAD_EN_REG1 0x460 |
91 | #define PC_THREAD_EN_REG1_SET 0x468 |
92 | #define PC_THREAD_EN_REG1_CLR 0x470 |
93 | #define PC_GLOBAL_CONFIG 0x480 |
94 | #define PC_GCONF_INDIRECT PPC_BIT(32) |
95 | #define PC_GCONF_CHIPID_OVR PPC_BIT(40) |
96 | #define PC_GCONF_CHIPID PPC_BITMASK(44, 47) |
97 | #define PC_VSD_TABLE_ADDR 0x488 |
98 | #define PC_VSD_TABLE_DATA 0x490 |
99 | #define PC_AT_KILL 0x4b0 |
100 | #define PC_AT_KILL_VALID PPC_BIT(0) |
101 | #define PC_AT_KILL_BLOCK_ID PPC_BITMASK(27, 31) |
102 | #define PC_AT_KILL_OFFSET PPC_BITMASK(48, 60) |
103 | #define PC_AT_KILL_MASK 0x4b8 |
104 | |
105 | /* PC LBS2 register offsets */ |
106 | #define PC_VPC_CACHE_ENABLE 0x708 |
107 | #define PC_VPC_CACHE_EN_MASK PPC_BITMASK(0, 31) |
108 | #define PC_VPC_SCRUB_TRIG 0x710 |
109 | #define PC_VPC_SCRUB_MASK 0x718 |
110 | #define PC_SCRUB_VALID PPC_BIT(0) |
111 | #define PC_SCRUB_WANT_DISABLE PPC_BIT(1) |
112 | #define PC_SCRUB_WANT_INVAL PPC_BIT(2) |
113 | #define PC_SCRUB_BLOCK_ID PPC_BITMASK(27, 31) |
114 | #define PC_SCRUB_OFFSET PPC_BITMASK(45, 63) |
115 | #define PC_VPC_CWATCH_SPEC 0x738 |
116 | #define PC_VPC_CWATCH_CONFLICT PPC_BIT(0) |
117 | #define PC_VPC_CWATCH_FULL PPC_BIT(8) |
118 | #define PC_VPC_CWATCH_BLOCKID PPC_BITMASK(27, 31) |
119 | #define PC_VPC_CWATCH_OFFSET PPC_BITMASK(45, 63) |
120 | #define PC_VPC_CWATCH_DAT0 0x740 |
121 | #define PC_VPC_CWATCH_DAT1 0x748 |
122 | #define PC_VPC_CWATCH_DAT2 0x750 |
123 | #define PC_VPC_CWATCH_DAT3 0x758 |
124 | #define PC_VPC_CWATCH_DAT4 0x760 |
125 | #define PC_VPC_CWATCH_DAT5 0x768 |
126 | #define PC_VPC_CWATCH_DAT6 0x770 |
127 | #define PC_VPC_CWATCH_DAT7 0x778 |
128 | |
129 | /* VC0 register offsets 0x800 - 0xFFF */ |
130 | #define VC_GLOBAL_CONFIG 0x800 |
131 | #define VC_GCONF_INDIRECT PPC_BIT(32) |
132 | #define VC_VSD_TABLE_ADDR 0x808 |
133 | #define VC_VSD_TABLE_DATA 0x810 |
134 | #define VC_IVE_ISB_BLOCK_MODE 0x818 |
135 | #define VC_EQD_BLOCK_MODE 0x820 |
136 | #define VC_VPS_BLOCK_MODE 0x828 |
137 | #define VC_IRQ_CONFIG_IPI 0x840 |
138 | #define VC_IRQ_CONFIG_MEMB_EN PPC_BIT(45) |
139 | #define VC_IRQ_CONFIG_MEMB_SZ PPC_BITMASK(46, 51) |
140 | #define VC_IRQ_CONFIG_HW 0x848 |
141 | #define VC_IRQ_CONFIG_CASCADE1 0x850 |
142 | #define VC_IRQ_CONFIG_CASCADE2 0x858 |
143 | #define VC_IRQ_CONFIG_REDIST 0x860 |
144 | #define VC_IRQ_CONFIG_IPI_CASC 0x868 |
145 | #define VC_AIB_TX_ORDER_TAG2_REL_TF PPC_BIT(20) |
146 | #define VC_AIB_TX_ORDER_TAG2 0x890 |
147 | #define VC_AT_MACRO_KILL 0x8b0 |
148 | #define VC_AT_MACRO_KILL_MASK 0x8b8 |
149 | #define VC_KILL_VALID PPC_BIT(0) |
150 | #define VC_KILL_TYPE PPC_BITMASK(14, 15) |
151 | #define VC_KILL_IRQ 0 |
152 | #define VC_KILL_IVC 1 |
153 | #define VC_KILL_SBC 2 |
154 | #define VC_KILL_EQD 3 |
155 | #define VC_KILL_BLOCK_ID PPC_BITMASK(27, 31) |
156 | #define VC_KILL_OFFSET PPC_BITMASK(48, 60) |
157 | #define VC_EQC_CACHE_ENABLE 0x908 |
158 | #define VC_EQC_CACHE_EN_MASK PPC_BITMASK(0, 15) |
159 | #define VC_EQC_SCRUB_TRIG 0x910 |
160 | #define VC_EQC_SCRUB_MASK 0x918 |
161 | #define VC_EQC_CONFIG 0x920 |
162 | #define X_VC_EQC_CONFIG 0x214 /* XSCOM register */ |
163 | #define VC_EQC_CONF_SYNC_IPI PPC_BIT(32) |
164 | #define VC_EQC_CONF_SYNC_HW PPC_BIT(33) |
165 | #define VC_EQC_CONF_SYNC_ESC1 PPC_BIT(34) |
166 | #define VC_EQC_CONF_SYNC_ESC2 PPC_BIT(35) |
167 | #define VC_EQC_CONF_SYNC_REDI PPC_BIT(36) |
168 | #define VC_EQC_CONF_EQP_INTERLEAVE PPC_BIT(38) |
169 | #define VC_EQC_CONF_ENABLE_END_s_BIT PPC_BIT(39) |
170 | #define VC_EQC_CONF_ENABLE_END_u_BIT PPC_BIT(40) |
171 | #define VC_EQC_CONF_ENABLE_END_c_BIT PPC_BIT(41) |
172 | #define VC_EQC_CONF_ENABLE_MORE_QSZ PPC_BIT(42) |
173 | #define VC_EQC_CONF_SKIP_ESCALATE PPC_BIT(43) |
174 | #define VC_EQC_CWATCH_SPEC 0x928 |
175 | #define VC_EQC_CWATCH_CONFLICT PPC_BIT(0) |
176 | #define VC_EQC_CWATCH_FULL PPC_BIT(8) |
177 | #define VC_EQC_CWATCH_BLOCKID PPC_BITMASK(28, 31) |
178 | #define VC_EQC_CWATCH_OFFSET PPC_BITMASK(40, 63) |
179 | #define VC_EQC_CWATCH_DAT0 0x930 |
180 | #define VC_EQC_CWATCH_DAT1 0x938 |
181 | #define VC_EQC_CWATCH_DAT2 0x940 |
182 | #define VC_EQC_CWATCH_DAT3 0x948 |
183 | #define VC_IVC_SCRUB_TRIG 0x990 |
184 | #define VC_IVC_SCRUB_MASK 0x998 |
185 | #define VC_SBC_SCRUB_TRIG 0xa10 |
186 | #define VC_SBC_SCRUB_MASK 0xa18 |
187 | #define VC_SCRUB_VALID PPC_BIT(0) |
188 | #define VC_SCRUB_WANT_DISABLE PPC_BIT(1) |
189 | #define VC_SCRUB_WANT_INVAL PPC_BIT(2) /* EQC and SBC only */ |
190 | #define VC_SCRUB_BLOCK_ID PPC_BITMASK(28, 31) |
191 | #define VC_SCRUB_OFFSET PPC_BITMASK(40, 63) |
192 | #define VC_IVC_CACHE_ENABLE 0x988 |
193 | #define VC_IVC_CACHE_EN_MASK PPC_BITMASK(0, 15) |
194 | #define VC_SBC_CACHE_ENABLE 0xa08 |
195 | #define VC_SBC_CACHE_EN_MASK PPC_BITMASK(0, 15) |
196 | #define VC_IVC_CACHE_SCRUB_TRIG 0x990 |
197 | #define VC_IVC_CACHE_SCRUB_MASK 0x998 |
198 | #define VC_SBC_CACHE_ENABLE 0xa08 |
199 | #define VC_SBC_CACHE_SCRUB_TRIG 0xa10 |
200 | #define VC_SBC_CACHE_SCRUB_MASK 0xa18 |
201 | #define VC_SBC_CONFIG 0xa20 |
202 | #define VC_SBC_CONF_CPLX_CIST PPC_BIT(44) |
203 | #define VC_SBC_CONF_CIST_BOTH PPC_BIT(45) |
204 | #define VC_SBC_CONF_NO_UPD_PRF PPC_BIT(59) |
205 | |
206 | /* VC1 register offsets */ |
207 | |
208 | /* VSD Table address register definitions (shared) */ |
209 | #define VST_ADDR_AUTOINC PPC_BIT(0) |
210 | #define VST_TABLE_SELECT PPC_BITMASK(13, 15) |
211 | #define VST_TSEL_IVT 0 |
212 | #define VST_TSEL_SBE 1 |
213 | #define VST_TSEL_EQDT 2 |
214 | #define VST_TSEL_VPDT 3 |
215 | #define VST_TSEL_IRQ 4 /* VC only */ |
216 | #define VST_TABLE_BLOCK PPC_BITMASK(27, 31) |
217 | |
218 | /* Number of queue overflow pages */ |
219 | #define VC_QUEUE_OVF_COUNT 6 |
220 | |
221 | /* |
222 | * Bits in a VSD entry. |
223 | * |
224 | * Note: the address is naturally aligned, we don't use a PPC_BITMASK, |
225 | * but just a mask to apply to the address before OR'ing it in. |
226 | * |
227 | * Note: VSD_FIRMWARE is a SW bit ! It hijacks an unused bit in the |
228 | * VSD and is only meant to be used in indirect mode ! |
229 | */ |
230 | #define VSD_MODE PPC_BITMASK(0, 1) |
231 | #define VSD_MODE_SHARED 1 |
232 | #define VSD_MODE_EXCLUSIVE 2 |
233 | #define VSD_MODE_FORWARD 3 |
234 | #define VSD_ADDRESS_MASK 0x0ffffffffffff000ull |
235 | #define VSD_MIGRATION_REG PPC_BITMASK(52, 55) |
236 | #define VSD_INDIRECT PPC_BIT(56) |
237 | #define VSD_TSIZE PPC_BITMASK(59, 63) |
238 | #define VSD_FIRMWARE PPC_BIT(2) /* Read warning above */ |
239 | |
240 | #define VC_EQC_SYNC_MASK \ |
241 | (VC_EQC_CONF_SYNC_IPI | \ |
242 | VC_EQC_CONF_SYNC_HW | \ |
243 | VC_EQC_CONF_SYNC_ESC1 | \ |
244 | VC_EQC_CONF_SYNC_ESC2 | \ |
245 | VC_EQC_CONF_SYNC_REDI) |
246 | |
247 | |
248 | #endif /* PPC_PNV_XIVE_REGS_H */ |
249 | |