xref: /illumos-gate/usr/src/uts/sun4u/io/px/px_hlib.c (revision 6ed9368a130d7c9a82e574da808d34034da33748)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 
22 /*
23  * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
24  */
25 
26 #include <sys/types.h>
27 #include <sys/cmn_err.h>
28 #include <sys/vmsystm.h>
29 #include <sys/vmem.h>
30 #include <sys/machsystm.h>	/* lddphys() */
31 #include <sys/iommutsb.h>
32 #include <px_obj.h>
33 #include <sys/hotplug/pci/pcie_hp.h>
34 #include "px_regs.h"
35 #include "oberon_regs.h"
36 #include "px_csr.h"
37 #include "px_lib4u.h"
38 #include "px_err.h"
39 
40 /*
41  * Registers that need to be saved and restored during suspend/resume.
42  */
43 
44 /*
45  * Registers in the PEC Module.
46  * LPU_RESET should be set to 0ull during resume
47  *
48  * This array is in reg,chip form. PX_CHIP_UNIDENTIFIED is for all chips
49  * or PX_CHIP_FIRE for Fire only, or PX_CHIP_OBERON for Oberon only.
50  */
51 static struct px_pec_regs {
52 	uint64_t reg;
53 	uint64_t chip;
54 } pec_config_state_regs[] = {
55 	{PEC_CORE_AND_BLOCK_INTERRUPT_ENABLE, PX_CHIP_UNIDENTIFIED},
56 	{ILU_ERROR_LOG_ENABLE, PX_CHIP_UNIDENTIFIED},
57 	{ILU_INTERRUPT_ENABLE, PX_CHIP_UNIDENTIFIED},
58 	{TLU_CONTROL, PX_CHIP_UNIDENTIFIED},
59 	{TLU_OTHER_EVENT_LOG_ENABLE, PX_CHIP_UNIDENTIFIED},
60 	{TLU_OTHER_EVENT_INTERRUPT_ENABLE, PX_CHIP_UNIDENTIFIED},
61 	{TLU_DEVICE_CONTROL, PX_CHIP_UNIDENTIFIED},
62 	{TLU_LINK_CONTROL, PX_CHIP_UNIDENTIFIED},
63 	{TLU_UNCORRECTABLE_ERROR_LOG_ENABLE, PX_CHIP_UNIDENTIFIED},
64 	{TLU_UNCORRECTABLE_ERROR_INTERRUPT_ENABLE, PX_CHIP_UNIDENTIFIED},
65 	{TLU_CORRECTABLE_ERROR_LOG_ENABLE, PX_CHIP_UNIDENTIFIED},
66 	{TLU_CORRECTABLE_ERROR_INTERRUPT_ENABLE, PX_CHIP_UNIDENTIFIED},
67 	{DLU_LINK_LAYER_CONFIG, PX_CHIP_OBERON},
68 	{DLU_FLOW_CONTROL_UPDATE_CONTROL, PX_CHIP_OBERON},
69 	{DLU_TXLINK_REPLAY_TIMER_THRESHOLD, PX_CHIP_OBERON},
70 	{LPU_LINK_LAYER_INTERRUPT_MASK, PX_CHIP_FIRE},
71 	{LPU_PHY_INTERRUPT_MASK, PX_CHIP_FIRE},
72 	{LPU_RECEIVE_PHY_INTERRUPT_MASK, PX_CHIP_FIRE},
73 	{LPU_TRANSMIT_PHY_INTERRUPT_MASK, PX_CHIP_FIRE},
74 	{LPU_GIGABLAZE_GLUE_INTERRUPT_MASK, PX_CHIP_FIRE},
75 	{LPU_LTSSM_INTERRUPT_MASK, PX_CHIP_FIRE},
76 	{LPU_RESET, PX_CHIP_FIRE},
77 	{LPU_DEBUG_CONFIG, PX_CHIP_FIRE},
78 	{LPU_INTERRUPT_MASK, PX_CHIP_FIRE},
79 	{LPU_LINK_LAYER_CONFIG, PX_CHIP_FIRE},
80 	{LPU_FLOW_CONTROL_UPDATE_CONTROL, PX_CHIP_FIRE},
81 	{LPU_TXLINK_FREQUENT_NAK_LATENCY_TIMER_THRESHOLD, PX_CHIP_FIRE},
82 	{LPU_TXLINK_REPLAY_TIMER_THRESHOLD, PX_CHIP_FIRE},
83 	{LPU_REPLAY_BUFFER_MAX_ADDRESS, PX_CHIP_FIRE},
84 	{LPU_TXLINK_RETRY_FIFO_POINTER, PX_CHIP_FIRE},
85 	{LPU_LTSSM_CONFIG2, PX_CHIP_FIRE},
86 	{LPU_LTSSM_CONFIG3, PX_CHIP_FIRE},
87 	{LPU_LTSSM_CONFIG4, PX_CHIP_FIRE},
88 	{LPU_LTSSM_CONFIG5, PX_CHIP_FIRE},
89 	{DMC_CORE_AND_BLOCK_INTERRUPT_ENABLE, PX_CHIP_UNIDENTIFIED},
90 	{DMC_DEBUG_SELECT_FOR_PORT_A, PX_CHIP_UNIDENTIFIED},
91 	{DMC_DEBUG_SELECT_FOR_PORT_B, PX_CHIP_UNIDENTIFIED}
92 };
93 
94 #define	PEC_KEYS	\
95 	((sizeof (pec_config_state_regs))/sizeof (struct px_pec_regs))
96 
97 #define	PEC_SIZE	(PEC_KEYS * sizeof (uint64_t))
98 
99 /*
100  * Registers for the MMU module.
101  * MMU_TTE_CACHE_INVALIDATE needs to be cleared. (-1ull)
102  */
103 static uint64_t mmu_config_state_regs[] = {
104 	MMU_TSB_CONTROL,
105 	MMU_CONTROL_AND_STATUS,
106 	MMU_ERROR_LOG_ENABLE,
107 	MMU_INTERRUPT_ENABLE
108 };
109 #define	MMU_SIZE (sizeof (mmu_config_state_regs))
110 #define	MMU_KEYS (MMU_SIZE / sizeof (uint64_t))
111 
112 /*
113  * Registers for the IB Module
114  */
115 static uint64_t ib_config_state_regs[] = {
116 	IMU_ERROR_LOG_ENABLE,
117 	IMU_INTERRUPT_ENABLE
118 };
119 #define	IB_SIZE (sizeof (ib_config_state_regs))
120 #define	IB_KEYS (IB_SIZE / sizeof (uint64_t))
121 #define	IB_MAP_SIZE (INTERRUPT_MAPPING_ENTRIES * sizeof (uint64_t))
122 
123 /*
124  * Registers for the JBC module.
125  * JBC_ERROR_STATUS_CLEAR needs to be cleared. (-1ull)
126  */
127 static uint64_t	jbc_config_state_regs[] = {
128 	JBUS_PARITY_CONTROL,
129 	JBC_FATAL_RESET_ENABLE,
130 	JBC_CORE_AND_BLOCK_INTERRUPT_ENABLE,
131 	JBC_ERROR_LOG_ENABLE,
132 	JBC_INTERRUPT_ENABLE
133 };
134 #define	JBC_SIZE (sizeof (jbc_config_state_regs))
135 #define	JBC_KEYS (JBC_SIZE / sizeof (uint64_t))
136 
137 /*
138  * Registers for the UBC module.
139  * UBC_ERROR_STATUS_CLEAR needs to be cleared. (-1ull)
140  */
141 static uint64_t	ubc_config_state_regs[] = {
142 	UBC_ERROR_LOG_ENABLE,
143 	UBC_INTERRUPT_ENABLE
144 };
145 #define	UBC_SIZE (sizeof (ubc_config_state_regs))
146 #define	UBC_KEYS (UBC_SIZE / sizeof (uint64_t))
147 
148 static uint64_t	msiq_config_other_regs[] = {
149 	ERR_COR_MAPPING,
150 	ERR_NONFATAL_MAPPING,
151 	ERR_FATAL_MAPPING,
152 	PM_PME_MAPPING,
153 	PME_TO_ACK_MAPPING,
154 	MSI_32_BIT_ADDRESS,
155 	MSI_64_BIT_ADDRESS
156 };
157 #define	MSIQ_OTHER_SIZE	(sizeof (msiq_config_other_regs))
158 #define	MSIQ_OTHER_KEYS	(MSIQ_OTHER_SIZE / sizeof (uint64_t))
159 
160 #define	MSIQ_STATE_SIZE		(EVENT_QUEUE_STATE_ENTRIES * sizeof (uint64_t))
161 #define	MSIQ_MAPPING_SIZE	(MSI_MAPPING_ENTRIES * sizeof (uint64_t))
162 
163 /* OPL tuning variables for link unstable issue */
164 int wait_perst = 5000000; 	/* step 9, default: 5s */
165 int wait_enable_port = 30000;	/* step 11, default: 30ms */
166 int link_retry_count = 2; 	/* step 11, default: 2 */
167 int link_status_check = 400000;	/* step 11, default: 400ms */
168 
169 static uint64_t msiq_suspend(devhandle_t dev_hdl, pxu_t *pxu_p);
170 static void msiq_resume(devhandle_t dev_hdl, pxu_t *pxu_p);
171 static void jbc_init(caddr_t xbc_csr_base, pxu_t *pxu_p);
172 static void ubc_init(caddr_t xbc_csr_base, pxu_t *pxu_p);
173 
174 extern int px_acknak_timer_table[LINK_MAX_PKT_ARR_SIZE][LINK_WIDTH_ARR_SIZE];
175 extern int px_replay_timer_table[LINK_MAX_PKT_ARR_SIZE][LINK_WIDTH_ARR_SIZE];
176 
177 /*
178  * Initialize the bus, but do not enable interrupts.
179  */
180 /* ARGSUSED */
181 void
182 hvio_cb_init(caddr_t xbc_csr_base, pxu_t *pxu_p)
183 {
184 	switch (PX_CHIP_TYPE(pxu_p)) {
185 	case PX_CHIP_OBERON:
186 		ubc_init(xbc_csr_base, pxu_p);
187 		break;
188 	case PX_CHIP_FIRE:
189 		jbc_init(xbc_csr_base, pxu_p);
190 		break;
191 	default:
192 		DBG(DBG_CB, NULL, "hvio_cb_init - unknown chip type: 0x%x\n",
193 		    PX_CHIP_TYPE(pxu_p));
194 		break;
195 	}
196 }
197 
198 /*
199  * Initialize the JBC module, but do not enable interrupts.
200  */
201 /* ARGSUSED */
202 static void
203 jbc_init(caddr_t xbc_csr_base, pxu_t *pxu_p)
204 {
205 	uint64_t val;
206 
207 	/* Check if we need to enable inverted parity */
208 	val = (1ULL << JBUS_PARITY_CONTROL_P_EN);
209 	CSR_XS(xbc_csr_base, JBUS_PARITY_CONTROL, val);
210 	DBG(DBG_CB, NULL, "jbc_init, JBUS_PARITY_CONTROL: 0x%llx\n",
211 	    CSR_XR(xbc_csr_base, JBUS_PARITY_CONTROL));
212 
213 	val = (1 << JBC_FATAL_RESET_ENABLE_SPARE_P_INT_EN) |
214 	    (1 << JBC_FATAL_RESET_ENABLE_MB_PEA_P_INT_EN) |
215 	    (1 << JBC_FATAL_RESET_ENABLE_CPE_P_INT_EN) |
216 	    (1 << JBC_FATAL_RESET_ENABLE_APE_P_INT_EN) |
217 	    (1 << JBC_FATAL_RESET_ENABLE_PIO_CPE_INT_EN) |
218 	    (1 << JBC_FATAL_RESET_ENABLE_JTCEEW_P_INT_EN) |
219 	    (1 << JBC_FATAL_RESET_ENABLE_JTCEEI_P_INT_EN) |
220 	    (1 << JBC_FATAL_RESET_ENABLE_JTCEER_P_INT_EN);
221 	CSR_XS(xbc_csr_base, JBC_FATAL_RESET_ENABLE, val);
222 	DBG(DBG_CB, NULL, "jbc_init, JBC_FATAL_RESET_ENABLE: 0x%llx\n",
223 	    CSR_XR(xbc_csr_base, JBC_FATAL_RESET_ENABLE));
224 
225 	/*
226 	 * Enable merge, jbc and dmc interrupts.
227 	 */
228 	CSR_XS(xbc_csr_base, JBC_CORE_AND_BLOCK_INTERRUPT_ENABLE, -1ull);
229 	DBG(DBG_CB, NULL,
230 	    "jbc_init, JBC_CORE_AND_BLOCK_INTERRUPT_ENABLE: 0x%llx\n",
231 	    CSR_XR(xbc_csr_base, JBC_CORE_AND_BLOCK_INTERRUPT_ENABLE));
232 
233 	/*
234 	 * CSR_V JBC's interrupt regs (log, enable, status, clear)
235 	 */
236 	DBG(DBG_CB, NULL, "jbc_init, JBC_ERROR_LOG_ENABLE: 0x%llx\n",
237 	    CSR_XR(xbc_csr_base, JBC_ERROR_LOG_ENABLE));
238 
239 	DBG(DBG_CB, NULL, "jbc_init, JBC_INTERRUPT_ENABLE: 0x%llx\n",
240 	    CSR_XR(xbc_csr_base, JBC_INTERRUPT_ENABLE));
241 
242 	DBG(DBG_CB, NULL, "jbc_init, JBC_INTERRUPT_STATUS: 0x%llx\n",
243 	    CSR_XR(xbc_csr_base, JBC_INTERRUPT_STATUS));
244 
245 	DBG(DBG_CB, NULL, "jbc_init, JBC_ERROR_STATUS_CLEAR: 0x%llx\n",
246 	    CSR_XR(xbc_csr_base, JBC_ERROR_STATUS_CLEAR));
247 }
248 
249 /*
250  * Initialize the UBC module, but do not enable interrupts.
251  */
252 /* ARGSUSED */
253 static void
254 ubc_init(caddr_t xbc_csr_base, pxu_t *pxu_p)
255 {
256 	/*
257 	 * Enable Uranus bus error log bits.
258 	 */
259 	CSR_XS(xbc_csr_base, UBC_ERROR_LOG_ENABLE, -1ull);
260 	DBG(DBG_CB, NULL, "ubc_init, UBC_ERROR_LOG_ENABLE: 0x%llx\n",
261 	    CSR_XR(xbc_csr_base, UBC_ERROR_LOG_ENABLE));
262 
263 	/*
264 	 * Clear Uranus bus errors.
265 	 */
266 	CSR_XS(xbc_csr_base, UBC_ERROR_STATUS_CLEAR, -1ull);
267 	DBG(DBG_CB, NULL, "ubc_init, UBC_ERROR_STATUS_CLEAR: 0x%llx\n",
268 	    CSR_XR(xbc_csr_base, UBC_ERROR_STATUS_CLEAR));
269 
270 	/*
271 	 * CSR_V UBC's interrupt regs (log, enable, status, clear)
272 	 */
273 	DBG(DBG_CB, NULL, "ubc_init, UBC_ERROR_LOG_ENABLE: 0x%llx\n",
274 	    CSR_XR(xbc_csr_base, UBC_ERROR_LOG_ENABLE));
275 
276 	DBG(DBG_CB, NULL, "ubc_init, UBC_INTERRUPT_ENABLE: 0x%llx\n",
277 	    CSR_XR(xbc_csr_base, UBC_INTERRUPT_ENABLE));
278 
279 	DBG(DBG_CB, NULL, "ubc_init, UBC_INTERRUPT_STATUS: 0x%llx\n",
280 	    CSR_XR(xbc_csr_base, UBC_INTERRUPT_STATUS));
281 
282 	DBG(DBG_CB, NULL, "ubc_init, UBC_ERROR_STATUS_CLEAR: 0x%llx\n",
283 	    CSR_XR(xbc_csr_base, UBC_ERROR_STATUS_CLEAR));
284 }
285 
286 /*
287  * Initialize the module, but do not enable interrupts.
288  */
289 /* ARGSUSED */
290 void
291 hvio_ib_init(caddr_t csr_base, pxu_t *pxu_p)
292 {
293 	/*
294 	 * CSR_V IB's interrupt regs (log, enable, status, clear)
295 	 */
296 	DBG(DBG_IB, NULL, "hvio_ib_init - IMU_ERROR_LOG_ENABLE: 0x%llx\n",
297 	    CSR_XR(csr_base, IMU_ERROR_LOG_ENABLE));
298 
299 	DBG(DBG_IB, NULL, "hvio_ib_init - IMU_INTERRUPT_ENABLE: 0x%llx\n",
300 	    CSR_XR(csr_base, IMU_INTERRUPT_ENABLE));
301 
302 	DBG(DBG_IB, NULL, "hvio_ib_init - IMU_INTERRUPT_STATUS: 0x%llx\n",
303 	    CSR_XR(csr_base, IMU_INTERRUPT_STATUS));
304 
305 	DBG(DBG_IB, NULL, "hvio_ib_init - IMU_ERROR_STATUS_CLEAR: 0x%llx\n",
306 	    CSR_XR(csr_base, IMU_ERROR_STATUS_CLEAR));
307 }
308 
309 /*
310  * Initialize the module, but do not enable interrupts.
311  */
312 /* ARGSUSED */
313 static void
314 ilu_init(caddr_t csr_base, pxu_t *pxu_p)
315 {
316 	/*
317 	 * CSR_V ILU's interrupt regs (log, enable, status, clear)
318 	 */
319 	DBG(DBG_ILU, NULL, "ilu_init - ILU_ERROR_LOG_ENABLE: 0x%llx\n",
320 	    CSR_XR(csr_base, ILU_ERROR_LOG_ENABLE));
321 
322 	DBG(DBG_ILU, NULL, "ilu_init - ILU_INTERRUPT_ENABLE: 0x%llx\n",
323 	    CSR_XR(csr_base, ILU_INTERRUPT_ENABLE));
324 
325 	DBG(DBG_ILU, NULL, "ilu_init - ILU_INTERRUPT_STATUS: 0x%llx\n",
326 	    CSR_XR(csr_base, ILU_INTERRUPT_STATUS));
327 
328 	DBG(DBG_ILU, NULL, "ilu_init - ILU_ERROR_STATUS_CLEAR: 0x%llx\n",
329 	    CSR_XR(csr_base, ILU_ERROR_STATUS_CLEAR));
330 }
331 
332 /*
333  * Initialize the module, but do not enable interrupts.
334  */
335 /* ARGSUSED */
336 static void
337 tlu_init(caddr_t csr_base, pxu_t *pxu_p)
338 {
339 	uint64_t val;
340 
341 	/*
342 	 * CSR_V TLU_CONTROL Expect OBP ???
343 	 */
344 
345 	/*
346 	 * L0s entry default timer value - 7.0 us
347 	 * Completion timeout select default value - 67.1 ms and
348 	 * OBP will set this value.
349 	 *
350 	 * Configuration - Bit 0 should always be 0 for upstream port.
351 	 * Bit 1 is clock - how is this related to the clock bit in TLU
352 	 * Link Control register?  Both are hardware dependent and likely
353 	 * set by OBP.
354 	 *
355 	 * NOTE: Do not set the NPWR_EN bit.  The desired value of this bit
356 	 * will be set by OBP.
357 	 */
358 	val = CSR_XR(csr_base, TLU_CONTROL);
359 	val |= (TLU_CONTROL_L0S_TIM_DEFAULT << TLU_CONTROL_L0S_TIM) |
360 	    TLU_CONTROL_CONFIG_DEFAULT;
361 
362 	/*
363 	 * For Oberon, NPWR_EN is set to 0 to prevent PIO reads from blocking
364 	 * behind non-posted PIO writes. This blocking could cause a master or
365 	 * slave timeout on the host bus if multiple serialized PIOs were to
366 	 * suffer Completion Timeouts because the CTO delays for each PIO ahead
367 	 * of the read would accumulate. Since the Olympus processor can have
368 	 * only 1 PIO outstanding, there is no possibility of PIO accesses from
369 	 * a given CPU to a given device being re-ordered by the PCIe fabric;
370 	 * therefore turning off serialization should be safe from a PCIe
371 	 * ordering perspective.
372 	 */
373 	if (PX_CHIP_TYPE(pxu_p) == PX_CHIP_OBERON)
374 		val &= ~(1ull << TLU_CONTROL_NPWR_EN);
375 
376 	/*
377 	 * Set Detect.Quiet. This will disable automatic link
378 	 * re-training, if the link goes down e.g. power management
379 	 * turns off power to the downstream device. This will enable
380 	 * Fire to go to Drain state, after link down. The drain state
381 	 * forces a reset to the FC state machine, which is required for
382 	 * proper link re-training.
383 	 */
384 	val |= (1ull << TLU_REMAIN_DETECT_QUIET);
385 	CSR_XS(csr_base, TLU_CONTROL, val);
386 	DBG(DBG_TLU, NULL, "tlu_init - TLU_CONTROL: 0x%llx\n",
387 	    CSR_XR(csr_base, TLU_CONTROL));
388 
389 	/*
390 	 * CSR_V TLU_STATUS Expect HW 0x4
391 	 */
392 
393 	/*
394 	 * Only bit [7:0] are currently defined.  Bits [2:0]
395 	 * are the state, which should likely be in state active,
396 	 * 100b.  Bit three is 'recovery', which is not understood.
397 	 * All other bits are reserved.
398 	 */
399 	DBG(DBG_TLU, NULL, "tlu_init - TLU_STATUS: 0x%llx\n",
400 	    CSR_XR(csr_base, TLU_STATUS));
401 
402 	/*
403 	 * CSR_V TLU_PME_TURN_OFF_GENERATE Expect HW 0x0
404 	 */
405 	DBG(DBG_TLU, NULL, "tlu_init - TLU_PME_TURN_OFF_GENERATE: 0x%llx\n",
406 	    CSR_XR(csr_base, TLU_PME_TURN_OFF_GENERATE));
407 
408 	/*
409 	 * CSR_V TLU_INGRESS_CREDITS_INITIAL Expect HW 0x10000200C0
410 	 */
411 
412 	/*
413 	 * Ingress credits initial register.  Bits [39:32] should be
414 	 * 0x10, bits [19:12] should be 0x20, and bits [11:0] should
415 	 * be 0xC0.  These are the reset values, and should be set by
416 	 * HW.
417 	 */
418 	DBG(DBG_TLU, NULL, "tlu_init - TLU_INGRESS_CREDITS_INITIAL: 0x%llx\n",
419 	    CSR_XR(csr_base, TLU_INGRESS_CREDITS_INITIAL));
420 
421 	/*
422 	 * CSR_V TLU_DIAGNOSTIC Expect HW 0x0
423 	 */
424 
425 	/*
426 	 * Diagnostic register - always zero unless we are debugging.
427 	 */
428 	DBG(DBG_TLU, NULL, "tlu_init - TLU_DIAGNOSTIC: 0x%llx\n",
429 	    CSR_XR(csr_base, TLU_DIAGNOSTIC));
430 
431 	/*
432 	 * CSR_V TLU_EGRESS_CREDITS_CONSUMED Expect HW 0x0
433 	 */
434 	DBG(DBG_TLU, NULL, "tlu_init - TLU_EGRESS_CREDITS_CONSUMED: 0x%llx\n",
435 	    CSR_XR(csr_base, TLU_EGRESS_CREDITS_CONSUMED));
436 
437 	/*
438 	 * CSR_V TLU_EGRESS_CREDIT_LIMIT Expect HW 0x0
439 	 */
440 	DBG(DBG_TLU, NULL, "tlu_init - TLU_EGRESS_CREDIT_LIMIT: 0x%llx\n",
441 	    CSR_XR(csr_base, TLU_EGRESS_CREDIT_LIMIT));
442 
443 	/*
444 	 * CSR_V TLU_EGRESS_RETRY_BUFFER Expect HW 0x0
445 	 */
446 	DBG(DBG_TLU, NULL, "tlu_init - TLU_EGRESS_RETRY_BUFFER: 0x%llx\n",
447 	    CSR_XR(csr_base, TLU_EGRESS_RETRY_BUFFER));
448 
449 	/*
450 	 * CSR_V TLU_INGRESS_CREDITS_ALLOCATED Expected HW 0x0
451 	 */
452 	DBG(DBG_TLU, NULL,
453 	    "tlu_init - TLU_INGRESS_CREDITS_ALLOCATED: 0x%llx\n",
454 	    CSR_XR(csr_base, TLU_INGRESS_CREDITS_ALLOCATED));
455 
456 	/*
457 	 * CSR_V TLU_INGRESS_CREDITS_RECEIVED Expected HW 0x0
458 	 */
459 	DBG(DBG_TLU, NULL,
460 	    "tlu_init - TLU_INGRESS_CREDITS_RECEIVED: 0x%llx\n",
461 	    CSR_XR(csr_base, TLU_INGRESS_CREDITS_RECEIVED));
462 
463 	/*
464 	 * CSR_V TLU's interrupt regs (log, enable, status, clear)
465 	 */
466 	DBG(DBG_TLU, NULL,
467 	    "tlu_init - TLU_OTHER_EVENT_LOG_ENABLE: 0x%llx\n",
468 	    CSR_XR(csr_base, TLU_OTHER_EVENT_LOG_ENABLE));
469 
470 	DBG(DBG_TLU, NULL,
471 	    "tlu_init - TLU_OTHER_EVENT_INTERRUPT_ENABLE: 0x%llx\n",
472 	    CSR_XR(csr_base, TLU_OTHER_EVENT_INTERRUPT_ENABLE));
473 
474 	DBG(DBG_TLU, NULL,
475 	    "tlu_init - TLU_OTHER_EVENT_INTERRUPT_STATUS: 0x%llx\n",
476 	    CSR_XR(csr_base, TLU_OTHER_EVENT_INTERRUPT_STATUS));
477 
478 	DBG(DBG_TLU, NULL,
479 	    "tlu_init - TLU_OTHER_EVENT_STATUS_CLEAR: 0x%llx\n",
480 	    CSR_XR(csr_base, TLU_OTHER_EVENT_STATUS_CLEAR));
481 
482 	/*
483 	 * CSR_V TLU_RECEIVE_OTHER_EVENT_HEADER1_LOG Expect HW 0x0
484 	 */
485 	DBG(DBG_TLU, NULL,
486 	    "tlu_init - TLU_RECEIVE_OTHER_EVENT_HEADER1_LOG: 0x%llx\n",
487 	    CSR_XR(csr_base, TLU_RECEIVE_OTHER_EVENT_HEADER1_LOG));
488 
489 	/*
490 	 * CSR_V TLU_RECEIVE_OTHER_EVENT_HEADER2_LOG Expect HW 0x0
491 	 */
492 	DBG(DBG_TLU, NULL,
493 	    "tlu_init - TLU_RECEIVE_OTHER_EVENT_HEADER2_LOG: 0x%llx\n",
494 	    CSR_XR(csr_base, TLU_RECEIVE_OTHER_EVENT_HEADER2_LOG));
495 
496 	/*
497 	 * CSR_V TLU_TRANSMIT_OTHER_EVENT_HEADER1_LOG Expect HW 0x0
498 	 */
499 	DBG(DBG_TLU, NULL,
500 	    "tlu_init - TLU_TRANSMIT_OTHER_EVENT_HEADER1_LOG: 0x%llx\n",
501 	    CSR_XR(csr_base, TLU_TRANSMIT_OTHER_EVENT_HEADER1_LOG));
502 
503 	/*
504 	 * CSR_V TLU_TRANSMIT_OTHER_EVENT_HEADER2_LOG Expect HW 0x0
505 	 */
506 	DBG(DBG_TLU, NULL,
507 	    "tlu_init - TLU_TRANSMIT_OTHER_EVENT_HEADER2_LOG: 0x%llx\n",
508 	    CSR_XR(csr_base, TLU_TRANSMIT_OTHER_EVENT_HEADER2_LOG));
509 
510 	/*
511 	 * CSR_V TLU_PERFORMANCE_COUNTER_SELECT Expect HW 0x0
512 	 */
513 	DBG(DBG_TLU, NULL,
514 	    "tlu_init - TLU_PERFORMANCE_COUNTER_SELECT: 0x%llx\n",
515 	    CSR_XR(csr_base, TLU_PERFORMANCE_COUNTER_SELECT));
516 
517 	/*
518 	 * CSR_V TLU_PERFORMANCE_COUNTER_ZERO Expect HW 0x0
519 	 */
520 	DBG(DBG_TLU, NULL,
521 	    "tlu_init - TLU_PERFORMANCE_COUNTER_ZERO: 0x%llx\n",
522 	    CSR_XR(csr_base, TLU_PERFORMANCE_COUNTER_ZERO));
523 
524 	/*
525 	 * CSR_V TLU_PERFORMANCE_COUNTER_ONE Expect HW 0x0
526 	 */
527 	DBG(DBG_TLU, NULL, "tlu_init - TLU_PERFORMANCE_COUNTER_ONE: 0x%llx\n",
528 	    CSR_XR(csr_base, TLU_PERFORMANCE_COUNTER_ONE));
529 
530 	/*
531 	 * CSR_V TLU_PERFORMANCE_COUNTER_TWO Expect HW 0x0
532 	 */
533 	DBG(DBG_TLU, NULL, "tlu_init - TLU_PERFORMANCE_COUNTER_TWO: 0x%llx\n",
534 	    CSR_XR(csr_base, TLU_PERFORMANCE_COUNTER_TWO));
535 
536 	/*
537 	 * CSR_V TLU_DEBUG_SELECT_A Expect HW 0x0
538 	 */
539 
540 	DBG(DBG_TLU, NULL, "tlu_init - TLU_DEBUG_SELECT_A: 0x%llx\n",
541 	    CSR_XR(csr_base, TLU_DEBUG_SELECT_A));
542 
543 	/*
544 	 * CSR_V TLU_DEBUG_SELECT_B Expect HW 0x0
545 	 */
546 	DBG(DBG_TLU, NULL, "tlu_init - TLU_DEBUG_SELECT_B: 0x%llx\n",
547 	    CSR_XR(csr_base, TLU_DEBUG_SELECT_B));
548 
549 	/*
550 	 * CSR_V TLU_DEVICE_CAPABILITIES Expect HW 0xFC2
551 	 */
552 	DBG(DBG_TLU, NULL, "tlu_init - TLU_DEVICE_CAPABILITIES: 0x%llx\n",
553 	    CSR_XR(csr_base, TLU_DEVICE_CAPABILITIES));
554 
555 	/*
556 	 * CSR_V TLU_DEVICE_CONTROL Expect HW 0x0
557 	 */
558 
559 	/*
560 	 * Bits [14:12] are the Max Read Request Size, which is always 64
561 	 * bytes which is 000b.  Bits [7:5] are Max Payload Size, which
562 	 * start at 128 bytes which is 000b.  This may be revisited if
563 	 * init_child finds greater values.
564 	 */
565 	val = 0x0ull;
566 	CSR_XS(csr_base, TLU_DEVICE_CONTROL, val);
567 	DBG(DBG_TLU, NULL, "tlu_init - TLU_DEVICE_CONTROL: 0x%llx\n",
568 	    CSR_XR(csr_base, TLU_DEVICE_CONTROL));
569 
570 	/*
571 	 * CSR_V TLU_DEVICE_STATUS Expect HW 0x0
572 	 */
573 	DBG(DBG_TLU, NULL, "tlu_init - TLU_DEVICE_STATUS: 0x%llx\n",
574 	    CSR_XR(csr_base, TLU_DEVICE_STATUS));
575 
576 	/*
577 	 * CSR_V TLU_LINK_CAPABILITIES Expect HW 0x15C81
578 	 */
579 	DBG(DBG_TLU, NULL, "tlu_init - TLU_LINK_CAPABILITIES: 0x%llx\n",
580 	    CSR_XR(csr_base, TLU_LINK_CAPABILITIES));
581 
582 	/*
583 	 * CSR_V TLU_LINK_CONTROL Expect OBP 0x40
584 	 */
585 
586 	/*
587 	 * The CLOCK bit should be set by OBP if the hardware dictates,
588 	 * and if it is set then ASPM should be used since then L0s exit
589 	 * latency should be lower than L1 exit latency.
590 	 *
591 	 * Note that we will not enable power management during bringup
592 	 * since it has not been test and is creating some problems in
593 	 * simulation.
594 	 */
595 	val = (1ull << TLU_LINK_CONTROL_CLOCK);
596 
597 	CSR_XS(csr_base, TLU_LINK_CONTROL, val);
598 	DBG(DBG_TLU, NULL, "tlu_init - TLU_LINK_CONTROL: 0x%llx\n",
599 	    CSR_XR(csr_base, TLU_LINK_CONTROL));
600 
601 	/*
602 	 * CSR_V TLU_LINK_STATUS Expect OBP 0x1011
603 	 */
604 
605 	/*
606 	 * Not sure if HW or OBP will be setting this read only
607 	 * register.  Bit 12 is Clock, and it should always be 1
608 	 * signifying that the component uses the same physical
609 	 * clock as the platform.  Bits [9:4] are for the width,
610 	 * with the expected value above signifying a x1 width.
611 	 * Bits [3:0] are the speed, with 1b signifying 2.5 Gb/s,
612 	 * the only speed as yet supported by the PCI-E spec.
613 	 */
614 	DBG(DBG_TLU, NULL, "tlu_init - TLU_LINK_STATUS: 0x%llx\n",
615 	    CSR_XR(csr_base, TLU_LINK_STATUS));
616 
617 	/*
618 	 * CSR_V TLU_SLOT_CAPABILITIES Expect OBP ???
619 	 */
620 
621 	/*
622 	 * Power Limits for the slots.  Will be platform
623 	 * dependent, and OBP will need to set after consulting
624 	 * with the HW guys.
625 	 *
626 	 * Bits [16:15] are power limit scale, which most likely
627 	 * will be 0b signifying 1x.  Bits [14:7] are the Set
628 	 * Power Limit Value, which is a number which is multiplied
629 	 * by the power limit scale to get the actual power limit.
630 	 */
631 	DBG(DBG_TLU, NULL, "tlu_init - TLU_SLOT_CAPABILITIES: 0x%llx\n",
632 	    CSR_XR(csr_base, TLU_SLOT_CAPABILITIES));
633 
634 	/*
635 	 * CSR_V TLU_UNCORRECTABLE_ERROR_LOG_ENABLE Expect Kernel 0x17F011
636 	 */
637 	DBG(DBG_TLU, NULL,
638 	    "tlu_init - TLU_UNCORRECTABLE_ERROR_LOG_ENABLE: 0x%llx\n",
639 	    CSR_XR(csr_base, TLU_UNCORRECTABLE_ERROR_LOG_ENABLE));
640 
641 	/*
642 	 * CSR_V TLU_UNCORRECTABLE_ERROR_INTERRUPT_ENABLE Expect
643 	 * Kernel 0x17F0110017F011
644 	 */
645 	DBG(DBG_TLU, NULL,
646 	    "tlu_init - TLU_UNCORRECTABLE_ERROR_INTERRUPT_ENABLE: 0x%llx\n",
647 	    CSR_XR(csr_base, TLU_UNCORRECTABLE_ERROR_INTERRUPT_ENABLE));
648 
649 	/*
650 	 * CSR_V TLU_UNCORRECTABLE_ERROR_INTERRUPT_STATUS Expect HW 0x0
651 	 */
652 	DBG(DBG_TLU, NULL,
653 	    "tlu_init - TLU_UNCORRECTABLE_ERROR_INTERRUPT_STATUS: 0x%llx\n",
654 	    CSR_XR(csr_base, TLU_UNCORRECTABLE_ERROR_INTERRUPT_STATUS));
655 
656 	/*
657 	 * CSR_V TLU_UNCORRECTABLE_ERROR_STATUS_CLEAR Expect HW 0x0
658 	 */
659 	DBG(DBG_TLU, NULL,
660 	    "tlu_init - TLU_UNCORRECTABLE_ERROR_STATUS_CLEAR: 0x%llx\n",
661 	    CSR_XR(csr_base, TLU_UNCORRECTABLE_ERROR_STATUS_CLEAR));
662 
663 	/*
664 	 * CSR_V TLU_RECEIVE_UNCORRECTABLE_ERROR_HEADER1_LOG HW 0x0
665 	 */
666 	DBG(DBG_TLU, NULL,
667 	    "tlu_init - TLU_RECEIVE_UNCORRECTABLE_ERROR_HEADER1_LOG: 0x%llx\n",
668 	    CSR_XR(csr_base, TLU_RECEIVE_UNCORRECTABLE_ERROR_HEADER1_LOG));
669 
670 	/*
671 	 * CSR_V TLU_RECEIVE_UNCORRECTABLE_ERROR_HEADER2_LOG HW 0x0
672 	 */
673 	DBG(DBG_TLU, NULL,
674 	    "tlu_init - TLU_RECEIVE_UNCORRECTABLE_ERROR_HEADER2_LOG: 0x%llx\n",
675 	    CSR_XR(csr_base, TLU_RECEIVE_UNCORRECTABLE_ERROR_HEADER2_LOG));
676 
677 	/*
678 	 * CSR_V TLU_TRANSMIT_UNCORRECTABLE_ERROR_HEADER1_LOG HW 0x0
679 	 */
680 	DBG(DBG_TLU, NULL,
681 	    "tlu_init - TLU_TRANSMIT_UNCORRECTABLE_ERROR_HEADER1_LOG: 0x%llx\n",
682 	    CSR_XR(csr_base, TLU_TRANSMIT_UNCORRECTABLE_ERROR_HEADER1_LOG));
683 
684 	/*
685 	 * CSR_V TLU_TRANSMIT_UNCORRECTABLE_ERROR_HEADER2_LOG HW 0x0
686 	 */
687 	DBG(DBG_TLU, NULL,
688 	    "tlu_init - TLU_TRANSMIT_UNCORRECTABLE_ERROR_HEADER2_LOG: 0x%llx\n",
689 	    CSR_XR(csr_base, TLU_TRANSMIT_UNCORRECTABLE_ERROR_HEADER2_LOG));
690 
691 
692 	/*
693 	 * CSR_V TLU's CE interrupt regs (log, enable, status, clear)
694 	 * Plus header logs
695 	 */
696 
697 	/*
698 	 * CSR_V TLU_CORRECTABLE_ERROR_LOG_ENABLE Expect Kernel 0x11C1
699 	 */
700 	DBG(DBG_TLU, NULL,
701 	    "tlu_init - TLU_CORRECTABLE_ERROR_LOG_ENABLE: 0x%llx\n",
702 	    CSR_XR(csr_base, TLU_CORRECTABLE_ERROR_LOG_ENABLE));
703 
704 	/*
705 	 * CSR_V TLU_CORRECTABLE_ERROR_INTERRUPT_ENABLE Kernel 0x11C1000011C1
706 	 */
707 	DBG(DBG_TLU, NULL,
708 	    "tlu_init - TLU_CORRECTABLE_ERROR_INTERRUPT_ENABLE: 0x%llx\n",
709 	    CSR_XR(csr_base, TLU_CORRECTABLE_ERROR_INTERRUPT_ENABLE));
710 
711 	/*
712 	 * CSR_V TLU_CORRECTABLE_ERROR_INTERRUPT_STATUS Expect HW 0x0
713 	 */
714 	DBG(DBG_TLU, NULL,
715 	    "tlu_init - TLU_CORRECTABLE_ERROR_INTERRUPT_STATUS: 0x%llx\n",
716 	    CSR_XR(csr_base, TLU_CORRECTABLE_ERROR_INTERRUPT_STATUS));
717 
718 	/*
719 	 * CSR_V TLU_CORRECTABLE_ERROR_STATUS_CLEAR Expect HW 0x0
720 	 */
721 	DBG(DBG_TLU, NULL,
722 	    "tlu_init - TLU_CORRECTABLE_ERROR_STATUS_CLEAR: 0x%llx\n",
723 	    CSR_XR(csr_base, TLU_CORRECTABLE_ERROR_STATUS_CLEAR));
724 }
725 
726 /* ARGSUSED */
727 static void
728 lpu_init(caddr_t csr_base, pxu_t *pxu_p)
729 {
730 	/* Variables used to set the ACKNAK Latency Timer and Replay Timer */
731 	int link_width, max_payload;
732 
733 	uint64_t val;
734 
735 	/*
736 	 * Get the Link Width.  See table above LINK_WIDTH_ARR_SIZE #define
737 	 * Only Link Widths of x1, x4, and x8 are supported.
738 	 * If any width is reported other than x8, set default to x8.
739 	 */
740 	link_width = CSR_FR(csr_base, TLU_LINK_STATUS, WIDTH);
741 	DBG(DBG_LPU, NULL, "lpu_init - Link Width: x%d\n", link_width);
742 
743 	/*
744 	 * Convert link_width to match timer array configuration.
745 	 */
746 	switch (link_width) {
747 	case 1:
748 		link_width = 0;
749 		break;
750 	case 4:
751 		link_width = 1;
752 		break;
753 	case 8:
754 		link_width = 2;
755 		break;
756 	case 16:
757 		link_width = 3;
758 		break;
759 	default:
760 		link_width = 0;
761 	}
762 
763 	/*
764 	 * Get the Max Payload Size.
765 	 * See table above LINK_MAX_PKT_ARR_SIZE #define
766 	 */
767 	max_payload = ((CSR_FR(csr_base, TLU_CONTROL, CONFIG) &
768 	    TLU_CONTROL_MPS_MASK) >> TLU_CONTROL_MPS_SHIFT);
769 
770 	DBG(DBG_LPU, NULL, "lpu_init - May Payload: %d\n",
771 	    (0x80 << max_payload));
772 
773 	/* Make sure the packet size is not greater than 4096 */
774 	max_payload = (max_payload >= LINK_MAX_PKT_ARR_SIZE) ?
775 	    (LINK_MAX_PKT_ARR_SIZE - 1) : max_payload;
776 
777 	/*
778 	 * CSR_V LPU_ID Expect HW 0x0
779 	 */
780 
781 	/*
782 	 * This register has link id, phy id and gigablaze id.
783 	 * Should be set by HW.
784 	 */
785 	DBG(DBG_LPU, NULL, "lpu_init - LPU_ID: 0x%llx\n",
786 	    CSR_XR(csr_base, LPU_ID));
787 
788 	/*
789 	 * CSR_V LPU_RESET Expect Kernel 0x0
790 	 */
791 
792 	/*
793 	 * No reason to have any reset bits high until an error is
794 	 * detected on the link.
795 	 */
796 	val = 0ull;
797 	CSR_XS(csr_base, LPU_RESET, val);
798 	DBG(DBG_LPU, NULL, "lpu_init - LPU_RESET: 0x%llx\n",
799 	    CSR_XR(csr_base, LPU_RESET));
800 
801 	/*
802 	 * CSR_V LPU_DEBUG_STATUS Expect HW 0x0
803 	 */
804 
805 	/*
806 	 * Bits [15:8] are Debug B, and bit [7:0] are Debug A.
807 	 * They are read-only.  What do the 8 bits mean, and
808 	 * how do they get set if they are read only?
809 	 */
810 	DBG(DBG_LPU, NULL, "lpu_init - LPU_DEBUG_STATUS: 0x%llx\n",
811 	    CSR_XR(csr_base, LPU_DEBUG_STATUS));
812 
813 	/*
814 	 * CSR_V LPU_DEBUG_CONFIG Expect Kernel 0x0
815 	 */
816 	DBG(DBG_LPU, NULL, "lpu_init - LPU_DEBUG_CONFIG: 0x%llx\n",
817 	    CSR_XR(csr_base, LPU_DEBUG_CONFIG));
818 
819 	/*
820 	 * CSR_V LPU_LTSSM_CONTROL Expect HW 0x0
821 	 */
822 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LTSSM_CONTROL: 0x%llx\n",
823 	    CSR_XR(csr_base, LPU_LTSSM_CONTROL));
824 
825 	/*
826 	 * CSR_V LPU_LINK_STATUS Expect HW 0x101
827 	 */
828 
829 	/*
830 	 * This register has bits [9:4] for link width, and the
831 	 * default 0x10, means a width of x16.  The problem is
832 	 * this width is not supported according to the TLU
833 	 * link status register.
834 	 */
835 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LINK_STATUS: 0x%llx\n",
836 	    CSR_XR(csr_base, LPU_LINK_STATUS));
837 
838 	/*
839 	 * CSR_V LPU_INTERRUPT_STATUS Expect HW 0x0
840 	 */
841 	DBG(DBG_LPU, NULL, "lpu_init - LPU_INTERRUPT_STATUS: 0x%llx\n",
842 	    CSR_XR(csr_base, LPU_INTERRUPT_STATUS));
843 
844 	/*
845 	 * CSR_V LPU_INTERRUPT_MASK Expect HW 0x0
846 	 */
847 	DBG(DBG_LPU, NULL, "lpu_init - LPU_INTERRUPT_MASK: 0x%llx\n",
848 	    CSR_XR(csr_base, LPU_INTERRUPT_MASK));
849 
850 	/*
851 	 * CSR_V LPU_LINK_PERFORMANCE_COUNTER_SELECT Expect HW 0x0
852 	 */
853 	DBG(DBG_LPU, NULL,
854 	    "lpu_init - LPU_LINK_PERFORMANCE_COUNTER_SELECT: 0x%llx\n",
855 	    CSR_XR(csr_base, LPU_LINK_PERFORMANCE_COUNTER_SELECT));
856 
857 	/*
858 	 * CSR_V LPU_LINK_PERFORMANCE_COUNTER_CONTROL Expect HW 0x0
859 	 */
860 	DBG(DBG_LPU, NULL,
861 	    "lpu_init - LPU_LINK_PERFORMANCE_COUNTER_CONTROL: 0x%llx\n",
862 	    CSR_XR(csr_base, LPU_LINK_PERFORMANCE_COUNTER_CONTROL));
863 
864 	/*
865 	 * CSR_V LPU_LINK_PERFORMANCE_COUNTER1 Expect HW 0x0
866 	 */
867 	DBG(DBG_LPU, NULL,
868 	    "lpu_init - LPU_LINK_PERFORMANCE_COUNTER1: 0x%llx\n",
869 	    CSR_XR(csr_base, LPU_LINK_PERFORMANCE_COUNTER1));
870 
871 	/*
872 	 * CSR_V LPU_LINK_PERFORMANCE_COUNTER1_TEST Expect HW 0x0
873 	 */
874 	DBG(DBG_LPU, NULL,
875 	    "lpu_init - LPU_LINK_PERFORMANCE_COUNTER1_TEST: 0x%llx\n",
876 	    CSR_XR(csr_base, LPU_LINK_PERFORMANCE_COUNTER1_TEST));
877 
878 	/*
879 	 * CSR_V LPU_LINK_PERFORMANCE_COUNTER2 Expect HW 0x0
880 	 */
881 	DBG(DBG_LPU, NULL,
882 	    "lpu_init - LPU_LINK_PERFORMANCE_COUNTER2: 0x%llx\n",
883 	    CSR_XR(csr_base, LPU_LINK_PERFORMANCE_COUNTER2));
884 
885 	/*
886 	 * CSR_V LPU_LINK_PERFORMANCE_COUNTER2_TEST Expect HW 0x0
887 	 */
888 	DBG(DBG_LPU, NULL,
889 	    "lpu_init - LPU_LINK_PERFORMANCE_COUNTER2_TEST: 0x%llx\n",
890 	    CSR_XR(csr_base, LPU_LINK_PERFORMANCE_COUNTER2_TEST));
891 
892 	/*
893 	 * CSR_V LPU_LINK_LAYER_CONFIG Expect HW 0x100
894 	 */
895 
896 	/*
897 	 * This is another place where Max Payload can be set,
898 	 * this time for the link layer.  It will be set to
899 	 * 128B, which is the default, but this will need to
900 	 * be revisited.
901 	 */
902 	val = (1ull << LPU_LINK_LAYER_CONFIG_VC0_EN);
903 	CSR_XS(csr_base, LPU_LINK_LAYER_CONFIG, val);
904 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LINK_LAYER_CONFIG: 0x%llx\n",
905 	    CSR_XR(csr_base, LPU_LINK_LAYER_CONFIG));
906 
907 	/*
908 	 * CSR_V LPU_LINK_LAYER_STATUS Expect OBP 0x5
909 	 */
910 
911 	/*
912 	 * Another R/W status register.  Bit 3, DL up Status, will
913 	 * be set high.  The link state machine status bits [2:0]
914 	 * are set to 0x1, but the status bits are not defined in the
915 	 * PRM.  What does 0x1 mean, what others values are possible
916 	 * and what are thier meanings?
917 	 *
918 	 * This register has been giving us problems in simulation.
919 	 * It has been mentioned that software should not program
920 	 * any registers with WE bits except during debug.  So
921 	 * this register will no longer be programmed.
922 	 */
923 
924 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LINK_LAYER_STATUS: 0x%llx\n",
925 	    CSR_XR(csr_base, LPU_LINK_LAYER_STATUS));
926 
927 	/*
928 	 * CSR_V LPU_LINK_LAYER_INTERRUPT_AND_STATUS_TEST Expect HW 0x0
929 	 */
930 	DBG(DBG_LPU, NULL,
931 	    "lpu_init - LPU_LINK_LAYER_INTERRUPT_AND_STATUS_TEST: 0x%llx\n",
932 	    CSR_XR(csr_base, LPU_LINK_LAYER_INTERRUPT_AND_STATUS_TEST));
933 
934 	/*
935 	 * CSR_V LPU Link Layer interrupt regs (mask, status)
936 	 */
937 	DBG(DBG_LPU, NULL,
938 	    "lpu_init - LPU_LINK_LAYER_INTERRUPT_MASK: 0x%llx\n",
939 	    CSR_XR(csr_base, LPU_LINK_LAYER_INTERRUPT_MASK));
940 
941 	DBG(DBG_LPU, NULL,
942 	    "lpu_init - LPU_LINK_LAYER_INTERRUPT_AND_STATUS: 0x%llx\n",
943 	    CSR_XR(csr_base, LPU_LINK_LAYER_INTERRUPT_AND_STATUS));
944 
945 	/*
946 	 * CSR_V LPU_FLOW_CONTROL_UPDATE_CONTROL Expect OBP 0x7
947 	 */
948 
949 	/*
950 	 * The PRM says that only the first two bits will be set
951 	 * high by default, which will enable flow control for
952 	 * posted and non-posted updates, but NOT completetion
953 	 * updates.
954 	 */
955 	val = (1ull << LPU_FLOW_CONTROL_UPDATE_CONTROL_FC0_U_NP_EN) |
956 	    (1ull << LPU_FLOW_CONTROL_UPDATE_CONTROL_FC0_U_P_EN);
957 	CSR_XS(csr_base, LPU_FLOW_CONTROL_UPDATE_CONTROL, val);
958 	DBG(DBG_LPU, NULL,
959 	    "lpu_init - LPU_FLOW_CONTROL_UPDATE_CONTROL: 0x%llx\n",
960 	    CSR_XR(csr_base, LPU_FLOW_CONTROL_UPDATE_CONTROL));
961 
962 	/*
963 	 * CSR_V LPU_LINK_LAYER_FLOW_CONTROL_UPDATE_TIMEOUT_VALUE
964 	 * Expect OBP 0x1D4C
965 	 */
966 
967 	/*
968 	 * This should be set by OBP.  We'll check to make sure.
969 	 */
970 	DBG(DBG_LPU, NULL, "lpu_init - "
971 	    "LPU_LINK_LAYER_FLOW_CONTROL_UPDATE_TIMEOUT_VALUE: 0x%llx\n",
972 	    CSR_XR(csr_base,
973 	    LPU_LINK_LAYER_FLOW_CONTROL_UPDATE_TIMEOUT_VALUE));
974 
975 	/*
976 	 * CSR_V LPU_LINK_LAYER_VC0_FLOW_CONTROL_UPDATE_TIMER0 Expect OBP ???
977 	 */
978 
979 	/*
980 	 * This register has Flow Control Update Timer values for
981 	 * non-posted and posted requests, bits [30:16] and bits
982 	 * [14:0], respectively.  These are read-only to SW so
983 	 * either HW or OBP needs to set them.
984 	 */
985 	DBG(DBG_LPU, NULL, "lpu_init - "
986 	    "LPU_LINK_LAYER_VC0_FLOW_CONTROL_UPDATE_TIMER0: 0x%llx\n",
987 	    CSR_XR(csr_base,
988 	    LPU_LINK_LAYER_VC0_FLOW_CONTROL_UPDATE_TIMER0));
989 
990 	/*
991 	 * CSR_V LPU_LINK_LAYER_VC0_FLOW_CONTROL_UPDATE_TIMER1 Expect OBP ???
992 	 */
993 
994 	/*
995 	 * Same as timer0 register above, except for bits [14:0]
996 	 * have the timer values for completetions.  Read-only to
997 	 * SW; OBP or HW need to set it.
998 	 */
999 	DBG(DBG_LPU, NULL, "lpu_init - "
1000 	    "LPU_LINK_LAYER_VC0_FLOW_CONTROL_UPDATE_TIMER1: 0x%llx\n",
1001 	    CSR_XR(csr_base,
1002 	    LPU_LINK_LAYER_VC0_FLOW_CONTROL_UPDATE_TIMER1));
1003 
1004 	/*
1005 	 * CSR_V LPU_TXLINK_FREQUENT_NAK_LATENCY_TIMER_THRESHOLD
1006 	 */
1007 	val = px_acknak_timer_table[max_payload][link_width];
1008 	CSR_XS(csr_base, LPU_TXLINK_FREQUENT_NAK_LATENCY_TIMER_THRESHOLD, val);
1009 
1010 	DBG(DBG_LPU, NULL, "lpu_init - "
1011 	    "LPU_TXLINK_FREQUENT_NAK_LATENCY_TIMER_THRESHOLD: 0x%llx\n",
1012 	    CSR_XR(csr_base, LPU_TXLINK_FREQUENT_NAK_LATENCY_TIMER_THRESHOLD));
1013 
1014 	/*
1015 	 * CSR_V LPU_TXLINK_ACKNAK_LATENCY_TIMER Expect HW 0x0
1016 	 */
1017 	DBG(DBG_LPU, NULL,
1018 	    "lpu_init - LPU_TXLINK_ACKNAK_LATENCY_TIMER: 0x%llx\n",
1019 	    CSR_XR(csr_base, LPU_TXLINK_ACKNAK_LATENCY_TIMER));
1020 
1021 	/*
1022 	 * CSR_V LPU_TXLINK_REPLAY_TIMER_THRESHOLD
1023 	 */
1024 	val = px_replay_timer_table[max_payload][link_width];
1025 	CSR_XS(csr_base, LPU_TXLINK_REPLAY_TIMER_THRESHOLD, val);
1026 
1027 	DBG(DBG_LPU, NULL,
1028 	    "lpu_init - LPU_TXLINK_REPLAY_TIMER_THRESHOLD: 0x%llx\n",
1029 	    CSR_XR(csr_base, LPU_TXLINK_REPLAY_TIMER_THRESHOLD));
1030 
1031 	/*
1032 	 * CSR_V LPU_TXLINK_REPLAY_TIMER Expect HW 0x0
1033 	 */
1034 	DBG(DBG_LPU, NULL, "lpu_init - LPU_TXLINK_REPLAY_TIMER: 0x%llx\n",
1035 	    CSR_XR(csr_base, LPU_TXLINK_REPLAY_TIMER));
1036 
1037 	/*
1038 	 * CSR_V LPU_TXLINK_REPLAY_NUMBER_STATUS Expect OBP 0x3
1039 	 */
1040 	DBG(DBG_LPU, NULL,
1041 	    "lpu_init - LPU_TXLINK_REPLAY_NUMBER_STATUS: 0x%llx\n",
1042 	    CSR_XR(csr_base, LPU_TXLINK_REPLAY_NUMBER_STATUS));
1043 
1044 	/*
1045 	 * CSR_V LPU_REPLAY_BUFFER_MAX_ADDRESS Expect OBP 0xB3F
1046 	 */
1047 	DBG(DBG_LPU, NULL,
1048 	    "lpu_init - LPU_REPLAY_BUFFER_MAX_ADDRESS: 0x%llx\n",
1049 	    CSR_XR(csr_base, LPU_REPLAY_BUFFER_MAX_ADDRESS));
1050 
1051 	/*
1052 	 * CSR_V LPU_TXLINK_RETRY_FIFO_POINTER Expect OBP 0xFFFF0000
1053 	 */
1054 	val = ((LPU_TXLINK_RETRY_FIFO_POINTER_RTRY_FIFO_TLPTR_DEFAULT <<
1055 	    LPU_TXLINK_RETRY_FIFO_POINTER_RTRY_FIFO_TLPTR) |
1056 	    (LPU_TXLINK_RETRY_FIFO_POINTER_RTRY_FIFO_HDPTR_DEFAULT <<
1057 	    LPU_TXLINK_RETRY_FIFO_POINTER_RTRY_FIFO_HDPTR));
1058 
1059 	CSR_XS(csr_base, LPU_TXLINK_RETRY_FIFO_POINTER, val);
1060 	DBG(DBG_LPU, NULL,
1061 	    "lpu_init - LPU_TXLINK_RETRY_FIFO_POINTER: 0x%llx\n",
1062 	    CSR_XR(csr_base, LPU_TXLINK_RETRY_FIFO_POINTER));
1063 
1064 	/*
1065 	 * CSR_V LPU_TXLINK_RETRY_FIFO_R_W_POINTER Expect OBP 0x0
1066 	 */
1067 	DBG(DBG_LPU, NULL,
1068 	    "lpu_init - LPU_TXLINK_RETRY_FIFO_R_W_POINTER: 0x%llx\n",
1069 	    CSR_XR(csr_base, LPU_TXLINK_RETRY_FIFO_R_W_POINTER));
1070 
1071 	/*
1072 	 * CSR_V LPU_TXLINK_RETRY_FIFO_CREDIT Expect HW 0x1580
1073 	 */
1074 	DBG(DBG_LPU, NULL,
1075 	    "lpu_init - LPU_TXLINK_RETRY_FIFO_CREDIT: 0x%llx\n",
1076 	    CSR_XR(csr_base, LPU_TXLINK_RETRY_FIFO_CREDIT));
1077 
1078 	/*
1079 	 * CSR_V LPU_TXLINK_SEQUENCE_COUNTER Expect OBP 0xFFF0000
1080 	 */
1081 	DBG(DBG_LPU, NULL, "lpu_init - LPU_TXLINK_SEQUENCE_COUNTER: 0x%llx\n",
1082 	    CSR_XR(csr_base, LPU_TXLINK_SEQUENCE_COUNTER));
1083 
1084 	/*
1085 	 * CSR_V LPU_TXLINK_ACK_SENT_SEQUENCE_NUMBER Expect HW 0xFFF
1086 	 */
1087 	DBG(DBG_LPU, NULL,
1088 	    "lpu_init - LPU_TXLINK_ACK_SENT_SEQUENCE_NUMBER: 0x%llx\n",
1089 	    CSR_XR(csr_base, LPU_TXLINK_ACK_SENT_SEQUENCE_NUMBER));
1090 
1091 	/*
1092 	 * CSR_V LPU_TXLINK_SEQUENCE_COUNT_FIFO_MAX_ADDR Expect OBP 0x157
1093 	 */
1094 
1095 	/*
1096 	 * Test only register.  Will not be programmed.
1097 	 */
1098 	DBG(DBG_LPU, NULL,
1099 	    "lpu_init - LPU_TXLINK_SEQUENCE_COUNT_FIFO_MAX_ADDR: 0x%llx\n",
1100 	    CSR_XR(csr_base, LPU_TXLINK_SEQUENCE_COUNT_FIFO_MAX_ADDR));
1101 
1102 	/*
1103 	 * CSR_V LPU_TXLINK_SEQUENCE_COUNT_FIFO_POINTERS Expect HW 0xFFF0000
1104 	 */
1105 
1106 	/*
1107 	 * Test only register.  Will not be programmed.
1108 	 */
1109 	DBG(DBG_LPU, NULL,
1110 	    "lpu_init - LPU_TXLINK_SEQUENCE_COUNT_FIFO_POINTERS: 0x%llx\n",
1111 	    CSR_XR(csr_base, LPU_TXLINK_SEQUENCE_COUNT_FIFO_POINTERS));
1112 
1113 	/*
1114 	 * CSR_V LPU_TXLINK_SEQUENCE_COUNT_R_W_POINTERS Expect HW 0x0
1115 	 */
1116 	DBG(DBG_LPU, NULL,
1117 	    "lpu_init - LPU_TXLINK_SEQUENCE_COUNT_R_W_POINTERS: 0x%llx\n",
1118 	    CSR_XR(csr_base, LPU_TXLINK_SEQUENCE_COUNT_R_W_POINTERS));
1119 
1120 	/*
1121 	 * CSR_V LPU_TXLINK_TEST_CONTROL Expect HW 0x0
1122 	 */
1123 	DBG(DBG_LPU, NULL, "lpu_init - LPU_TXLINK_TEST_CONTROL: 0x%llx\n",
1124 	    CSR_XR(csr_base, LPU_TXLINK_TEST_CONTROL));
1125 
1126 	/*
1127 	 * CSR_V LPU_TXLINK_MEMORY_ADDRESS_CONTROL Expect HW 0x0
1128 	 */
1129 
1130 	/*
1131 	 * Test only register.  Will not be programmed.
1132 	 */
1133 	DBG(DBG_LPU, NULL,
1134 	    "lpu_init - LPU_TXLINK_MEMORY_ADDRESS_CONTROL: 0x%llx\n",
1135 	    CSR_XR(csr_base, LPU_TXLINK_MEMORY_ADDRESS_CONTROL));
1136 
1137 	/*
1138 	 * CSR_V LPU_TXLINK_MEMORY_DATA_LOAD0 Expect HW 0x0
1139 	 */
1140 	DBG(DBG_LPU, NULL,
1141 	    "lpu_init - LPU_TXLINK_MEMORY_DATA_LOAD0: 0x%llx\n",
1142 	    CSR_XR(csr_base, LPU_TXLINK_MEMORY_DATA_LOAD0));
1143 
1144 	/*
1145 	 * CSR_V LPU_TXLINK_MEMORY_DATA_LOAD1 Expect HW 0x0
1146 	 */
1147 	DBG(DBG_LPU, NULL,
1148 	    "lpu_init - LPU_TXLINK_MEMORY_DATA_LOAD1: 0x%llx\n",
1149 	    CSR_XR(csr_base, LPU_TXLINK_MEMORY_DATA_LOAD1));
1150 
1151 	/*
1152 	 * CSR_V LPU_TXLINK_MEMORY_DATA_LOAD2 Expect HW 0x0
1153 	 */
1154 	DBG(DBG_LPU, NULL,
1155 	    "lpu_init - LPU_TXLINK_MEMORY_DATA_LOAD2: 0x%llx\n",
1156 	    CSR_XR(csr_base, LPU_TXLINK_MEMORY_DATA_LOAD2));
1157 
1158 	/*
1159 	 * CSR_V LPU_TXLINK_MEMORY_DATA_LOAD3 Expect HW 0x0
1160 	 */
1161 	DBG(DBG_LPU, NULL,
1162 	    "lpu_init - LPU_TXLINK_MEMORY_DATA_LOAD3: 0x%llx\n",
1163 	    CSR_XR(csr_base, LPU_TXLINK_MEMORY_DATA_LOAD3));
1164 
1165 	/*
1166 	 * CSR_V LPU_TXLINK_MEMORY_DATA_LOAD4 Expect HW 0x0
1167 	 */
1168 	DBG(DBG_LPU, NULL,
1169 	    "lpu_init - LPU_TXLINK_MEMORY_DATA_LOAD4: 0x%llx\n",
1170 	    CSR_XR(csr_base, LPU_TXLINK_MEMORY_DATA_LOAD4));
1171 
1172 	/*
1173 	 * CSR_V LPU_TXLINK_RETRY_DATA_COUNT Expect HW 0x0
1174 	 */
1175 
1176 	/*
1177 	 * Test only register.  Will not be programmed.
1178 	 */
1179 	DBG(DBG_LPU, NULL, "lpu_init - LPU_TXLINK_RETRY_DATA_COUNT: 0x%llx\n",
1180 	    CSR_XR(csr_base, LPU_TXLINK_RETRY_DATA_COUNT));
1181 
1182 	/*
1183 	 * CSR_V LPU_TXLINK_SEQUENCE_BUFFER_COUNT Expect HW 0x0
1184 	 */
1185 
1186 	/*
1187 	 * Test only register.  Will not be programmed.
1188 	 */
1189 	DBG(DBG_LPU, NULL,
1190 	    "lpu_init - LPU_TXLINK_SEQUENCE_BUFFER_COUNT: 0x%llx\n",
1191 	    CSR_XR(csr_base, LPU_TXLINK_SEQUENCE_BUFFER_COUNT));
1192 
1193 	/*
1194 	 * CSR_V LPU_TXLINK_SEQUENCE_BUFFER_BOTTOM_DATA Expect HW 0x0
1195 	 */
1196 
1197 	/*
1198 	 * Test only register.
1199 	 */
1200 	DBG(DBG_LPU, NULL,
1201 	    "lpu_init - LPU_TXLINK_SEQUENCE_BUFFER_BOTTOM_DATA: 0x%llx\n",
1202 	    CSR_XR(csr_base, LPU_TXLINK_SEQUENCE_BUFFER_BOTTOM_DATA));
1203 
1204 	/*
1205 	 * CSR_V LPU_RXLINK_NEXT_RECEIVE_SEQUENCE_1_COUNTER Expect HW 0x0
1206 	 */
1207 	DBG(DBG_LPU, NULL, "lpu_init - "
1208 	    "LPU_RXLINK_NEXT_RECEIVE_SEQUENCE_1_COUNTER: 0x%llx\n",
1209 	    CSR_XR(csr_base, LPU_RXLINK_NEXT_RECEIVE_SEQUENCE_1_COUNTER));
1210 
1211 	/*
1212 	 * CSR_V LPU_RXLINK_UNSUPPORTED_DLLP_RECEIVED Expect HW 0x0
1213 	 */
1214 
1215 	/*
1216 	 * test only register.
1217 	 */
1218 	DBG(DBG_LPU, NULL,
1219 	    "lpu_init - LPU_RXLINK_UNSUPPORTED_DLLP_RECEIVED: 0x%llx\n",
1220 	    CSR_XR(csr_base, LPU_RXLINK_UNSUPPORTED_DLLP_RECEIVED));
1221 
1222 	/*
1223 	 * CSR_V LPU_RXLINK_TEST_CONTROL Expect HW 0x0
1224 	 */
1225 
1226 	/*
1227 	 * test only register.
1228 	 */
1229 	DBG(DBG_LPU, NULL, "lpu_init - LPU_RXLINK_TEST_CONTROL: 0x%llx\n",
1230 	    CSR_XR(csr_base, LPU_RXLINK_TEST_CONTROL));
1231 
1232 	/*
1233 	 * CSR_V LPU_PHYSICAL_LAYER_CONFIGURATION Expect HW 0x10
1234 	 */
1235 	DBG(DBG_LPU, NULL,
1236 	    "lpu_init - LPU_PHYSICAL_LAYER_CONFIGURATION: 0x%llx\n",
1237 	    CSR_XR(csr_base, LPU_PHYSICAL_LAYER_CONFIGURATION));
1238 
1239 	/*
1240 	 * CSR_V LPU_PHY_LAYER_STATUS Expect HW 0x0
1241 	 */
1242 	DBG(DBG_LPU, NULL, "lpu_init - LPU_PHY_LAYER_STATUS: 0x%llx\n",
1243 	    CSR_XR(csr_base, LPU_PHY_LAYER_STATUS));
1244 
1245 	/*
1246 	 * CSR_V LPU_PHY_INTERRUPT_AND_STATUS_TEST Expect HW 0x0
1247 	 */
1248 	DBG(DBG_LPU, NULL,
1249 	    "lpu_init - LPU_PHY_INTERRUPT_AND_STATUS_TEST: 0x%llx\n",
1250 	    CSR_XR(csr_base, LPU_PHY_INTERRUPT_AND_STATUS_TEST));
1251 
1252 	/*
1253 	 * CSR_V LPU PHY LAYER interrupt regs (mask, status)
1254 	 */
1255 	DBG(DBG_LPU, NULL, "lpu_init - LPU_PHY_INTERRUPT_MASK: 0x%llx\n",
1256 	    CSR_XR(csr_base, LPU_PHY_INTERRUPT_MASK));
1257 
1258 	DBG(DBG_LPU, NULL,
1259 	    "lpu_init - LPU_PHY_LAYER_INTERRUPT_AND_STATUS: 0x%llx\n",
1260 	    CSR_XR(csr_base, LPU_PHY_LAYER_INTERRUPT_AND_STATUS));
1261 
1262 	/*
1263 	 * CSR_V LPU_RECEIVE_PHY_CONFIG Expect HW 0x0
1264 	 */
1265 
1266 	/*
1267 	 * This also needs some explanation.  What is the best value
1268 	 * for the water mark?  Test mode enables which test mode?
1269 	 * Programming model needed for the Receiver Reset Lane N
1270 	 * bits.
1271 	 */
1272 	DBG(DBG_LPU, NULL, "lpu_init - LPU_RECEIVE_PHY_CONFIG: 0x%llx\n",
1273 	    CSR_XR(csr_base, LPU_RECEIVE_PHY_CONFIG));
1274 
1275 	/*
1276 	 * CSR_V LPU_RECEIVE_PHY_STATUS1 Expect HW 0x0
1277 	 */
1278 	DBG(DBG_LPU, NULL, "lpu_init - LPU_RECEIVE_PHY_STATUS1: 0x%llx\n",
1279 	    CSR_XR(csr_base, LPU_RECEIVE_PHY_STATUS1));
1280 
1281 	/*
1282 	 * CSR_V LPU_RECEIVE_PHY_STATUS2 Expect HW 0x0
1283 	 */
1284 	DBG(DBG_LPU, NULL, "lpu_init - LPU_RECEIVE_PHY_STATUS2: 0x%llx\n",
1285 	    CSR_XR(csr_base, LPU_RECEIVE_PHY_STATUS2));
1286 
1287 	/*
1288 	 * CSR_V LPU_RECEIVE_PHY_STATUS3 Expect HW 0x0
1289 	 */
1290 	DBG(DBG_LPU, NULL, "lpu_init - LPU_RECEIVE_PHY_STATUS3: 0x%llx\n",
1291 	    CSR_XR(csr_base, LPU_RECEIVE_PHY_STATUS3));
1292 
1293 	/*
1294 	 * CSR_V LPU_RECEIVE_PHY_INTERRUPT_AND_STATUS_TEST Expect HW 0x0
1295 	 */
1296 	DBG(DBG_LPU, NULL,
1297 	    "lpu_init - LPU_RECEIVE_PHY_INTERRUPT_AND_STATUS_TEST: 0x%llx\n",
1298 	    CSR_XR(csr_base, LPU_RECEIVE_PHY_INTERRUPT_AND_STATUS_TEST));
1299 
1300 	/*
1301 	 * CSR_V LPU RX LAYER interrupt regs (mask, status)
1302 	 */
1303 	DBG(DBG_LPU, NULL,
1304 	    "lpu_init - LPU_RECEIVE_PHY_INTERRUPT_MASK: 0x%llx\n",
1305 	    CSR_XR(csr_base, LPU_RECEIVE_PHY_INTERRUPT_MASK));
1306 
1307 	DBG(DBG_LPU, NULL,
1308 	    "lpu_init - LPU_RECEIVE_PHY_INTERRUPT_AND_STATUS: 0x%llx\n",
1309 	    CSR_XR(csr_base, LPU_RECEIVE_PHY_INTERRUPT_AND_STATUS));
1310 
1311 	/*
1312 	 * CSR_V LPU_TRANSMIT_PHY_CONFIG Expect HW 0x0
1313 	 */
1314 	DBG(DBG_LPU, NULL, "lpu_init - LPU_TRANSMIT_PHY_CONFIG: 0x%llx\n",
1315 	    CSR_XR(csr_base, LPU_TRANSMIT_PHY_CONFIG));
1316 
1317 	/*
1318 	 * CSR_V LPU_TRANSMIT_PHY_STATUS Expect HW 0x0
1319 	 */
1320 	DBG(DBG_LPU, NULL, "lpu_init - LPU_TRANSMIT_PHY_STATUS: 0x%llx\n",
1321 	    CSR_XR(csr_base, LPU_TRANSMIT_PHY_STATUS));
1322 
1323 	/*
1324 	 * CSR_V LPU_TRANSMIT_PHY_INTERRUPT_AND_STATUS_TEST Expect HW 0x0
1325 	 */
1326 	DBG(DBG_LPU, NULL,
1327 	    "lpu_init - LPU_TRANSMIT_PHY_INTERRUPT_AND_STATUS_TEST: 0x%llx\n",
1328 	    CSR_XR(csr_base,
1329 	    LPU_TRANSMIT_PHY_INTERRUPT_AND_STATUS_TEST));
1330 
1331 	/*
1332 	 * CSR_V LPU TX LAYER interrupt regs (mask, status)
1333 	 */
1334 	DBG(DBG_LPU, NULL,
1335 	    "lpu_init - LPU_TRANSMIT_PHY_INTERRUPT_MASK: 0x%llx\n",
1336 	    CSR_XR(csr_base, LPU_TRANSMIT_PHY_INTERRUPT_MASK));
1337 
1338 	DBG(DBG_LPU, NULL,
1339 	    "lpu_init - LPU_TRANSMIT_PHY_INTERRUPT_AND_STATUS: 0x%llx\n",
1340 	    CSR_XR(csr_base, LPU_TRANSMIT_PHY_INTERRUPT_AND_STATUS));
1341 
1342 	/*
1343 	 * CSR_V LPU_TRANSMIT_PHY_STATUS_2 Expect HW 0x0
1344 	 */
1345 	DBG(DBG_LPU, NULL, "lpu_init - LPU_TRANSMIT_PHY_STATUS_2: 0x%llx\n",
1346 	    CSR_XR(csr_base, LPU_TRANSMIT_PHY_STATUS_2));
1347 
1348 	/*
1349 	 * CSR_V LPU_LTSSM_CONFIG1 Expect OBP 0x205
1350 	 */
1351 
1352 	/*
1353 	 * The new PRM has values for LTSSM 8 ns timeout value and
1354 	 * LTSSM 20 ns timeout value.  But what do these values mean?
1355 	 * Most of the other bits are questions as well.
1356 	 *
1357 	 * As such we will use the reset value.
1358 	 */
1359 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LTSSM_CONFIG1: 0x%llx\n",
1360 	    CSR_XR(csr_base, LPU_LTSSM_CONFIG1));
1361 
1362 	/*
1363 	 * CSR_V LPU_LTSSM_CONFIG2 Expect OBP 0x2DC6C0
1364 	 */
1365 
1366 	/*
1367 	 * Again, what does '12 ms timeout value mean'?
1368 	 */
1369 	val = (LPU_LTSSM_CONFIG2_LTSSM_12_TO_DEFAULT <<
1370 	    LPU_LTSSM_CONFIG2_LTSSM_12_TO);
1371 	CSR_XS(csr_base, LPU_LTSSM_CONFIG2, val);
1372 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LTSSM_CONFIG2: 0x%llx\n",
1373 	    CSR_XR(csr_base, LPU_LTSSM_CONFIG2));
1374 
1375 	/*
1376 	 * CSR_V LPU_LTSSM_CONFIG3 Expect OBP 0x7A120
1377 	 */
1378 	val = (LPU_LTSSM_CONFIG3_LTSSM_2_TO_DEFAULT <<
1379 	    LPU_LTSSM_CONFIG3_LTSSM_2_TO);
1380 	CSR_XS(csr_base, LPU_LTSSM_CONFIG3, val);
1381 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LTSSM_CONFIG3: 0x%llx\n",
1382 	    CSR_XR(csr_base, LPU_LTSSM_CONFIG3));
1383 
1384 	/*
1385 	 * CSR_V LPU_LTSSM_CONFIG4 Expect OBP 0x21300
1386 	 */
1387 	val = ((LPU_LTSSM_CONFIG4_DATA_RATE_DEFAULT <<
1388 	    LPU_LTSSM_CONFIG4_DATA_RATE) |
1389 	    (LPU_LTSSM_CONFIG4_N_FTS_DEFAULT <<
1390 	    LPU_LTSSM_CONFIG4_N_FTS));
1391 
1392 	CSR_XS(csr_base, LPU_LTSSM_CONFIG4, val);
1393 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LTSSM_CONFIG4: 0x%llx\n",
1394 	    CSR_XR(csr_base, LPU_LTSSM_CONFIG4));
1395 
1396 	/*
1397 	 * CSR_V LPU_LTSSM_CONFIG5 Expect OBP 0x0
1398 	 */
1399 	val = 0ull;
1400 	CSR_XS(csr_base, LPU_LTSSM_CONFIG5, val);
1401 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LTSSM_CONFIG5: 0x%llx\n",
1402 	    CSR_XR(csr_base, LPU_LTSSM_CONFIG5));
1403 
1404 	/*
1405 	 * CSR_V LPU_LTSSM_STATUS1 Expect OBP 0x0
1406 	 */
1407 
1408 	/*
1409 	 * LTSSM Status registers are test only.
1410 	 */
1411 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LTSSM_STATUS1: 0x%llx\n",
1412 	    CSR_XR(csr_base, LPU_LTSSM_STATUS1));
1413 
1414 	/*
1415 	 * CSR_V LPU_LTSSM_STATUS2 Expect OBP 0x0
1416 	 */
1417 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LTSSM_STATUS2: 0x%llx\n",
1418 	    CSR_XR(csr_base, LPU_LTSSM_STATUS2));
1419 
1420 	/*
1421 	 * CSR_V LPU_LTSSM_INTERRUPT_AND_STATUS_TEST Expect HW 0x0
1422 	 */
1423 	DBG(DBG_LPU, NULL,
1424 	    "lpu_init - LPU_LTSSM_INTERRUPT_AND_STATUS_TEST: 0x%llx\n",
1425 	    CSR_XR(csr_base, LPU_LTSSM_INTERRUPT_AND_STATUS_TEST));
1426 
1427 	/*
1428 	 * CSR_V LPU LTSSM  LAYER interrupt regs (mask, status)
1429 	 */
1430 	DBG(DBG_LPU, NULL, "lpu_init - LPU_LTSSM_INTERRUPT_MASK: 0x%llx\n",
1431 	    CSR_XR(csr_base, LPU_LTSSM_INTERRUPT_MASK));
1432 
1433 	DBG(DBG_LPU, NULL,
1434 	    "lpu_init - LPU_LTSSM_INTERRUPT_AND_STATUS: 0x%llx\n",
1435 	    CSR_XR(csr_base, LPU_LTSSM_INTERRUPT_AND_STATUS));
1436 
1437 	/*
1438 	 * CSR_V LPU_LTSSM_STATUS_WRITE_ENABLE Expect OBP 0x0
1439 	 */
1440 	DBG(DBG_LPU, NULL,
1441 	    "lpu_init - LPU_LTSSM_STATUS_WRITE_ENABLE: 0x%llx\n",
1442 	    CSR_XR(csr_base, LPU_LTSSM_STATUS_WRITE_ENABLE));
1443 
1444 	/*
1445 	 * CSR_V LPU_GIGABLAZE_GLUE_CONFIG1 Expect OBP 0x88407
1446 	 */
1447 	DBG(DBG_LPU, NULL, "lpu_init - LPU_GIGABLAZE_GLUE_CONFIG1: 0x%llx\n",
1448 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_CONFIG1));
1449 
1450 	/*
1451 	 * CSR_V LPU_GIGABLAZE_GLUE_CONFIG2 Expect OBP 0x35
1452 	 */
1453 	DBG(DBG_LPU, NULL, "lpu_init - LPU_GIGABLAZE_GLUE_CONFIG2: 0x%llx\n",
1454 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_CONFIG2));
1455 
1456 	/*
1457 	 * CSR_V LPU_GIGABLAZE_GLUE_CONFIG3 Expect OBP 0x4400FA
1458 	 */
1459 	DBG(DBG_LPU, NULL, "lpu_init - LPU_GIGABLAZE_GLUE_CONFIG3: 0x%llx\n",
1460 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_CONFIG3));
1461 
1462 	/*
1463 	 * CSR_V LPU_GIGABLAZE_GLUE_CONFIG4 Expect OBP 0x1E848
1464 	 */
1465 	DBG(DBG_LPU, NULL, "lpu_init - LPU_GIGABLAZE_GLUE_CONFIG4: 0x%llx\n",
1466 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_CONFIG4));
1467 
1468 	/*
1469 	 * CSR_V LPU_GIGABLAZE_GLUE_STATUS Expect OBP 0x0
1470 	 */
1471 	DBG(DBG_LPU, NULL, "lpu_init - LPU_GIGABLAZE_GLUE_STATUS: 0x%llx\n",
1472 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_STATUS));
1473 
1474 	/*
1475 	 * CSR_V LPU_GIGABLAZE_GLUE_INTERRUPT_AND_STATUS_TEST Expect OBP 0x0
1476 	 */
1477 	DBG(DBG_LPU, NULL, "lpu_init - "
1478 	    "LPU_GIGABLAZE_GLUE_INTERRUPT_AND_STATUS_TEST: 0x%llx\n",
1479 	    CSR_XR(csr_base,
1480 	    LPU_GIGABLAZE_GLUE_INTERRUPT_AND_STATUS_TEST));
1481 
1482 	/*
1483 	 * CSR_V LPU GIGABLASE LAYER interrupt regs (mask, status)
1484 	 */
1485 	DBG(DBG_LPU, NULL,
1486 	    "lpu_init - LPU_GIGABLAZE_GLUE_INTERRUPT_MASK: 0x%llx\n",
1487 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_INTERRUPT_MASK));
1488 
1489 	DBG(DBG_LPU, NULL,
1490 	    "lpu_init - LPU_GIGABLAZE_GLUE_INTERRUPT_AND_STATUS: 0x%llx\n",
1491 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_INTERRUPT_AND_STATUS));
1492 
1493 	/*
1494 	 * CSR_V LPU_GIGABLAZE_GLUE_POWER_DOWN1 Expect HW 0x0
1495 	 */
1496 	DBG(DBG_LPU, NULL,
1497 	    "lpu_init - LPU_GIGABLAZE_GLUE_POWER_DOWN1: 0x%llx\n",
1498 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_POWER_DOWN1));
1499 
1500 	/*
1501 	 * CSR_V LPU_GIGABLAZE_GLUE_POWER_DOWN2 Expect HW 0x0
1502 	 */
1503 	DBG(DBG_LPU, NULL,
1504 	    "lpu_init - LPU_GIGABLAZE_GLUE_POWER_DOWN2: 0x%llx\n",
1505 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_POWER_DOWN2));
1506 
1507 	/*
1508 	 * CSR_V LPU_GIGABLAZE_GLUE_CONFIG5 Expect OBP 0x0
1509 	 */
1510 	DBG(DBG_LPU, NULL, "lpu_init - LPU_GIGABLAZE_GLUE_CONFIG5: 0x%llx\n",
1511 	    CSR_XR(csr_base, LPU_GIGABLAZE_GLUE_CONFIG5));
1512 }
1513 
1514 /* ARGSUSED */
1515 static void
1516 dlu_init(caddr_t csr_base, pxu_t *pxu_p)
1517 {
1518 uint64_t val;
1519 
1520 	CSR_XS(csr_base, DLU_INTERRUPT_MASK, 0ull);
1521 	DBG(DBG_TLU, NULL, "dlu_init - DLU_INTERRUPT_MASK: 0x%llx\n",
1522 	    CSR_XR(csr_base, DLU_INTERRUPT_MASK));
1523 
1524 	val = (1ull << DLU_LINK_LAYER_CONFIG_VC0_EN);
1525 	CSR_XS(csr_base, DLU_LINK_LAYER_CONFIG, val);
1526 	DBG(DBG_TLU, NULL, "dlu_init - DLU_LINK_LAYER_CONFIG: 0x%llx\n",
1527 	    CSR_XR(csr_base, DLU_LINK_LAYER_CONFIG));
1528 
1529 	val = (1ull << DLU_FLOW_CONTROL_UPDATE_CONTROL_FC0_U_NP_EN) |
1530 	    (1ull << DLU_FLOW_CONTROL_UPDATE_CONTROL_FC0_U_P_EN);
1531 
1532 	CSR_XS(csr_base, DLU_FLOW_CONTROL_UPDATE_CONTROL, val);
1533 	DBG(DBG_TLU, NULL, "dlu_init - DLU_FLOW_CONTROL_UPDATE_CONTROL: "
1534 	    "0x%llx\n", CSR_XR(csr_base, DLU_FLOW_CONTROL_UPDATE_CONTROL));
1535 
1536 	val = (DLU_TXLINK_REPLAY_TIMER_THRESHOLD_DEFAULT <<
1537 	    DLU_TXLINK_REPLAY_TIMER_THRESHOLD_RPLAY_TMR_THR);
1538 
1539 	CSR_XS(csr_base, DLU_TXLINK_REPLAY_TIMER_THRESHOLD, val);
1540 
1541 	DBG(DBG_TLU, NULL, "dlu_init - DLU_TXLINK_REPLAY_TIMER_THRESHOLD: "
1542 	    "0x%llx\n", CSR_XR(csr_base, DLU_TXLINK_REPLAY_TIMER_THRESHOLD));
1543 }
1544 
1545 /* ARGSUSED */
1546 static void
1547 dmc_init(caddr_t csr_base, pxu_t *pxu_p)
1548 {
1549 	uint64_t val;
1550 
1551 /*
1552  * CSR_V DMC_CORE_AND_BLOCK_INTERRUPT_ENABLE Expect OBP 0x8000000000000003
1553  */
1554 
1555 	val = -1ull;
1556 	CSR_XS(csr_base, DMC_CORE_AND_BLOCK_INTERRUPT_ENABLE, val);
1557 	DBG(DBG_DMC, NULL,
1558 	    "dmc_init - DMC_CORE_AND_BLOCK_INTERRUPT_ENABLE: 0x%llx\n",
1559 	    CSR_XR(csr_base, DMC_CORE_AND_BLOCK_INTERRUPT_ENABLE));
1560 
1561 	/*
1562 	 * CSR_V DMC_CORE_AND_BLOCK_ERROR_STATUS Expect HW 0x0
1563 	 */
1564 	DBG(DBG_DMC, NULL,
1565 	    "dmc_init - DMC_CORE_AND_BLOCK_ERROR_STATUS: 0x%llx\n",
1566 	    CSR_XR(csr_base, DMC_CORE_AND_BLOCK_ERROR_STATUS));
1567 
1568 	/*
1569 	 * CSR_V DMC_DEBUG_SELECT_FOR_PORT_A Expect HW 0x0
1570 	 */
1571 	val = 0x0ull;
1572 	CSR_XS(csr_base, DMC_DEBUG_SELECT_FOR_PORT_A, val);
1573 	DBG(DBG_DMC, NULL, "dmc_init - DMC_DEBUG_SELECT_FOR_PORT_A: 0x%llx\n",
1574 	    CSR_XR(csr_base, DMC_DEBUG_SELECT_FOR_PORT_A));
1575 
1576 	/*
1577 	 * CSR_V DMC_DEBUG_SELECT_FOR_PORT_B Expect HW 0x0
1578 	 */
1579 	val = 0x0ull;
1580 	CSR_XS(csr_base, DMC_DEBUG_SELECT_FOR_PORT_B, val);
1581 	DBG(DBG_DMC, NULL, "dmc_init - DMC_DEBUG_SELECT_FOR_PORT_B: 0x%llx\n",
1582 	    CSR_XR(csr_base, DMC_DEBUG_SELECT_FOR_PORT_B));
1583 }
1584 
1585 void
1586 hvio_pec_init(caddr_t csr_base, pxu_t *pxu_p)
1587 {
1588 	uint64_t val;
1589 
1590 	ilu_init(csr_base, pxu_p);
1591 	tlu_init(csr_base, pxu_p);
1592 
1593 	switch (PX_CHIP_TYPE(pxu_p)) {
1594 	case PX_CHIP_OBERON:
1595 		dlu_init(csr_base, pxu_p);
1596 		break;
1597 	case PX_CHIP_FIRE:
1598 		lpu_init(csr_base, pxu_p);
1599 		break;
1600 	default:
1601 		DBG(DBG_PEC, NULL, "hvio_pec_init - unknown chip type: 0x%x\n",
1602 		    PX_CHIP_TYPE(pxu_p));
1603 		break;
1604 	}
1605 
1606 	dmc_init(csr_base, pxu_p);
1607 
1608 /*
1609  * CSR_V PEC_CORE_AND_BLOCK_INTERRUPT_ENABLE Expect Kernel 0x800000000000000F
1610  */
1611 
1612 	val = -1ull;
1613 	CSR_XS(csr_base, PEC_CORE_AND_BLOCK_INTERRUPT_ENABLE, val);
1614 	DBG(DBG_PEC, NULL,
1615 	    "hvio_pec_init - PEC_CORE_AND_BLOCK_INTERRUPT_ENABLE: 0x%llx\n",
1616 	    CSR_XR(csr_base, PEC_CORE_AND_BLOCK_INTERRUPT_ENABLE));
1617 
1618 	/*
1619 	 * CSR_V PEC_CORE_AND_BLOCK_INTERRUPT_STATUS Expect HW 0x0
1620 	 */
1621 	DBG(DBG_PEC, NULL,
1622 	    "hvio_pec_init - PEC_CORE_AND_BLOCK_INTERRUPT_STATUS: 0x%llx\n",
1623 	    CSR_XR(csr_base, PEC_CORE_AND_BLOCK_INTERRUPT_STATUS));
1624 }
1625 
1626 /*
1627  * Convert a TTE to physical address
1628  */
1629 static r_addr_t
1630 mmu_tte_to_pa(uint64_t tte, pxu_t *pxu_p)
1631 {
1632 	uint64_t pa_mask;
1633 
1634 	switch (PX_CHIP_TYPE(pxu_p)) {
1635 	case PX_CHIP_OBERON:
1636 		pa_mask = MMU_OBERON_PADDR_MASK;
1637 		break;
1638 	case PX_CHIP_FIRE:
1639 		pa_mask = MMU_FIRE_PADDR_MASK;
1640 		break;
1641 	default:
1642 		DBG(DBG_MMU, NULL, "mmu_tte_to_pa - unknown chip type: 0x%x\n",
1643 		    PX_CHIP_TYPE(pxu_p));
1644 		pa_mask = 0;
1645 		break;
1646 	}
1647 	return ((tte & pa_mask) >> MMU_PAGE_SHIFT);
1648 }
1649 
1650 /*
1651  * Return MMU bypass noncache bit for chip
1652  */
1653 static r_addr_t
1654 mmu_bypass_noncache(pxu_t *pxu_p)
1655 {
1656 	r_addr_t bypass_noncache_bit;
1657 
1658 	switch (PX_CHIP_TYPE(pxu_p)) {
1659 	case PX_CHIP_OBERON:
1660 		bypass_noncache_bit = MMU_OBERON_BYPASS_NONCACHE;
1661 		break;
1662 	case PX_CHIP_FIRE:
1663 		bypass_noncache_bit = MMU_FIRE_BYPASS_NONCACHE;
1664 		break;
1665 	default:
1666 		DBG(DBG_MMU, NULL,
1667 		    "mmu_bypass_nocache - unknown chip type: 0x%x\n",
1668 		    PX_CHIP_TYPE(pxu_p));
1669 		bypass_noncache_bit = 0;
1670 		break;
1671 	}
1672 	return (bypass_noncache_bit);
1673 }
1674 
1675 /*
1676  * Calculate number of TSB entries for the chip.
1677  */
1678 /* ARGSUSED */
1679 static uint_t
1680 mmu_tsb_entries(caddr_t csr_base, pxu_t *pxu_p)
1681 {
1682 	uint64_t tsb_ctrl;
1683 	uint_t obp_tsb_entries, obp_tsb_size;
1684 
1685 	tsb_ctrl = CSR_XR(csr_base, MMU_TSB_CONTROL);
1686 
1687 	obp_tsb_size = tsb_ctrl & 0xF;
1688 
1689 	obp_tsb_entries = MMU_TSBSIZE_TO_TSBENTRIES(obp_tsb_size);
1690 
1691 	return (obp_tsb_entries);
1692 }
1693 
1694 /*
1695  * Initialize the module, but do not enable interrupts.
1696  */
1697 void
1698 hvio_mmu_init(caddr_t csr_base, pxu_t *pxu_p)
1699 {
1700 	uint64_t	val, i, obp_tsb_pa;
1701 	uint_t obp_tsb_entries;
1702 
1703 	bzero(pxu_p->tsb_vaddr, pxu_p->tsb_size);
1704 
1705 	/*
1706 	 * Preserve OBP's TSB
1707 	 */
1708 	obp_tsb_pa = CSR_XR(csr_base, MMU_TSB_CONTROL) & MMU_TSB_PA_MASK;
1709 
1710 	obp_tsb_entries = mmu_tsb_entries(csr_base, pxu_p);
1711 
1712 	/* save "shape" of OBP's TSB for use during Detach */
1713 	pxu_p->obp_tsb_paddr = obp_tsb_pa;
1714 	pxu_p->obp_tsb_entries = obp_tsb_entries;
1715 
1716 	/* For each Valid TTE in OBP's TSB, save its value in px's IOTSB */
1717 	hvio_obptsb_attach(pxu_p);
1718 
1719 	/*
1720 	 * Invalidate the TLB through the diagnostic register.
1721 	 */
1722 
1723 	CSR_XS(csr_base, MMU_TTE_CACHE_INVALIDATE, -1ull);
1724 
1725 	/*
1726 	 * Configure the Fire MMU TSB Control Register.  Determine
1727 	 * the encoding for either 8KB pages (0) or 64KB pages (1).
1728 	 *
1729 	 * Write the most significant 30 bits of the TSB physical address
1730 	 * and the encoded TSB table size.
1731 	 */
1732 	for (i = 8; i && (pxu_p->tsb_size < (0x2000 << i)); i--)
1733 		;
1734 
1735 	val = (((((va_to_pa(pxu_p->tsb_vaddr)) >> 13) << 13) |
1736 	    ((MMU_PAGE_SHIFT == 13) ? 0 : 1) << 8) | i);
1737 
1738 	CSR_XS(csr_base, MMU_TSB_CONTROL, val);
1739 
1740 	/*
1741 	 * Enable the MMU, set the "TSB Cache Snoop Enable",
1742 	 * the "Cache Mode", the "Bypass Enable" and
1743 	 * the "Translation Enable" bits.
1744 	 */
1745 	val = CSR_XR(csr_base, MMU_CONTROL_AND_STATUS);
1746 	val |= ((1ull << MMU_CONTROL_AND_STATUS_SE)
1747 	    |  (MMU_CONTROL_AND_STATUS_ROE_BIT63_ENABLE <<
1748 	    MMU_CONTROL_AND_STATUS_ROE)
1749 	    | (MMU_CONTROL_AND_STATUS_CM_MASK << MMU_CONTROL_AND_STATUS_CM)
1750 	    | (1ull << MMU_CONTROL_AND_STATUS_BE)
1751 	    | (1ull << MMU_CONTROL_AND_STATUS_TE));
1752 
1753 	CSR_XS(csr_base, MMU_CONTROL_AND_STATUS, val);
1754 
1755 	/*
1756 	 * Read the register here to ensure that the previous writes to
1757 	 * the Fire MMU registers have been flushed.  (Technically, this
1758 	 * is not entirely necessary here as we will likely do later reads
1759 	 * during Fire initialization, but it is a small price to pay for
1760 	 * more modular code.)
1761 	 */
1762 	(void) CSR_XR(csr_base, MMU_CONTROL_AND_STATUS);
1763 
1764 	/*
1765 	 * CSR_V TLU's UE interrupt regs (log, enable, status, clear)
1766 	 * Plus header logs
1767 	 */
1768 	DBG(DBG_MMU, NULL, "mmu_init - MMU_ERROR_LOG_ENABLE: 0x%llx\n",
1769 	    CSR_XR(csr_base, MMU_ERROR_LOG_ENABLE));
1770 
1771 	DBG(DBG_MMU, NULL, "mmu_init - MMU_INTERRUPT_ENABLE: 0x%llx\n",
1772 	    CSR_XR(csr_base, MMU_INTERRUPT_ENABLE));
1773 
1774 	DBG(DBG_MMU, NULL, "mmu_init - MMU_INTERRUPT_STATUS: 0x%llx\n",
1775 	    CSR_XR(csr_base, MMU_INTERRUPT_STATUS));
1776 
1777 	DBG(DBG_MMU, NULL, "mmu_init - MMU_ERROR_STATUS_CLEAR: 0x%llx\n",
1778 	    CSR_XR(csr_base, MMU_ERROR_STATUS_CLEAR));
1779 }
1780 
1781 /*
1782  * Generic IOMMU Servies
1783  */
1784 
1785 /* ARGSUSED */
1786 uint64_t
1787 hvio_iommu_map(devhandle_t dev_hdl, pxu_t *pxu_p, tsbid_t tsbid, pages_t pages,
1788     io_attributes_t io_attr, void *addr, size_t pfn_index, int flags)
1789 {
1790 	tsbindex_t	tsb_index = PCI_TSBID_TO_TSBINDEX(tsbid);
1791 	uint64_t	attr = MMU_TTE_V;
1792 	int		i;
1793 
1794 	if (io_attr & PCI_MAP_ATTR_WRITE)
1795 		attr |= MMU_TTE_W;
1796 
1797 	if ((PX_CHIP_TYPE(pxu_p) == PX_CHIP_OBERON) &&
1798 	    (io_attr & PCI_MAP_ATTR_RO))
1799 		attr |= MMU_TTE_RO;
1800 
1801 	if (attr & MMU_TTE_RO) {
1802 		DBG(DBG_MMU, NULL, "hvio_iommu_map: pfn_index=0x%x "
1803 		    "pages=0x%x attr = 0x%lx\n", pfn_index, pages, attr);
1804 	}
1805 
1806 	if (flags & MMU_MAP_PFN) {
1807 		ddi_dma_impl_t	*mp = (ddi_dma_impl_t *)addr;
1808 		for (i = 0; i < pages; i++, pfn_index++, tsb_index++) {
1809 			px_iopfn_t pfn = PX_GET_MP_PFN(mp, pfn_index);
1810 			pxu_p->tsb_vaddr[tsb_index] = MMU_PTOB(pfn) | attr;
1811 
1812 			/*
1813 			 * Oberon will need to flush the corresponding TTEs in
1814 			 * Cache. We only need to flush every cache line.
1815 			 * Extra PIO's are expensive.
1816 			 */
1817 			if (PX_CHIP_TYPE(pxu_p) == PX_CHIP_OBERON) {
1818 				if ((i == (pages-1))||!((tsb_index+1) & 0x7)) {
1819 					CSR_XS(dev_hdl,
1820 					    MMU_TTE_CACHE_FLUSH_ADDRESS,
1821 					    (pxu_p->tsb_paddr+
1822 					    (tsb_index*MMU_TTE_SIZE)));
1823 				}
1824 			}
1825 		}
1826 	} else {
1827 		caddr_t	a = (caddr_t)addr;
1828 		for (i = 0; i < pages; i++, a += MMU_PAGE_SIZE, tsb_index++) {
1829 			px_iopfn_t pfn = hat_getpfnum(kas.a_hat, a);
1830 			pxu_p->tsb_vaddr[tsb_index] = MMU_PTOB(pfn) | attr;
1831 
1832 			/*
1833 			 * Oberon will need to flush the corresponding TTEs in
1834 			 * Cache. We only need to flush every cache line.
1835 			 * Extra PIO's are expensive.
1836 			 */
1837 			if (PX_CHIP_TYPE(pxu_p) == PX_CHIP_OBERON) {
1838 				if ((i == (pages-1))||!((tsb_index+1) & 0x7)) {
1839 					CSR_XS(dev_hdl,
1840 					    MMU_TTE_CACHE_FLUSH_ADDRESS,
1841 					    (pxu_p->tsb_paddr+
1842 					    (tsb_index*MMU_TTE_SIZE)));
1843 				}
1844 			}
1845 		}
1846 	}
1847 
1848 	return (H_EOK);
1849 }
1850 
1851 /* ARGSUSED */
1852 uint64_t
1853 hvio_iommu_demap(devhandle_t dev_hdl, pxu_t *pxu_p, tsbid_t tsbid,
1854     pages_t pages)
1855 {
1856 	tsbindex_t	tsb_index = PCI_TSBID_TO_TSBINDEX(tsbid);
1857 	int		i;
1858 
1859 	for (i = 0; i < pages; i++, tsb_index++) {
1860 		pxu_p->tsb_vaddr[tsb_index] = MMU_INVALID_TTE;
1861 
1862 			/*
1863 			 * Oberon will need to flush the corresponding TTEs in
1864 			 * Cache. We only need to flush every cache line.
1865 			 * Extra PIO's are expensive.
1866 			 */
1867 			if (PX_CHIP_TYPE(pxu_p) == PX_CHIP_OBERON) {
1868 				if ((i == (pages-1))||!((tsb_index+1) & 0x7)) {
1869 					CSR_XS(dev_hdl,
1870 					    MMU_TTE_CACHE_FLUSH_ADDRESS,
1871 					    (pxu_p->tsb_paddr+
1872 					    (tsb_index*MMU_TTE_SIZE)));
1873 				}
1874 			}
1875 	}
1876 
1877 	return (H_EOK);
1878 }
1879 
1880 /* ARGSUSED */
1881 uint64_t
1882 hvio_iommu_getmap(devhandle_t dev_hdl, pxu_t *pxu_p, tsbid_t tsbid,
1883     io_attributes_t *attr_p, r_addr_t *r_addr_p)
1884 {
1885 	tsbindex_t	tsb_index = PCI_TSBID_TO_TSBINDEX(tsbid);
1886 	uint64_t	*tte_addr;
1887 	uint64_t	ret = H_EOK;
1888 
1889 	tte_addr = (uint64_t *)(pxu_p->tsb_vaddr) + tsb_index;
1890 
1891 	if (*tte_addr & MMU_TTE_V) {
1892 		*r_addr_p = mmu_tte_to_pa(*tte_addr, pxu_p);
1893 		*attr_p = (*tte_addr & MMU_TTE_W) ?
1894 		    PCI_MAP_ATTR_WRITE:PCI_MAP_ATTR_READ;
1895 	} else {
1896 		*r_addr_p = 0;
1897 		*attr_p = 0;
1898 		ret = H_ENOMAP;
1899 	}
1900 
1901 	return (ret);
1902 }
1903 
1904 /*
1905  * Copy each Valid OBP TTE from OBP's IOTSB to px's IOTSB.
1906  */
1907 void
1908 hvio_obptsb_attach(pxu_t *pxu_p)
1909 {
1910 	uint64_t	obp_tsb_pa;
1911 	uint64_t	*base_tte_addr;
1912 	uint64_t	i;
1913 	uint_t		obp_tsb_entries;
1914 
1915 	obp_tsb_pa = pxu_p->obp_tsb_paddr;
1916 	obp_tsb_entries = pxu_p->obp_tsb_entries;
1917 
1918 	/*
1919 	 * Compute the starting addr of the area reserved for
1920 	 * OBP's TTEs; OBP's TTEs are stored at the highest addrs
1921 	 * of px's IOTSB.
1922 	 */
1923 	base_tte_addr = pxu_p->tsb_vaddr +
1924 	    ((pxu_p->tsb_size >> 3) - obp_tsb_entries);
1925 
1926 	for (i = 0; i < obp_tsb_entries; i++) {
1927 		uint64_t tte = lddphys(obp_tsb_pa + i * 8);
1928 
1929 		if (!MMU_TTE_VALID(tte))
1930 			continue;
1931 
1932 		base_tte_addr[i] = tte;
1933 	}
1934 }
1935 
1936 /*
1937  * For each Valid OBP TTE, deallocate space from the vmem Arena used
1938  * to manage the TTE's associated DVMA addr space.  (Allocation from
1939  * the DVMA Arena was done in px_mmu_attach).
1940  */
1941 void
1942 hvio_obptsb_detach(px_t *px_p)
1943 {
1944 	uint64_t	obp_tsb_pa;
1945 	uint64_t	i;
1946 	uint_t		obp_tsb_entries;
1947 	uint_t		obp_tsb_bias;
1948 	px_mmu_t	*mmu_p = px_p->px_mmu_p;
1949 	vmem_t		*dvma_map;
1950 	pxu_t		*pxu_p = (pxu_t *)px_p->px_plat_p;
1951 
1952 	dvma_map = mmu_p->mmu_dvma_map;
1953 
1954 	obp_tsb_pa = pxu_p->obp_tsb_paddr;
1955 	obp_tsb_entries = pxu_p->obp_tsb_entries;
1956 	/*
1957 	 * OBP's TTEs are located at the high end of px's IOTSB.
1958 	 * Equivalently, OBP's DVMA space is allocated at the high end
1959 	 * of px's DVMA space.  Compute the bias that references
1960 	 * OBP's first possible page of DVMA space.
1961 	 */
1962 	obp_tsb_bias = (pxu_p->tsb_size >> 3) - obp_tsb_entries;
1963 
1964 	for (i = 0; i < obp_tsb_entries; i++) {
1965 		caddr_t va;
1966 		uint64_t tte = lddphys(obp_tsb_pa + i * 8);
1967 
1968 		if (!MMU_TTE_VALID(tte))
1969 			continue;
1970 
1971 		/* deallocate the TTE's associated page of DVMA space */
1972 		va = (caddr_t)(MMU_PTOB(mmu_p->dvma_base_pg + obp_tsb_bias +
1973 		    i));
1974 		vmem_xfree(dvma_map, va, MMU_PAGE_SIZE);
1975 	}
1976 }
1977 
1978 /* ARGSUSED */
1979 uint64_t
1980 hvio_get_bypass_base(pxu_t *pxu_p)
1981 {
1982 	uint64_t base;
1983 
1984 	switch (PX_CHIP_TYPE(pxu_p)) {
1985 	case PX_CHIP_OBERON:
1986 		base = MMU_OBERON_BYPASS_BASE;
1987 		break;
1988 	case PX_CHIP_FIRE:
1989 		base = MMU_FIRE_BYPASS_BASE;
1990 		break;
1991 	default:
1992 		DBG(DBG_MMU, NULL,
1993 		    "hvio_get_bypass_base - unknown chip type: 0x%x\n",
1994 		    PX_CHIP_TYPE(pxu_p));
1995 		base = 0;
1996 		break;
1997 	}
1998 	return (base);
1999 }
2000 
2001 /* ARGSUSED */
2002 uint64_t
2003 hvio_get_bypass_end(pxu_t *pxu_p)
2004 {
2005 	uint64_t end;
2006 
2007 	switch (PX_CHIP_TYPE(pxu_p)) {
2008 	case PX_CHIP_OBERON:
2009 		end = MMU_OBERON_BYPASS_END;
2010 		break;
2011 	case PX_CHIP_FIRE:
2012 		end = MMU_FIRE_BYPASS_END;
2013 		break;
2014 	default:
2015 		DBG(DBG_MMU, NULL,
2016 		    "hvio_get_bypass_end - unknown chip type: 0x%x\n",
2017 		    PX_CHIP_TYPE(pxu_p));
2018 		end = 0;
2019 		break;
2020 	}
2021 	return (end);
2022 }
2023 
2024 /* ARGSUSED */
2025 uint64_t
2026 hvio_iommu_getbypass(devhandle_t dev_hdl, pxu_t *pxu_p, r_addr_t ra,
2027     io_attributes_t attr, io_addr_t *io_addr_p)
2028 {
2029 	uint64_t	pfn = MMU_BTOP(ra);
2030 
2031 	*io_addr_p = hvio_get_bypass_base(pxu_p) | ra |
2032 	    (pf_is_memory(pfn) ? 0 : mmu_bypass_noncache(pxu_p));
2033 
2034 	return (H_EOK);
2035 }
2036 
2037 /*
2038  * Generic IO Interrupt Servies
2039  */
2040 
2041 /*
2042  * Converts a device specific interrupt number given by the
2043  * arguments devhandle and devino into a system specific ino.
2044  */
2045 /* ARGSUSED */
2046 uint64_t
2047 hvio_intr_devino_to_sysino(devhandle_t dev_hdl, pxu_t *pxu_p, devino_t devino,
2048     sysino_t *sysino)
2049 {
2050 	if (devino > INTERRUPT_MAPPING_ENTRIES) {
2051 		DBG(DBG_IB, NULL, "ino %x is invalid\n", devino);
2052 		return (H_ENOINTR);
2053 	}
2054 
2055 	*sysino = DEVINO_TO_SYSINO(pxu_p->portid, devino);
2056 
2057 	return (H_EOK);
2058 }
2059 
2060 /*
2061  * Returns state in intr_valid_state if the interrupt defined by sysino
2062  * is valid (enabled) or not-valid (disabled).
2063  */
2064 uint64_t
2065 hvio_intr_getvalid(devhandle_t dev_hdl, sysino_t sysino,
2066     intr_valid_state_t *intr_valid_state)
2067 {
2068 	if (CSRA_BR((caddr_t)dev_hdl, INTERRUPT_MAPPING,
2069 	    SYSINO_TO_DEVINO(sysino), ENTRIES_V)) {
2070 		*intr_valid_state = INTR_VALID;
2071 	} else {
2072 		*intr_valid_state = INTR_NOTVALID;
2073 	}
2074 
2075 	return (H_EOK);
2076 }
2077 
2078 /*
2079  * Sets the 'valid' state of the interrupt defined by
2080  * the argument sysino to the state defined by the
2081  * argument intr_valid_state.
2082  */
2083 uint64_t
2084 hvio_intr_setvalid(devhandle_t dev_hdl, sysino_t sysino,
2085     intr_valid_state_t intr_valid_state)
2086 {
2087 	switch (intr_valid_state) {
2088 	case INTR_VALID:
2089 		CSRA_BS((caddr_t)dev_hdl, INTERRUPT_MAPPING,
2090 		    SYSINO_TO_DEVINO(sysino), ENTRIES_V);
2091 		break;
2092 	case INTR_NOTVALID:
2093 		CSRA_BC((caddr_t)dev_hdl, INTERRUPT_MAPPING,
2094 		    SYSINO_TO_DEVINO(sysino), ENTRIES_V);
2095 		break;
2096 	default:
2097 		return (EINVAL);
2098 	}
2099 
2100 	return (H_EOK);
2101 }
2102 
2103 /*
2104  * Returns the current state of the interrupt given by the sysino
2105  * argument.
2106  */
2107 uint64_t
2108 hvio_intr_getstate(devhandle_t dev_hdl, sysino_t sysino,
2109     intr_state_t *intr_state)
2110 {
2111 	intr_state_t state;
2112 
2113 	state = CSRA_FR((caddr_t)dev_hdl, INTERRUPT_CLEAR,
2114 	    SYSINO_TO_DEVINO(sysino), ENTRIES_INT_STATE);
2115 
2116 	switch (state) {
2117 	case INTERRUPT_IDLE_STATE:
2118 		*intr_state = INTR_IDLE_STATE;
2119 		break;
2120 	case INTERRUPT_RECEIVED_STATE:
2121 		*intr_state = INTR_RECEIVED_STATE;
2122 		break;
2123 	case INTERRUPT_PENDING_STATE:
2124 		*intr_state = INTR_DELIVERED_STATE;
2125 		break;
2126 	default:
2127 		return (EINVAL);
2128 	}
2129 
2130 	return (H_EOK);
2131 
2132 }
2133 
2134 /*
2135  * Sets the current state of the interrupt given by the sysino
2136  * argument to the value given in the argument intr_state.
2137  *
2138  * Note: Setting the state to INTR_IDLE clears any pending
2139  * interrupt for sysino.
2140  */
2141 uint64_t
2142 hvio_intr_setstate(devhandle_t dev_hdl, sysino_t sysino,
2143     intr_state_t intr_state)
2144 {
2145 	intr_state_t state;
2146 
2147 	switch (intr_state) {
2148 	case INTR_IDLE_STATE:
2149 		state = INTERRUPT_IDLE_STATE;
2150 		break;
2151 	case INTR_DELIVERED_STATE:
2152 		state = INTERRUPT_PENDING_STATE;
2153 		break;
2154 	default:
2155 		return (EINVAL);
2156 	}
2157 
2158 	CSRA_FS((caddr_t)dev_hdl, INTERRUPT_CLEAR,
2159 	    SYSINO_TO_DEVINO(sysino), ENTRIES_INT_STATE, state);
2160 
2161 	return (H_EOK);
2162 }
2163 
2164 /*
2165  * Returns the cpuid that is the current target of the
2166  * interrupt given by the sysino argument.
2167  *
2168  * The cpuid value returned is undefined if the target
2169  * has not been set via intr_settarget.
2170  */
2171 uint64_t
2172 hvio_intr_gettarget(devhandle_t dev_hdl, pxu_t *pxu_p, sysino_t sysino,
2173     cpuid_t *cpuid)
2174 {
2175 	switch (PX_CHIP_TYPE(pxu_p)) {
2176 	case PX_CHIP_OBERON:
2177 		*cpuid = CSRA_FR((caddr_t)dev_hdl, INTERRUPT_MAPPING,
2178 		    SYSINO_TO_DEVINO(sysino), ENTRIES_T_DESTID);
2179 		break;
2180 	case PX_CHIP_FIRE:
2181 		*cpuid = CSRA_FR((caddr_t)dev_hdl, INTERRUPT_MAPPING,
2182 		    SYSINO_TO_DEVINO(sysino), ENTRIES_T_JPID);
2183 		break;
2184 	default:
2185 		DBG(DBG_CB, NULL, "hvio_intr_gettarget - "
2186 		    "unknown chip type: 0x%x\n", PX_CHIP_TYPE(pxu_p));
2187 		return (EINVAL);
2188 	}
2189 
2190 	return (H_EOK);
2191 }
2192 
2193 /*
2194  * Set the target cpu for the interrupt defined by the argument
2195  * sysino to the target cpu value defined by the argument cpuid.
2196  */
2197 uint64_t
2198 hvio_intr_settarget(devhandle_t dev_hdl, pxu_t *pxu_p, sysino_t sysino,
2199     cpuid_t cpuid)
2200 {
2201 	uint64_t	val, intr_controller;
2202 	uint32_t	ino = SYSINO_TO_DEVINO(sysino);
2203 
2204 	/*
2205 	 * For now, we assign interrupt controller in a round
2206 	 * robin fashion.  Later, we may need to come up with
2207 	 * a more efficient assignment algorithm.
2208 	 */
2209 	intr_controller = 0x1ull << (cpuid % 4);
2210 
2211 	switch (PX_CHIP_TYPE(pxu_p)) {
2212 	case PX_CHIP_OBERON:
2213 		val = (((cpuid &
2214 		    INTERRUPT_MAPPING_ENTRIES_T_DESTID_MASK) <<
2215 		    INTERRUPT_MAPPING_ENTRIES_T_DESTID) |
2216 		    ((intr_controller &
2217 		    INTERRUPT_MAPPING_ENTRIES_INT_CNTRL_NUM_MASK)
2218 		    << INTERRUPT_MAPPING_ENTRIES_INT_CNTRL_NUM));
2219 		break;
2220 	case PX_CHIP_FIRE:
2221 		val = (((cpuid & INTERRUPT_MAPPING_ENTRIES_T_JPID_MASK) <<
2222 		    INTERRUPT_MAPPING_ENTRIES_T_JPID) |
2223 		    ((intr_controller &
2224 		    INTERRUPT_MAPPING_ENTRIES_INT_CNTRL_NUM_MASK)
2225 		    << INTERRUPT_MAPPING_ENTRIES_INT_CNTRL_NUM));
2226 		break;
2227 	default:
2228 		DBG(DBG_CB, NULL, "hvio_intr_settarget - "
2229 		    "unknown chip type: 0x%x\n", PX_CHIP_TYPE(pxu_p));
2230 		return (EINVAL);
2231 	}
2232 
2233 	/* For EQ interrupts, set DATA MONDO bit */
2234 	if ((ino >= EQ_1ST_DEVINO) && (ino < (EQ_1ST_DEVINO + EQ_CNT)))
2235 		val |= (0x1ull << INTERRUPT_MAPPING_ENTRIES_MDO_MODE);
2236 
2237 	CSRA_XS((caddr_t)dev_hdl, INTERRUPT_MAPPING, ino, val);
2238 
2239 	return (H_EOK);
2240 }
2241 
2242 /*
2243  * MSIQ Functions:
2244  */
2245 uint64_t
2246 hvio_msiq_init(devhandle_t dev_hdl, pxu_t *pxu_p)
2247 {
2248 	CSRA_XS((caddr_t)dev_hdl, EVENT_QUEUE_BASE_ADDRESS, 0,
2249 	    (uint64_t)pxu_p->msiq_mapped_p);
2250 	DBG(DBG_IB, NULL,
2251 	    "hvio_msiq_init: EVENT_QUEUE_BASE_ADDRESS 0x%llx\n",
2252 	    CSR_XR((caddr_t)dev_hdl, EVENT_QUEUE_BASE_ADDRESS));
2253 
2254 	CSRA_XS((caddr_t)dev_hdl, INTERRUPT_MONDO_DATA_0, 0,
2255 	    (uint64_t)ID_TO_IGN(PX_CHIP_TYPE(pxu_p),
2256 	    pxu_p->portid) << INO_BITS);
2257 	DBG(DBG_IB, NULL, "hvio_msiq_init: "
2258 	    "INTERRUPT_MONDO_DATA_0: 0x%llx\n",
2259 	    CSR_XR((caddr_t)dev_hdl, INTERRUPT_MONDO_DATA_0));
2260 
2261 	return (H_EOK);
2262 }
2263 
2264 uint64_t
2265 hvio_msiq_getvalid(devhandle_t dev_hdl, msiqid_t msiq_id,
2266     pci_msiq_valid_state_t *msiq_valid_state)
2267 {
2268 	uint32_t	eq_state;
2269 	uint64_t	ret = H_EOK;
2270 
2271 	eq_state = CSRA_FR((caddr_t)dev_hdl, EVENT_QUEUE_STATE,
2272 	    msiq_id, ENTRIES_STATE);
2273 
2274 	switch (eq_state) {
2275 	case EQ_IDLE_STATE:
2276 		*msiq_valid_state = PCI_MSIQ_INVALID;
2277 		break;
2278 	case EQ_ACTIVE_STATE:
2279 	case EQ_ERROR_STATE:
2280 		*msiq_valid_state = PCI_MSIQ_VALID;
2281 		break;
2282 	default:
2283 		ret = H_EIO;
2284 		break;
2285 	}
2286 
2287 	return (ret);
2288 }
2289 
2290 uint64_t
2291 hvio_msiq_setvalid(devhandle_t dev_hdl, msiqid_t msiq_id,
2292     pci_msiq_valid_state_t msiq_valid_state)
2293 {
2294 	uint64_t	ret = H_EOK;
2295 
2296 	switch (msiq_valid_state) {
2297 	case PCI_MSIQ_INVALID:
2298 		CSRA_BS((caddr_t)dev_hdl, EVENT_QUEUE_CONTROL_CLEAR,
2299 		    msiq_id, ENTRIES_DIS);
2300 		break;
2301 	case PCI_MSIQ_VALID:
2302 		CSRA_BS((caddr_t)dev_hdl, EVENT_QUEUE_CONTROL_SET,
2303 		    msiq_id, ENTRIES_EN);
2304 		break;
2305 	default:
2306 		ret = H_EINVAL;
2307 		break;
2308 	}
2309 
2310 	return (ret);
2311 }
2312 
2313 uint64_t
2314 hvio_msiq_getstate(devhandle_t dev_hdl, msiqid_t msiq_id,
2315     pci_msiq_state_t *msiq_state)
2316 {
2317 	uint32_t	eq_state;
2318 	uint64_t	ret = H_EOK;
2319 
2320 	eq_state = CSRA_FR((caddr_t)dev_hdl, EVENT_QUEUE_STATE,
2321 	    msiq_id, ENTRIES_STATE);
2322 
2323 	switch (eq_state) {
2324 	case EQ_IDLE_STATE:
2325 	case EQ_ACTIVE_STATE:
2326 		*msiq_state = PCI_MSIQ_STATE_IDLE;
2327 		break;
2328 	case EQ_ERROR_STATE:
2329 		*msiq_state = PCI_MSIQ_STATE_ERROR;
2330 		break;
2331 	default:
2332 		ret = H_EIO;
2333 	}
2334 
2335 	return (ret);
2336 }
2337 
2338 uint64_t
2339 hvio_msiq_setstate(devhandle_t dev_hdl, msiqid_t msiq_id,
2340     pci_msiq_state_t msiq_state)
2341 {
2342 	uint32_t	eq_state;
2343 	uint64_t	ret = H_EOK;
2344 
2345 	eq_state = CSRA_FR((caddr_t)dev_hdl, EVENT_QUEUE_STATE,
2346 	    msiq_id, ENTRIES_STATE);
2347 
2348 	switch (eq_state) {
2349 	case EQ_IDLE_STATE:
2350 		if (msiq_state == PCI_MSIQ_STATE_ERROR)
2351 			ret = H_EIO;
2352 		break;
2353 	case EQ_ACTIVE_STATE:
2354 		if (msiq_state == PCI_MSIQ_STATE_ERROR)
2355 			CSRA_BS((caddr_t)dev_hdl, EVENT_QUEUE_CONTROL_SET,
2356 			    msiq_id, ENTRIES_ENOVERR);
2357 		else
2358 			ret = H_EIO;
2359 		break;
2360 	case EQ_ERROR_STATE:
2361 		if (msiq_state == PCI_MSIQ_STATE_IDLE)
2362 			CSRA_BS((caddr_t)dev_hdl, EVENT_QUEUE_CONTROL_CLEAR,
2363 			    msiq_id, ENTRIES_E2I);
2364 		else
2365 			ret = H_EIO;
2366 		break;
2367 	default:
2368 		ret = H_EIO;
2369 	}
2370 
2371 	return (ret);
2372 }
2373 
2374 uint64_t
2375 hvio_msiq_gethead(devhandle_t dev_hdl, msiqid_t msiq_id,
2376     msiqhead_t *msiq_head)
2377 {
2378 	*msiq_head = CSRA_FR((caddr_t)dev_hdl, EVENT_QUEUE_HEAD,
2379 	    msiq_id, ENTRIES_HEAD);
2380 
2381 	return (H_EOK);
2382 }
2383 
2384 uint64_t
2385 hvio_msiq_sethead(devhandle_t dev_hdl, msiqid_t msiq_id,
2386     msiqhead_t msiq_head)
2387 {
2388 	CSRA_FS((caddr_t)dev_hdl, EVENT_QUEUE_HEAD, msiq_id,
2389 	    ENTRIES_HEAD, msiq_head);
2390 
2391 	return (H_EOK);
2392 }
2393 
2394 uint64_t
2395 hvio_msiq_gettail(devhandle_t dev_hdl, msiqid_t msiq_id,
2396     msiqtail_t *msiq_tail)
2397 {
2398 	*msiq_tail = CSRA_FR((caddr_t)dev_hdl, EVENT_QUEUE_TAIL,
2399 	    msiq_id, ENTRIES_TAIL);
2400 
2401 	return (H_EOK);
2402 }
2403 
2404 /*
2405  * MSI Functions:
2406  */
2407 uint64_t
2408 hvio_msi_init(devhandle_t dev_hdl, uint64_t addr32, uint64_t addr64)
2409 {
2410 	/* PCI MEM 32 resources to perform 32 bit MSI transactions */
2411 	CSRA_FS((caddr_t)dev_hdl, MSI_32_BIT_ADDRESS, 0,
2412 	    ADDR, (uint64_t)addr32 >> MSI_32_BIT_ADDRESS_ADDR);
2413 	DBG(DBG_IB, NULL, "hvio_msi_init: MSI_32_BIT_ADDRESS: 0x%llx\n",
2414 	    CSR_XR((caddr_t)dev_hdl, MSI_32_BIT_ADDRESS));
2415 
2416 	/* Reserve PCI MEM 64 resources to perform 64 bit MSI transactions */
2417 	CSRA_FS((caddr_t)dev_hdl, MSI_64_BIT_ADDRESS, 0,
2418 	    ADDR, (uint64_t)addr64 >> MSI_64_BIT_ADDRESS_ADDR);
2419 	DBG(DBG_IB, NULL, "hvio_msi_init: MSI_64_BIT_ADDRESS: 0x%llx\n",
2420 	    CSR_XR((caddr_t)dev_hdl, MSI_64_BIT_ADDRESS));
2421 
2422 	return (H_EOK);
2423 }
2424 
2425 uint64_t
2426 hvio_msi_getmsiq(devhandle_t dev_hdl, msinum_t msi_num,
2427     msiqid_t *msiq_id)
2428 {
2429 	*msiq_id = CSRA_FR((caddr_t)dev_hdl, MSI_MAPPING,
2430 	    msi_num, ENTRIES_EQNUM);
2431 
2432 	return (H_EOK);
2433 }
2434 
2435 uint64_t
2436 hvio_msi_setmsiq(devhandle_t dev_hdl, msinum_t msi_num,
2437     msiqid_t msiq_id)
2438 {
2439 	CSRA_FS((caddr_t)dev_hdl, MSI_MAPPING, msi_num,
2440 	    ENTRIES_EQNUM, msiq_id);
2441 
2442 	return (H_EOK);
2443 }
2444 
2445 uint64_t
2446 hvio_msi_getvalid(devhandle_t dev_hdl, msinum_t msi_num,
2447     pci_msi_valid_state_t *msi_valid_state)
2448 {
2449 	*msi_valid_state = CSRA_BR((caddr_t)dev_hdl, MSI_MAPPING,
2450 	    msi_num, ENTRIES_V);
2451 
2452 	return (H_EOK);
2453 }
2454 
2455 uint64_t
2456 hvio_msi_setvalid(devhandle_t dev_hdl, msinum_t msi_num,
2457     pci_msi_valid_state_t msi_valid_state)
2458 {
2459 	uint64_t	ret = H_EOK;
2460 
2461 	switch (msi_valid_state) {
2462 	case PCI_MSI_VALID:
2463 		CSRA_BS((caddr_t)dev_hdl, MSI_MAPPING, msi_num,
2464 		    ENTRIES_V);
2465 		break;
2466 	case PCI_MSI_INVALID:
2467 		CSRA_BC((caddr_t)dev_hdl, MSI_MAPPING, msi_num,
2468 		    ENTRIES_V);
2469 		break;
2470 	default:
2471 		ret = H_EINVAL;
2472 	}
2473 
2474 	return (ret);
2475 }
2476 
2477 uint64_t
2478 hvio_msi_getstate(devhandle_t dev_hdl, msinum_t msi_num,
2479     pci_msi_state_t *msi_state)
2480 {
2481 	*msi_state = CSRA_BR((caddr_t)dev_hdl, MSI_MAPPING,
2482 	    msi_num, ENTRIES_EQWR_N);
2483 
2484 	return (H_EOK);
2485 }
2486 
2487 uint64_t
2488 hvio_msi_setstate(devhandle_t dev_hdl, msinum_t msi_num,
2489     pci_msi_state_t msi_state)
2490 {
2491 	uint64_t	ret = H_EOK;
2492 
2493 	switch (msi_state) {
2494 	case PCI_MSI_STATE_IDLE:
2495 		CSRA_BS((caddr_t)dev_hdl, MSI_CLEAR, msi_num,
2496 		    ENTRIES_EQWR_N);
2497 		break;
2498 	case PCI_MSI_STATE_DELIVERED:
2499 	default:
2500 		ret = H_EINVAL;
2501 		break;
2502 	}
2503 
2504 	return (ret);
2505 }
2506 
2507 /*
2508  * MSG Functions:
2509  */
2510 uint64_t
2511 hvio_msg_getmsiq(devhandle_t dev_hdl, pcie_msg_type_t msg_type,
2512     msiqid_t *msiq_id)
2513 {
2514 	uint64_t	ret = H_EOK;
2515 
2516 	switch (msg_type) {
2517 	case PCIE_PME_MSG:
2518 		*msiq_id = CSR_FR((caddr_t)dev_hdl, PM_PME_MAPPING, EQNUM);
2519 		break;
2520 	case PCIE_PME_ACK_MSG:
2521 		*msiq_id = CSR_FR((caddr_t)dev_hdl, PME_TO_ACK_MAPPING,
2522 		    EQNUM);
2523 		break;
2524 	case PCIE_CORR_MSG:
2525 		*msiq_id = CSR_FR((caddr_t)dev_hdl, ERR_COR_MAPPING, EQNUM);
2526 		break;
2527 	case PCIE_NONFATAL_MSG:
2528 		*msiq_id = CSR_FR((caddr_t)dev_hdl, ERR_NONFATAL_MAPPING,
2529 		    EQNUM);
2530 		break;
2531 	case PCIE_FATAL_MSG:
2532 		*msiq_id = CSR_FR((caddr_t)dev_hdl, ERR_FATAL_MAPPING, EQNUM);
2533 		break;
2534 	default:
2535 		ret = H_EINVAL;
2536 		break;
2537 	}
2538 
2539 	return (ret);
2540 }
2541 
2542 uint64_t
2543 hvio_msg_setmsiq(devhandle_t dev_hdl, pcie_msg_type_t msg_type,
2544     msiqid_t msiq_id)
2545 {
2546 	uint64_t	ret = H_EOK;
2547 
2548 	switch (msg_type) {
2549 	case PCIE_PME_MSG:
2550 		CSR_FS((caddr_t)dev_hdl, PM_PME_MAPPING, EQNUM, msiq_id);
2551 		break;
2552 	case PCIE_PME_ACK_MSG:
2553 		CSR_FS((caddr_t)dev_hdl, PME_TO_ACK_MAPPING, EQNUM, msiq_id);
2554 		break;
2555 	case PCIE_CORR_MSG:
2556 		CSR_FS((caddr_t)dev_hdl, ERR_COR_MAPPING, EQNUM, msiq_id);
2557 		break;
2558 	case PCIE_NONFATAL_MSG:
2559 		CSR_FS((caddr_t)dev_hdl, ERR_NONFATAL_MAPPING, EQNUM, msiq_id);
2560 		break;
2561 	case PCIE_FATAL_MSG:
2562 		CSR_FS((caddr_t)dev_hdl, ERR_FATAL_MAPPING, EQNUM, msiq_id);
2563 		break;
2564 	default:
2565 		ret = H_EINVAL;
2566 		break;
2567 	}
2568 
2569 	return (ret);
2570 }
2571 
2572 uint64_t
2573 hvio_msg_getvalid(devhandle_t dev_hdl, pcie_msg_type_t msg_type,
2574     pcie_msg_valid_state_t *msg_valid_state)
2575 {
2576 	uint64_t	ret = H_EOK;
2577 
2578 	switch (msg_type) {
2579 	case PCIE_PME_MSG:
2580 		*msg_valid_state = CSR_BR((caddr_t)dev_hdl, PM_PME_MAPPING, V);
2581 		break;
2582 	case PCIE_PME_ACK_MSG:
2583 		*msg_valid_state = CSR_BR((caddr_t)dev_hdl,
2584 		    PME_TO_ACK_MAPPING, V);
2585 		break;
2586 	case PCIE_CORR_MSG:
2587 		*msg_valid_state = CSR_BR((caddr_t)dev_hdl, ERR_COR_MAPPING, V);
2588 		break;
2589 	case PCIE_NONFATAL_MSG:
2590 		*msg_valid_state = CSR_BR((caddr_t)dev_hdl,
2591 		    ERR_NONFATAL_MAPPING, V);
2592 		break;
2593 	case PCIE_FATAL_MSG:
2594 		*msg_valid_state = CSR_BR((caddr_t)dev_hdl, ERR_FATAL_MAPPING,
2595 		    V);
2596 		break;
2597 	default:
2598 		ret = H_EINVAL;
2599 		break;
2600 	}
2601 
2602 	return (ret);
2603 }
2604 
2605 uint64_t
2606 hvio_msg_setvalid(devhandle_t dev_hdl, pcie_msg_type_t msg_type,
2607     pcie_msg_valid_state_t msg_valid_state)
2608 {
2609 	uint64_t	ret = H_EOK;
2610 
2611 	switch (msg_valid_state) {
2612 	case PCIE_MSG_VALID:
2613 		switch (msg_type) {
2614 		case PCIE_PME_MSG:
2615 			CSR_BS((caddr_t)dev_hdl, PM_PME_MAPPING, V);
2616 			break;
2617 		case PCIE_PME_ACK_MSG:
2618 			CSR_BS((caddr_t)dev_hdl, PME_TO_ACK_MAPPING, V);
2619 			break;
2620 		case PCIE_CORR_MSG:
2621 			CSR_BS((caddr_t)dev_hdl, ERR_COR_MAPPING, V);
2622 			break;
2623 		case PCIE_NONFATAL_MSG:
2624 			CSR_BS((caddr_t)dev_hdl, ERR_NONFATAL_MAPPING, V);
2625 			break;
2626 		case PCIE_FATAL_MSG:
2627 			CSR_BS((caddr_t)dev_hdl, ERR_FATAL_MAPPING, V);
2628 			break;
2629 		default:
2630 			ret = H_EINVAL;
2631 			break;
2632 		}
2633 
2634 		break;
2635 	case PCIE_MSG_INVALID:
2636 		switch (msg_type) {
2637 		case PCIE_PME_MSG:
2638 			CSR_BC((caddr_t)dev_hdl, PM_PME_MAPPING, V);
2639 			break;
2640 		case PCIE_PME_ACK_MSG:
2641 			CSR_BC((caddr_t)dev_hdl, PME_TO_ACK_MAPPING, V);
2642 			break;
2643 		case PCIE_CORR_MSG:
2644 			CSR_BC((caddr_t)dev_hdl, ERR_COR_MAPPING, V);
2645 			break;
2646 		case PCIE_NONFATAL_MSG:
2647 			CSR_BC((caddr_t)dev_hdl, ERR_NONFATAL_MAPPING, V);
2648 			break;
2649 		case PCIE_FATAL_MSG:
2650 			CSR_BC((caddr_t)dev_hdl, ERR_FATAL_MAPPING, V);
2651 			break;
2652 		default:
2653 			ret = H_EINVAL;
2654 			break;
2655 		}
2656 		break;
2657 	default:
2658 		ret = H_EINVAL;
2659 	}
2660 
2661 	return (ret);
2662 }
2663 
2664 /*
2665  * Suspend/Resume Functions:
2666  *	(pec, mmu, ib)
2667  *	cb
2668  * Registers saved have all been touched in the XXX_init functions.
2669  */
2670 uint64_t
2671 hvio_suspend(devhandle_t dev_hdl, pxu_t *pxu_p)
2672 {
2673 	uint64_t	*config_state;
2674 	int		total_size;
2675 	int		i;
2676 
2677 	if (msiq_suspend(dev_hdl, pxu_p) != H_EOK)
2678 		return (H_EIO);
2679 
2680 	total_size = PEC_SIZE + MMU_SIZE + IB_SIZE + IB_MAP_SIZE;
2681 	config_state = kmem_zalloc(total_size, KM_NOSLEEP);
2682 
2683 	if (config_state == NULL) {
2684 		return (H_EIO);
2685 	}
2686 
2687 	/*
2688 	 * Soft state for suspend/resume  from pxu_t
2689 	 * uint64_t	*pec_config_state;
2690 	 * uint64_t	*mmu_config_state;
2691 	 * uint64_t	*ib_intr_map;
2692 	 * uint64_t	*ib_config_state;
2693 	 * uint64_t	*xcb_config_state;
2694 	 */
2695 
2696 	/* Save the PEC configuration states */
2697 	pxu_p->pec_config_state = config_state;
2698 	for (i = 0; i < PEC_KEYS; i++) {
2699 		if ((pec_config_state_regs[i].chip == PX_CHIP_TYPE(pxu_p)) ||
2700 		    (pec_config_state_regs[i].chip == PX_CHIP_UNIDENTIFIED)) {
2701 			pxu_p->pec_config_state[i] =
2702 			    CSR_XR((caddr_t)dev_hdl,
2703 			    pec_config_state_regs[i].reg);
2704 		}
2705 	}
2706 
2707 	/* Save the MMU configuration states */
2708 	pxu_p->mmu_config_state = pxu_p->pec_config_state + PEC_KEYS;
2709 	for (i = 0; i < MMU_KEYS; i++) {
2710 		pxu_p->mmu_config_state[i] =
2711 		    CSR_XR((caddr_t)dev_hdl, mmu_config_state_regs[i]);
2712 	}
2713 
2714 	/* Save the interrupt mapping registers */
2715 	pxu_p->ib_intr_map = pxu_p->mmu_config_state + MMU_KEYS;
2716 	for (i = 0; i < INTERRUPT_MAPPING_ENTRIES; i++) {
2717 		pxu_p->ib_intr_map[i] =
2718 		    CSRA_XR((caddr_t)dev_hdl, INTERRUPT_MAPPING, i);
2719 	}
2720 
2721 	/* Save the IB configuration states */
2722 	pxu_p->ib_config_state = pxu_p->ib_intr_map + INTERRUPT_MAPPING_ENTRIES;
2723 	for (i = 0; i < IB_KEYS; i++) {
2724 		pxu_p->ib_config_state[i] =
2725 		    CSR_XR((caddr_t)dev_hdl, ib_config_state_regs[i]);
2726 	}
2727 
2728 	return (H_EOK);
2729 }
2730 
2731 void
2732 hvio_resume(devhandle_t dev_hdl, devino_t devino, pxu_t *pxu_p)
2733 {
2734 	int		total_size;
2735 	sysino_t	sysino;
2736 	int		i;
2737 	uint64_t	ret;
2738 
2739 	/* Make sure that suspend actually did occur */
2740 	if (!pxu_p->pec_config_state) {
2741 		return;
2742 	}
2743 
2744 	/* Restore IB configuration states */
2745 	for (i = 0; i < IB_KEYS; i++) {
2746 		CSR_XS((caddr_t)dev_hdl, ib_config_state_regs[i],
2747 		    pxu_p->ib_config_state[i]);
2748 	}
2749 
2750 	/*
2751 	 * Restore the interrupt mapping registers
2752 	 * And make sure the intrs are idle.
2753 	 */
2754 	for (i = 0; i < INTERRUPT_MAPPING_ENTRIES; i++) {
2755 		CSRA_FS((caddr_t)dev_hdl, INTERRUPT_CLEAR, i,
2756 		    ENTRIES_INT_STATE, INTERRUPT_IDLE_STATE);
2757 		CSRA_XS((caddr_t)dev_hdl, INTERRUPT_MAPPING, i,
2758 		    pxu_p->ib_intr_map[i]);
2759 	}
2760 
2761 	/* Restore MMU configuration states */
2762 	/* Clear the cache. */
2763 	CSR_XS((caddr_t)dev_hdl, MMU_TTE_CACHE_INVALIDATE, -1ull);
2764 
2765 	for (i = 0; i < MMU_KEYS; i++) {
2766 		CSR_XS((caddr_t)dev_hdl, mmu_config_state_regs[i],
2767 		    pxu_p->mmu_config_state[i]);
2768 	}
2769 
2770 	/* Restore PEC configuration states */
2771 	/* Make sure all reset bits are low until error is detected */
2772 	CSR_XS((caddr_t)dev_hdl, LPU_RESET, 0ull);
2773 
2774 	for (i = 0; i < PEC_KEYS; i++) {
2775 		if ((pec_config_state_regs[i].chip == PX_CHIP_TYPE(pxu_p)) ||
2776 		    (pec_config_state_regs[i].chip == PX_CHIP_UNIDENTIFIED)) {
2777 			CSR_XS((caddr_t)dev_hdl, pec_config_state_regs[i].reg,
2778 			    pxu_p->pec_config_state[i]);
2779 		}
2780 	}
2781 
2782 	/* Enable PCI-E interrupt */
2783 	if ((ret = hvio_intr_devino_to_sysino(dev_hdl, pxu_p, devino,
2784 	    &sysino)) != H_EOK) {
2785 		cmn_err(CE_WARN,
2786 		    "hvio_resume: hvio_intr_devino_to_sysino failed, "
2787 		    "ret 0x%lx", ret);
2788 	}
2789 
2790 	if ((ret =  hvio_intr_setstate(dev_hdl, sysino, INTR_IDLE_STATE))
2791 	    != H_EOK) {
2792 		cmn_err(CE_WARN,
2793 		    "hvio_resume: hvio_intr_setstate failed, "
2794 		    "ret 0x%lx", ret);
2795 	}
2796 
2797 	total_size = PEC_SIZE + MMU_SIZE + IB_SIZE + IB_MAP_SIZE;
2798 	kmem_free(pxu_p->pec_config_state, total_size);
2799 
2800 	pxu_p->pec_config_state = NULL;
2801 	pxu_p->mmu_config_state = NULL;
2802 	pxu_p->ib_config_state = NULL;
2803 	pxu_p->ib_intr_map = NULL;
2804 
2805 	msiq_resume(dev_hdl, pxu_p);
2806 }
2807 
2808 uint64_t
2809 hvio_cb_suspend(devhandle_t dev_hdl, pxu_t *pxu_p)
2810 {
2811 	uint64_t *config_state, *cb_regs;
2812 	int i, cb_size, cb_keys;
2813 
2814 	switch (PX_CHIP_TYPE(pxu_p)) {
2815 	case PX_CHIP_OBERON:
2816 		cb_size = UBC_SIZE;
2817 		cb_keys = UBC_KEYS;
2818 		cb_regs = ubc_config_state_regs;
2819 		break;
2820 	case PX_CHIP_FIRE:
2821 		cb_size = JBC_SIZE;
2822 		cb_keys = JBC_KEYS;
2823 		cb_regs = jbc_config_state_regs;
2824 		break;
2825 	default:
2826 		DBG(DBG_CB, NULL, "hvio_cb_suspend - unknown chip type: 0x%x\n",
2827 		    PX_CHIP_TYPE(pxu_p));
2828 		break;
2829 	}
2830 
2831 	config_state = kmem_zalloc(cb_size, KM_NOSLEEP);
2832 
2833 	if (config_state == NULL) {
2834 		return (H_EIO);
2835 	}
2836 
2837 	/* Save the configuration states */
2838 	pxu_p->xcb_config_state = config_state;
2839 	for (i = 0; i < cb_keys; i++) {
2840 		pxu_p->xcb_config_state[i] =
2841 		    CSR_XR((caddr_t)dev_hdl, cb_regs[i]);
2842 	}
2843 
2844 	return (H_EOK);
2845 }
2846 
2847 void
2848 hvio_cb_resume(devhandle_t pci_dev_hdl, devhandle_t xbus_dev_hdl,
2849     devino_t devino, pxu_t *pxu_p)
2850 {
2851 	sysino_t sysino;
2852 	uint64_t *cb_regs;
2853 	int i, cb_size, cb_keys;
2854 	uint64_t ret;
2855 
2856 	switch (PX_CHIP_TYPE(pxu_p)) {
2857 	case PX_CHIP_OBERON:
2858 		cb_size = UBC_SIZE;
2859 		cb_keys = UBC_KEYS;
2860 		cb_regs = ubc_config_state_regs;
2861 		/*
2862 		 * No reason to have any reset bits high until an error is
2863 		 * detected on the link.
2864 		 */
2865 		CSR_XS((caddr_t)xbus_dev_hdl, UBC_ERROR_STATUS_CLEAR, -1ull);
2866 		break;
2867 	case PX_CHIP_FIRE:
2868 		cb_size = JBC_SIZE;
2869 		cb_keys = JBC_KEYS;
2870 		cb_regs = jbc_config_state_regs;
2871 		/*
2872 		 * No reason to have any reset bits high until an error is
2873 		 * detected on the link.
2874 		 */
2875 		CSR_XS((caddr_t)xbus_dev_hdl, JBC_ERROR_STATUS_CLEAR, -1ull);
2876 		break;
2877 	default:
2878 		DBG(DBG_CB, NULL, "hvio_cb_resume - unknown chip type: 0x%x\n",
2879 		    PX_CHIP_TYPE(pxu_p));
2880 		break;
2881 	}
2882 
2883 	ASSERT(pxu_p->xcb_config_state);
2884 
2885 	/* Restore the configuration states */
2886 	for (i = 0; i < cb_keys; i++) {
2887 		CSR_XS((caddr_t)xbus_dev_hdl, cb_regs[i],
2888 		    pxu_p->xcb_config_state[i]);
2889 	}
2890 
2891 	/* Enable XBC interrupt */
2892 	if ((ret = hvio_intr_devino_to_sysino(pci_dev_hdl, pxu_p, devino,
2893 	    &sysino)) != H_EOK) {
2894 		cmn_err(CE_WARN,
2895 		    "hvio_cb_resume: hvio_intr_devino_to_sysino failed, "
2896 		    "ret 0x%lx", ret);
2897 	}
2898 
2899 	if ((ret = hvio_intr_setstate(pci_dev_hdl, sysino, INTR_IDLE_STATE))
2900 	    != H_EOK) {
2901 		cmn_err(CE_WARN,
2902 		    "hvio_cb_resume: hvio_intr_setstate failed, "
2903 		    "ret 0x%lx", ret);
2904 	}
2905 
2906 	kmem_free(pxu_p->xcb_config_state, cb_size);
2907 
2908 	pxu_p->xcb_config_state = NULL;
2909 }
2910 
2911 static uint64_t
2912 msiq_suspend(devhandle_t dev_hdl, pxu_t *pxu_p)
2913 {
2914 	size_t	bufsz;
2915 	volatile uint64_t *cur_p;
2916 	int i;
2917 
2918 	bufsz = MSIQ_STATE_SIZE + MSIQ_MAPPING_SIZE + MSIQ_OTHER_SIZE;
2919 	if ((pxu_p->msiq_config_state = kmem_zalloc(bufsz, KM_NOSLEEP)) ==
2920 	    NULL)
2921 		return (H_EIO);
2922 
2923 	cur_p = pxu_p->msiq_config_state;
2924 
2925 	/* Save each EQ state */
2926 	for (i = 0; i < EVENT_QUEUE_STATE_ENTRIES; i++, cur_p++)
2927 		*cur_p = CSRA_XR((caddr_t)dev_hdl, EVENT_QUEUE_STATE, i);
2928 
2929 	/* Save MSI mapping registers */
2930 	for (i = 0; i < MSI_MAPPING_ENTRIES; i++, cur_p++)
2931 		*cur_p = CSRA_XR((caddr_t)dev_hdl, MSI_MAPPING, i);
2932 
2933 	/* Save all other MSIQ registers */
2934 	for (i = 0; i < MSIQ_OTHER_KEYS; i++, cur_p++)
2935 		*cur_p = CSR_XR((caddr_t)dev_hdl, msiq_config_other_regs[i]);
2936 	return (H_EOK);
2937 }
2938 
2939 static void
2940 msiq_resume(devhandle_t dev_hdl, pxu_t *pxu_p)
2941 {
2942 	size_t	bufsz;
2943 	uint64_t *cur_p, state;
2944 	int i;
2945 	uint64_t ret;
2946 
2947 	bufsz = MSIQ_STATE_SIZE + MSIQ_MAPPING_SIZE + MSIQ_OTHER_SIZE;
2948 	cur_p = pxu_p->msiq_config_state;
2949 	/*
2950 	 * Initialize EQ base address register and
2951 	 * Interrupt Mondo Data 0 register.
2952 	 */
2953 	if ((ret = hvio_msiq_init(dev_hdl, pxu_p)) != H_EOK) {
2954 		cmn_err(CE_WARN,
2955 		    "msiq_resume: hvio_msiq_init failed, "
2956 		    "ret 0x%lx", ret);
2957 	}
2958 
2959 	/* Restore EQ states */
2960 	for (i = 0; i < EVENT_QUEUE_STATE_ENTRIES; i++, cur_p++) {
2961 		state = (*cur_p) & EVENT_QUEUE_STATE_ENTRIES_STATE_MASK;
2962 		if ((state == EQ_ACTIVE_STATE) || (state == EQ_ERROR_STATE))
2963 			CSRA_BS((caddr_t)dev_hdl, EVENT_QUEUE_CONTROL_SET,
2964 			    i, ENTRIES_EN);
2965 	}
2966 
2967 	/* Restore MSI mapping */
2968 	for (i = 0; i < MSI_MAPPING_ENTRIES; i++, cur_p++)
2969 		CSRA_XS((caddr_t)dev_hdl, MSI_MAPPING, i, *cur_p);
2970 
2971 	/*
2972 	 * Restore all other registers. MSI 32 bit address and
2973 	 * MSI 64 bit address are restored as part of this.
2974 	 */
2975 	for (i = 0; i < MSIQ_OTHER_KEYS; i++, cur_p++)
2976 		CSR_XS((caddr_t)dev_hdl, msiq_config_other_regs[i], *cur_p);
2977 
2978 	kmem_free(pxu_p->msiq_config_state, bufsz);
2979 	pxu_p->msiq_config_state = NULL;
2980 }
2981 
2982 /*
2983  * sends PME_Turn_Off message to put the link in L2/L3 ready state.
2984  * called by px_goto_l23ready.
2985  * returns DDI_SUCCESS or DDI_FAILURE
2986  */
2987 int
2988 px_send_pme_turnoff(caddr_t csr_base)
2989 {
2990 	volatile uint64_t reg;
2991 
2992 	reg = CSR_XR(csr_base, TLU_PME_TURN_OFF_GENERATE);
2993 	/* If already pending, return failure */
2994 	if (reg & (1ull << TLU_PME_TURN_OFF_GENERATE_PTO)) {
2995 		DBG(DBG_PWR, NULL, "send_pme_turnoff: pending PTO bit "
2996 		    "tlu_pme_turn_off_generate = %x\n", reg);
2997 		return (DDI_FAILURE);
2998 	}
2999 
3000 	/* write to PME_Turn_off reg to boradcast */
3001 	reg |= (1ull << TLU_PME_TURN_OFF_GENERATE_PTO);
3002 	CSR_XS(csr_base,  TLU_PME_TURN_OFF_GENERATE, reg);
3003 
3004 	return (DDI_SUCCESS);
3005 }
3006 
3007 /*
3008  * Checks for link being in L1idle state.
3009  * Returns
3010  * DDI_SUCCESS - if the link is in L1idle
3011  * DDI_FAILURE - if the link is not in L1idle
3012  */
3013 int
3014 px_link_wait4l1idle(caddr_t csr_base)
3015 {
3016 	uint8_t ltssm_state;
3017 	int ntries = px_max_l1_tries;
3018 
3019 	while (ntries > 0) {
3020 		ltssm_state = CSR_FR(csr_base, LPU_LTSSM_STATUS1, LTSSM_STATE);
3021 		if (ltssm_state == LPU_LTSSM_L1_IDLE || (--ntries <= 0))
3022 			break;
3023 		delay(1);
3024 	}
3025 	DBG(DBG_PWR, NULL, "check_for_l1idle: ltssm_state %x\n", ltssm_state);
3026 	return ((ltssm_state == LPU_LTSSM_L1_IDLE) ? DDI_SUCCESS : DDI_FAILURE);
3027 }
3028 
3029 /*
3030  * Tranisition the link to L0, after it is down.
3031  */
3032 int
3033 px_link_retrain(caddr_t csr_base)
3034 {
3035 	volatile uint64_t reg;
3036 
3037 	reg = CSR_XR(csr_base, TLU_CONTROL);
3038 	if (!(reg & (1ull << TLU_REMAIN_DETECT_QUIET))) {
3039 		DBG(DBG_PWR, NULL, "retrain_link: detect.quiet bit not set\n");
3040 		return (DDI_FAILURE);
3041 	}
3042 
3043 	/* Clear link down bit in TLU Other Event Clear Status Register. */
3044 	CSR_BS(csr_base, TLU_OTHER_EVENT_STATUS_CLEAR, LDN_P);
3045 
3046 	/* Clear Drain bit in TLU Status Register */
3047 	CSR_BS(csr_base, TLU_STATUS, DRAIN);
3048 
3049 	/* Clear Remain in Detect.Quiet bit in TLU Control Register */
3050 	reg = CSR_XR(csr_base, TLU_CONTROL);
3051 	reg &= ~(1ull << TLU_REMAIN_DETECT_QUIET);
3052 	CSR_XS(csr_base, TLU_CONTROL, reg);
3053 
3054 	return (DDI_SUCCESS);
3055 }
3056 
3057 void
3058 px_enable_detect_quiet(caddr_t csr_base)
3059 {
3060 	volatile uint64_t tlu_ctrl;
3061 
3062 	tlu_ctrl = CSR_XR(csr_base, TLU_CONTROL);
3063 	tlu_ctrl |= (1ull << TLU_REMAIN_DETECT_QUIET);
3064 	CSR_XS(csr_base, TLU_CONTROL, tlu_ctrl);
3065 }
3066 
3067 static uint_t
3068 oberon_hp_pwron(caddr_t csr_base)
3069 {
3070 	volatile uint64_t reg;
3071 	boolean_t link_retry, link_up;
3072 	int loop, i;
3073 
3074 	DBG(DBG_HP, NULL, "oberon_hp_pwron the slot\n");
3075 
3076 	/* Check Leaf Reset status */
3077 	reg = CSR_XR(csr_base, ILU_ERROR_LOG_ENABLE);
3078 	if (!(reg & (1ull << ILU_ERROR_LOG_ENABLE_SPARE3))) {
3079 		DBG(DBG_HP, NULL, "oberon_hp_pwron fails: leaf not reset\n");
3080 		goto fail;
3081 	}
3082 
3083 	/* Check HP Capable */
3084 	if (!CSR_BR(csr_base, TLU_SLOT_CAPABILITIES, HP)) {
3085 		DBG(DBG_HP, NULL, "oberon_hp_pwron fails: leaf not "
3086 		    "hotplugable\n");
3087 		goto fail;
3088 	}
3089 
3090 	/* Check Slot status */
3091 	reg = CSR_XR(csr_base, TLU_SLOT_STATUS);
3092 	if (!(reg & (1ull << TLU_SLOT_STATUS_PSD)) ||
3093 	    (reg & (1ull << TLU_SLOT_STATUS_MRLS))) {
3094 		DBG(DBG_HP, NULL, "oberon_hp_pwron fails: slot status %lx\n",
3095 		    reg);
3096 		goto fail;
3097 	}
3098 
3099 	/* Blink power LED, this is done from pciehpc already */
3100 
3101 	/* Turn on slot power */
3102 	CSR_BS(csr_base, HOTPLUG_CONTROL, PWREN);
3103 
3104 	/* power fault detection */
3105 	delay(drv_usectohz(25000));
3106 	CSR_BS(csr_base, TLU_SLOT_STATUS, PWFD);
3107 	CSR_BC(csr_base, HOTPLUG_CONTROL, PWREN);
3108 
3109 	/* wait to check power state */
3110 	delay(drv_usectohz(25000));
3111 
3112 	if (!CSR_BR(csr_base, TLU_SLOT_STATUS, PWFD)) {
3113 		DBG(DBG_HP, NULL, "oberon_hp_pwron fails: power fault\n");
3114 		goto fail1;
3115 	}
3116 
3117 	/* power is good */
3118 	CSR_BS(csr_base, HOTPLUG_CONTROL, PWREN);
3119 
3120 	delay(drv_usectohz(25000));
3121 	CSR_BS(csr_base, TLU_SLOT_STATUS, PWFD);
3122 	CSR_BS(csr_base, TLU_SLOT_CONTROL, PWFDEN);
3123 
3124 	/* Turn on slot clock */
3125 	CSR_BS(csr_base, HOTPLUG_CONTROL, CLKEN);
3126 
3127 	link_up = B_FALSE;
3128 	link_retry = B_FALSE;
3129 
3130 	for (loop = 0; (loop < link_retry_count) && (link_up == B_FALSE);
3131 	    loop++) {
3132 		if (link_retry == B_TRUE) {
3133 			DBG(DBG_HP, NULL, "oberon_hp_pwron : retry link loop "
3134 			    "%d\n", loop);
3135 			CSR_BS(csr_base, TLU_CONTROL, DRN_TR_DIS);
3136 			CSR_XS(csr_base, FLP_PORT_CONTROL, 0x1);
3137 			delay(drv_usectohz(10000));
3138 			CSR_BC(csr_base, TLU_CONTROL, DRN_TR_DIS);
3139 			CSR_BS(csr_base, TLU_DIAGNOSTIC, IFC_DIS);
3140 			CSR_BC(csr_base, HOTPLUG_CONTROL, N_PERST);
3141 			delay(drv_usectohz(50000));
3142 		}
3143 
3144 		/* Release PCI-E Reset */
3145 		delay(drv_usectohz(wait_perst));
3146 		CSR_BS(csr_base, HOTPLUG_CONTROL, N_PERST);
3147 
3148 		/*
3149 		 * Open events' mask
3150 		 * This should be done from pciehpc already
3151 		 */
3152 
3153 		/* Enable PCIE port */
3154 		delay(drv_usectohz(wait_enable_port));
3155 		CSR_BS(csr_base, TLU_CONTROL, DRN_TR_DIS);
3156 		CSR_XS(csr_base, FLP_PORT_CONTROL, 0x20);
3157 
3158 		/* wait for the link up */
3159 		/* BEGIN CSTYLED */
3160 		for (i = 0; (i < 2) && (link_up == B_FALSE); i++) {
3161 			delay(drv_usectohz(link_status_check));
3162 			reg = CSR_XR(csr_base, DLU_LINK_LAYER_STATUS);
3163 
3164 		if ((((reg >> DLU_LINK_LAYER_STATUS_INIT_FC_SM_STS) &
3165 		    DLU_LINK_LAYER_STATUS_INIT_FC_SM_STS_MASK) ==
3166 		    DLU_LINK_LAYER_STATUS_INIT_FC_SM_STS_FC_INIT_DONE) &&
3167 		    (reg & (1ull << DLU_LINK_LAYER_STATUS_DLUP_STS)) &&
3168 		    ((reg &
3169 		    DLU_LINK_LAYER_STATUS_LNK_STATE_MACH_STS_MASK) ==
3170 		    DLU_LINK_LAYER_STATUS_LNK_STATE_MACH_STS_DL_ACTIVE)) {
3171 			DBG(DBG_HP, NULL, "oberon_hp_pwron : "
3172 			    "link is up\n");
3173 			link_up = B_TRUE;
3174 		} else
3175 			link_retry = B_TRUE;
3176 
3177 		}
3178 		/* END CSTYLED */
3179 	}
3180 
3181 	if (link_up == B_FALSE) {
3182 		DBG(DBG_HP, NULL, "oberon_hp_pwron fails to enable "
3183 		    "PCI-E port\n");
3184 		goto fail2;
3185 	}
3186 
3187 	/* link is up */
3188 	CSR_BC(csr_base, TLU_DIAGNOSTIC, IFC_DIS);
3189 	CSR_BS(csr_base, FLP_PORT_ACTIVE_STATUS, TRAIN_ERROR);
3190 	CSR_BS(csr_base, TLU_UNCORRECTABLE_ERROR_STATUS_CLEAR, TE_P);
3191 	CSR_BS(csr_base, TLU_UNCORRECTABLE_ERROR_STATUS_CLEAR, TE_S);
3192 	CSR_BC(csr_base, TLU_CONTROL, DRN_TR_DIS);
3193 
3194 	/* Restore LUP/LDN */
3195 	reg = CSR_XR(csr_base, TLU_OTHER_EVENT_LOG_ENABLE);
3196 	if (px_tlu_oe_log_mask & (1ull << TLU_OTHER_EVENT_STATUS_SET_LUP_P))
3197 		reg |= 1ull << TLU_OTHER_EVENT_STATUS_SET_LUP_P;
3198 	if (px_tlu_oe_log_mask & (1ull << TLU_OTHER_EVENT_STATUS_SET_LDN_P))
3199 		reg |= 1ull << TLU_OTHER_EVENT_STATUS_SET_LDN_P;
3200 	if (px_tlu_oe_log_mask & (1ull << TLU_OTHER_EVENT_STATUS_SET_LUP_S))
3201 		reg |= 1ull << TLU_OTHER_EVENT_STATUS_SET_LUP_S;
3202 	if (px_tlu_oe_log_mask & (1ull << TLU_OTHER_EVENT_STATUS_SET_LDN_S))
3203 		reg |= 1ull << TLU_OTHER_EVENT_STATUS_SET_LDN_S;
3204 	CSR_XS(csr_base, TLU_OTHER_EVENT_LOG_ENABLE, reg);
3205 
3206 	/*
3207 	 * Initialize Leaf
3208 	 * SPLS = 00b, SPLV = 11001b, i.e. 25W
3209 	 */
3210 	reg = CSR_XR(csr_base, TLU_SLOT_CAPABILITIES);
3211 	reg &= ~(TLU_SLOT_CAPABILITIES_SPLS_MASK <<
3212 	    TLU_SLOT_CAPABILITIES_SPLS);
3213 	reg &= ~(TLU_SLOT_CAPABILITIES_SPLV_MASK <<
3214 	    TLU_SLOT_CAPABILITIES_SPLV);
3215 	reg |= (0x19 << TLU_SLOT_CAPABILITIES_SPLV);
3216 	CSR_XS(csr_base, TLU_SLOT_CAPABILITIES, reg);
3217 
3218 	/* Turn on Power LED */
3219 	reg = CSR_XR(csr_base, TLU_SLOT_CONTROL);
3220 	reg &= ~PCIE_SLOTCTL_PWR_INDICATOR_MASK;
3221 	reg = pcie_slotctl_pwr_indicator_set(reg,
3222 	    PCIE_SLOTCTL_INDICATOR_STATE_ON);
3223 	CSR_XS(csr_base, TLU_SLOT_CONTROL, reg);
3224 
3225 	/* Notify to SCF */
3226 	if (CSR_BR(csr_base, HOTPLUG_CONTROL, SLOTPON))
3227 		CSR_BC(csr_base, HOTPLUG_CONTROL, SLOTPON);
3228 	else
3229 		CSR_BS(csr_base, HOTPLUG_CONTROL, SLOTPON);
3230 
3231 	/* Wait for one second */
3232 	delay(drv_usectohz(1000000));
3233 
3234 	return (DDI_SUCCESS);
3235 
3236 fail2:
3237 	/* Link up is failed */
3238 	CSR_BS(csr_base, FLP_PORT_CONTROL, PORT_DIS);
3239 	CSR_BC(csr_base, HOTPLUG_CONTROL, N_PERST);
3240 	delay(drv_usectohz(150));
3241 
3242 	CSR_BC(csr_base, HOTPLUG_CONTROL, CLKEN);
3243 	delay(drv_usectohz(100));
3244 
3245 fail1:
3246 	CSR_BC(csr_base, TLU_SLOT_CONTROL, PWFDEN);
3247 
3248 	CSR_BC(csr_base, HOTPLUG_CONTROL, PWREN);
3249 
3250 	reg = CSR_XR(csr_base, TLU_SLOT_CONTROL);
3251 	reg &= ~PCIE_SLOTCTL_PWR_INDICATOR_MASK;
3252 	reg = pcie_slotctl_pwr_indicator_set(reg,
3253 	    PCIE_SLOTCTL_INDICATOR_STATE_OFF);
3254 	CSR_XS(csr_base, TLU_SLOT_CONTROL, reg);
3255 
3256 	CSR_BC(csr_base, TLU_SLOT_STATUS, PWFD);
3257 
3258 fail:
3259 	return ((uint_t)DDI_FAILURE);
3260 }
3261 
3262 hrtime_t oberon_leaf_reset_timeout = 120ll * NANOSEC;	/* 120 seconds */
3263 
3264 static uint_t
3265 oberon_hp_pwroff(caddr_t csr_base)
3266 {
3267 	volatile uint64_t reg;
3268 	volatile uint64_t reg_tluue, reg_tluce;
3269 	hrtime_t start_time, end_time;
3270 
3271 	DBG(DBG_HP, NULL, "oberon_hp_pwroff the slot\n");
3272 
3273 	/* Blink power LED, this is done from pciehpc already */
3274 
3275 	/* Clear Slot Event */
3276 	CSR_BS(csr_base, TLU_SLOT_STATUS, PSDC);
3277 	CSR_BS(csr_base, TLU_SLOT_STATUS, PWFD);
3278 
3279 	/* DRN_TR_DIS on */
3280 	CSR_BS(csr_base, TLU_CONTROL, DRN_TR_DIS);
3281 	delay(drv_usectohz(10000));
3282 
3283 	/* Disable LUP/LDN */
3284 	reg = CSR_XR(csr_base, TLU_OTHER_EVENT_LOG_ENABLE);
3285 	reg &= ~((1ull << TLU_OTHER_EVENT_STATUS_SET_LDN_P) |
3286 	    (1ull << TLU_OTHER_EVENT_STATUS_SET_LUP_P) |
3287 	    (1ull << TLU_OTHER_EVENT_STATUS_SET_LDN_S) |
3288 	    (1ull << TLU_OTHER_EVENT_STATUS_SET_LUP_S));
3289 	CSR_XS(csr_base, TLU_OTHER_EVENT_LOG_ENABLE, reg);
3290 
3291 	/* Save the TLU registers */
3292 	reg_tluue = CSR_XR(csr_base, TLU_UNCORRECTABLE_ERROR_LOG_ENABLE);
3293 	reg_tluce = CSR_XR(csr_base, TLU_CORRECTABLE_ERROR_LOG_ENABLE);
3294 	/* All clear */
3295 	CSR_XS(csr_base, TLU_UNCORRECTABLE_ERROR_LOG_ENABLE, 0);
3296 	CSR_XS(csr_base, TLU_CORRECTABLE_ERROR_LOG_ENABLE, 0);
3297 
3298 	/* Disable port */
3299 	CSR_BS(csr_base, FLP_PORT_CONTROL, PORT_DIS);
3300 
3301 	/* PCIE reset */
3302 	delay(drv_usectohz(10000));
3303 	CSR_BC(csr_base, HOTPLUG_CONTROL, N_PERST);
3304 
3305 	/* PCIE clock stop */
3306 	delay(drv_usectohz(150));
3307 	CSR_BC(csr_base, HOTPLUG_CONTROL, CLKEN);
3308 
3309 	/* Turn off slot power */
3310 	delay(drv_usectohz(100));
3311 	CSR_BC(csr_base, TLU_SLOT_CONTROL, PWFDEN);
3312 	CSR_BC(csr_base, HOTPLUG_CONTROL, PWREN);
3313 	delay(drv_usectohz(25000));
3314 	CSR_BS(csr_base, TLU_SLOT_STATUS, PWFD);
3315 
3316 	/* write 0 to bit 7 of ILU Error Log Enable Register */
3317 	CSR_BC(csr_base, ILU_ERROR_LOG_ENABLE, SPARE3);
3318 
3319 	/* Set back TLU registers */
3320 	CSR_XS(csr_base, TLU_UNCORRECTABLE_ERROR_LOG_ENABLE, reg_tluue);
3321 	CSR_XS(csr_base, TLU_CORRECTABLE_ERROR_LOG_ENABLE, reg_tluce);
3322 
3323 	/* Power LED off */
3324 	reg = CSR_XR(csr_base, TLU_SLOT_CONTROL);
3325 	reg &= ~PCIE_SLOTCTL_PWR_INDICATOR_MASK;
3326 	reg = pcie_slotctl_pwr_indicator_set(reg,
3327 	    PCIE_SLOTCTL_INDICATOR_STATE_OFF);
3328 	CSR_XS(csr_base, TLU_SLOT_CONTROL, reg);
3329 
3330 	/* Indicator LED blink */
3331 	reg = CSR_XR(csr_base, TLU_SLOT_CONTROL);
3332 	reg &= ~PCIE_SLOTCTL_ATTN_INDICATOR_MASK;
3333 	reg = pcie_slotctl_attn_indicator_set(reg,
3334 	    PCIE_SLOTCTL_INDICATOR_STATE_BLINK);
3335 	CSR_XS(csr_base, TLU_SLOT_CONTROL, reg);
3336 
3337 	/* Notify to SCF */
3338 	if (CSR_BR(csr_base, HOTPLUG_CONTROL, SLOTPON))
3339 		CSR_BC(csr_base, HOTPLUG_CONTROL, SLOTPON);
3340 	else
3341 		CSR_BS(csr_base, HOTPLUG_CONTROL, SLOTPON);
3342 
3343 	start_time = gethrtime();
3344 	/* Check Leaf Reset status */
3345 	while (!(CSR_BR(csr_base, ILU_ERROR_LOG_ENABLE, SPARE3))) {
3346 		if ((end_time = (gethrtime() - start_time)) >
3347 		    oberon_leaf_reset_timeout) {
3348 			cmn_err(CE_WARN, "Oberon leaf reset is not completed, "
3349 			    "even after waiting %llx ticks", end_time);
3350 
3351 			break;
3352 		}
3353 
3354 		/* Wait for one second */
3355 		delay(drv_usectohz(1000000));
3356 	}
3357 
3358 	/* Indicator LED off */
3359 	reg = CSR_XR(csr_base, TLU_SLOT_CONTROL);
3360 	reg &= ~PCIE_SLOTCTL_ATTN_INDICATOR_MASK;
3361 	reg = pcie_slotctl_attn_indicator_set(reg,
3362 	    PCIE_SLOTCTL_INDICATOR_STATE_OFF);
3363 	CSR_XS(csr_base, TLU_SLOT_CONTROL, reg);
3364 
3365 	return (DDI_SUCCESS);
3366 }
3367 
3368 static uint_t
3369 oberon_hpreg_get(void *cookie, off_t off)
3370 {
3371 	caddr_t csr_base = *(caddr_t *)cookie;
3372 	volatile uint64_t val = -1ull;
3373 
3374 	switch (off) {
3375 	case PCIE_SLOTCAP:
3376 		val = CSR_XR(csr_base, TLU_SLOT_CAPABILITIES);
3377 		break;
3378 	case PCIE_SLOTCTL:
3379 		val = CSR_XR(csr_base, TLU_SLOT_CONTROL);
3380 
3381 		/* Get the power state */
3382 		val |= (CSR_XR(csr_base, HOTPLUG_CONTROL) &
3383 		    (1ull << HOTPLUG_CONTROL_PWREN)) ?
3384 		    0 : PCIE_SLOTCTL_PWR_CONTROL;
3385 		break;
3386 	case PCIE_SLOTSTS:
3387 		val = CSR_XR(csr_base, TLU_SLOT_STATUS);
3388 		break;
3389 	case PCIE_LINKCAP:
3390 		val = CSR_XR(csr_base, TLU_LINK_CAPABILITIES);
3391 		break;
3392 	case PCIE_LINKSTS:
3393 		val = CSR_XR(csr_base, TLU_LINK_STATUS);
3394 		break;
3395 	default:
3396 		DBG(DBG_HP, NULL, "oberon_hpreg_get(): "
3397 		    "unsupported offset 0x%lx\n", off);
3398 		break;
3399 	}
3400 
3401 	return ((uint_t)val);
3402 }
3403 
3404 static uint_t
3405 oberon_hpreg_put(void *cookie, off_t off, uint_t val)
3406 {
3407 	caddr_t csr_base = *(caddr_t *)cookie;
3408 	volatile uint64_t pwr_state_on, pwr_fault;
3409 	uint_t pwr_off, ret = DDI_SUCCESS;
3410 
3411 	DBG(DBG_HP, NULL, "oberon_hpreg_put 0x%lx: cur %x, new %x\n",
3412 	    off, oberon_hpreg_get(cookie, off), val);
3413 
3414 	switch (off) {
3415 	case PCIE_SLOTCTL:
3416 		/*
3417 		 * Depending on the current state, insertion or removal
3418 		 * will go through their respective sequences.
3419 		 */
3420 		pwr_state_on = CSR_BR(csr_base, HOTPLUG_CONTROL, PWREN);
3421 		pwr_off = val & PCIE_SLOTCTL_PWR_CONTROL;
3422 
3423 		if (!pwr_off && !pwr_state_on)
3424 			ret = oberon_hp_pwron(csr_base);
3425 		else if (pwr_off && pwr_state_on) {
3426 			pwr_fault = CSR_XR(csr_base, TLU_SLOT_STATUS) &
3427 			    (1ull << TLU_SLOT_STATUS_PWFD);
3428 
3429 			if (pwr_fault) {
3430 				DBG(DBG_HP, NULL, "oberon_hpreg_put: power "
3431 				    "off because of power fault\n");
3432 				CSR_BC(csr_base, HOTPLUG_CONTROL, PWREN);
3433 			}
3434 			else
3435 				ret = oberon_hp_pwroff(csr_base);
3436 		} else
3437 			CSR_XS(csr_base, TLU_SLOT_CONTROL, val);
3438 		break;
3439 	case PCIE_SLOTSTS:
3440 		CSR_XS(csr_base, TLU_SLOT_STATUS, val);
3441 		break;
3442 	default:
3443 		DBG(DBG_HP, NULL, "oberon_hpreg_put(): "
3444 		    "unsupported offset 0x%lx\n", off);
3445 		ret = (uint_t)DDI_FAILURE;
3446 		break;
3447 	}
3448 
3449 	return (ret);
3450 }
3451 
3452 int
3453 hvio_hotplug_init(dev_info_t *dip, void *arg)
3454 {
3455 	pcie_hp_regops_t *regops = (pcie_hp_regops_t *)arg;
3456 	px_t	*px_p = DIP_TO_STATE(dip);
3457 	pxu_t	*pxu_p = (pxu_t *)px_p->px_plat_p;
3458 	volatile uint64_t reg;
3459 
3460 	if (PX_CHIP_TYPE(pxu_p) == PX_CHIP_OBERON) {
3461 		if (!CSR_BR((caddr_t)pxu_p->px_address[PX_REG_CSR],
3462 		    TLU_SLOT_CAPABILITIES, HP)) {
3463 			DBG(DBG_HP, NULL, "%s%d: hotplug capabale not set\n",
3464 			    ddi_driver_name(dip), ddi_get_instance(dip));
3465 			return (DDI_FAILURE);
3466 		}
3467 
3468 		/* For empty or disconnected slot, disable LUP/LDN */
3469 		if (!CSR_BR((caddr_t)pxu_p->px_address[PX_REG_CSR],
3470 		    TLU_SLOT_STATUS, PSD) ||
3471 		    !CSR_BR((caddr_t)pxu_p->px_address[PX_REG_CSR],
3472 		    HOTPLUG_CONTROL, PWREN)) {
3473 
3474 			reg = CSR_XR((caddr_t)pxu_p->px_address[PX_REG_CSR],
3475 			    TLU_OTHER_EVENT_LOG_ENABLE);
3476 			reg &= ~((1ull << TLU_OTHER_EVENT_STATUS_SET_LDN_P) |
3477 			    (1ull << TLU_OTHER_EVENT_STATUS_SET_LUP_P) |
3478 			    (1ull << TLU_OTHER_EVENT_STATUS_SET_LDN_S) |
3479 			    (1ull << TLU_OTHER_EVENT_STATUS_SET_LUP_S));
3480 			CSR_XS((caddr_t)pxu_p->px_address[PX_REG_CSR],
3481 			    TLU_OTHER_EVENT_LOG_ENABLE, reg);
3482 		}
3483 
3484 		regops->get = oberon_hpreg_get;
3485 		regops->put = oberon_hpreg_put;
3486 
3487 		/* cookie is the csr_base */
3488 		regops->cookie = (void *)&pxu_p->px_address[PX_REG_CSR];
3489 
3490 		return (DDI_SUCCESS);
3491 	}
3492 
3493 	return (DDI_ENOTSUP);
3494 }
3495 
3496 int
3497 hvio_hotplug_uninit(dev_info_t *dip)
3498 {
3499 	px_t	*px_p = DIP_TO_STATE(dip);
3500 	pxu_t	*pxu_p = (pxu_t *)px_p->px_plat_p;
3501 
3502 	if (PX_CHIP_TYPE(pxu_p) == PX_CHIP_OBERON)
3503 		return (DDI_SUCCESS);
3504 
3505 	return (DDI_FAILURE);
3506 }
3507