xref: /illumos-gate/usr/src/uts/sun4u/opl/sys/pcicmu/pcmu_cb.h (revision 25cf1a301a396c38e8adf52c15f537b80d2483f7)
1*25cf1a30Sjl139090 /*
2*25cf1a30Sjl139090  * CDDL HEADER START
3*25cf1a30Sjl139090  *
4*25cf1a30Sjl139090  * The contents of this file are subject to the terms of the
5*25cf1a30Sjl139090  * Common Development and Distribution License (the "License").
6*25cf1a30Sjl139090  * You may not use this file except in compliance with the License.
7*25cf1a30Sjl139090  *
8*25cf1a30Sjl139090  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*25cf1a30Sjl139090  * or http://www.opensolaris.org/os/licensing.
10*25cf1a30Sjl139090  * See the License for the specific language governing permissions
11*25cf1a30Sjl139090  * and limitations under the License.
12*25cf1a30Sjl139090  *
13*25cf1a30Sjl139090  * When distributing Covered Code, include this CDDL HEADER in each
14*25cf1a30Sjl139090  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*25cf1a30Sjl139090  * If applicable, add the following below this CDDL HEADER, with the
16*25cf1a30Sjl139090  * fields enclosed by brackets "[]" replaced with your own identifying
17*25cf1a30Sjl139090  * information: Portions Copyright [yyyy] [name of copyright owner]
18*25cf1a30Sjl139090  *
19*25cf1a30Sjl139090  * CDDL HEADER END
20*25cf1a30Sjl139090  */
21*25cf1a30Sjl139090 /*
22*25cf1a30Sjl139090  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
23*25cf1a30Sjl139090  * Use is subject to license terms.
24*25cf1a30Sjl139090  */
25*25cf1a30Sjl139090 
26*25cf1a30Sjl139090 #ifndef	_SYS_PCMU_CB_H
27*25cf1a30Sjl139090 #define	_SYS_PCMU_CB_H
28*25cf1a30Sjl139090 
29*25cf1a30Sjl139090 #pragma ident	"%Z%%M%	%I%	%E% SMI"
30*25cf1a30Sjl139090 
31*25cf1a30Sjl139090 #ifdef	__cplusplus
32*25cf1a30Sjl139090 extern "C" {
33*25cf1a30Sjl139090 #endif
34*25cf1a30Sjl139090 
35*25cf1a30Sjl139090 enum pcmu_cb_nintr_index {
36*25cf1a30Sjl139090 	CBNINTR_PBM = 0,		/* not shared */
37*25cf1a30Sjl139090 	CBNINTR_UE = 1,			/* shared */
38*25cf1a30Sjl139090 	CBNINTR_CE = 2,			/* shared */
39*25cf1a30Sjl139090 	CBNINTR_POWER_FAIL	= 3,	/* shared */
40*25cf1a30Sjl139090 	CBNINTR_THERMAL		= 4,	/* shared */
41*25cf1a30Sjl139090 	CBNINTR_MAX			/* max */
42*25cf1a30Sjl139090 };
43*25cf1a30Sjl139090 
44*25cf1a30Sjl139090 /*
45*25cf1a30Sjl139090  * control block soft state structure:
46*25cf1a30Sjl139090  */
47*25cf1a30Sjl139090 struct pcmu_cb {
48*25cf1a30Sjl139090 	pcmu_t *pcb_pcmu_p;
49*25cf1a30Sjl139090 	pcmu_ign_t pcb_ign;		/* interrupt grp# */
50*25cf1a30Sjl139090 	kmutex_t pcb_intr_lock;		/* guards add/rem intr and intr dist */
51*25cf1a30Sjl139090 	uint32_t pcb_no_of_inos;	/* # of actual inos, including PBM */
52*25cf1a30Sjl139090 	uint32_t pcb_inos[CBNINTR_MAX];	/* subset of pcmu_p->pcmu_inos array */
53*25cf1a30Sjl139090 	uint64_t pcb_base_pa;		/* PA of CSR bank, 2nd "reg" */
54*25cf1a30Sjl139090 	uint64_t pcb_map_pa;		/* map reg base PA */
55*25cf1a30Sjl139090 	uint64_t pcb_clr_pa;		/* clr reg base PA */
56*25cf1a30Sjl139090 	uint64_t pcb_obsta_pa;		/* sta reg base PA */
57*25cf1a30Sjl139090 	uint64_t *pcb_imr_save;
58*25cf1a30Sjl139090 	caddr_t pcb_ittrans_cookie;	/* intr tgt translation */
59*25cf1a30Sjl139090 };
60*25cf1a30Sjl139090 
61*25cf1a30Sjl139090 #define	PCMU_CB_INO_TO_MONDO(pcb_p, ino)			\
62*25cf1a30Sjl139090 	    ((pcb_p)->pcb_ign << PCMU_INO_BITS |  (ino))
63*25cf1a30Sjl139090 
64*25cf1a30Sjl139090 /*
65*25cf1a30Sjl139090  * Prototypes.
66*25cf1a30Sjl139090  */
67*25cf1a30Sjl139090 extern void pcmu_cb_create(pcmu_t *pcmu_p);
68*25cf1a30Sjl139090 extern void pcmu_cb_destroy(pcmu_t *pcmu_p);
69*25cf1a30Sjl139090 extern void pcmu_cb_suspend(pcmu_cb_t *cb_p);
70*25cf1a30Sjl139090 extern void pcmu_cb_resume(pcmu_cb_t *cb_p);
71*25cf1a30Sjl139090 extern void pcmu_cb_enable_nintr(pcmu_t *pcmu_p, pcmu_cb_nintr_index_t idx);
72*25cf1a30Sjl139090 extern void pcmu_cb_disable_nintr(pcmu_cb_t *cb_p,
73*25cf1a30Sjl139090     pcmu_cb_nintr_index_t idx, int wait);
74*25cf1a30Sjl139090 extern void pcmu_cb_clear_nintr(pcmu_cb_t *cb_p, pcmu_cb_nintr_index_t idx);
75*25cf1a30Sjl139090 extern void pcmu_cb_intr_dist(void *arg);
76*25cf1a30Sjl139090 
77*25cf1a30Sjl139090 #ifdef	__cplusplus
78*25cf1a30Sjl139090 }
79*25cf1a30Sjl139090 #endif
80*25cf1a30Sjl139090 
81*25cf1a30Sjl139090 #endif	/* _SYS_PCMU_CB_H */
82