xref: /OK3568_Linux_fs/external/rkwifibt/drivers/bcmdhd/include/siutils.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Misc utility routines for accessing the SOC Interconnects
3*4882a593Smuzhiyun  * of Broadcom HNBU chips.
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * Copyright (C) 2020, Broadcom.
6*4882a593Smuzhiyun  *
7*4882a593Smuzhiyun  *      Unless you and Broadcom execute a separate written software license
8*4882a593Smuzhiyun  * agreement governing use of this software, this software is licensed to you
9*4882a593Smuzhiyun  * under the terms of the GNU General Public License version 2 (the "GPL"),
10*4882a593Smuzhiyun  * available at http://www.broadcom.com/licenses/GPLv2.php, with the
11*4882a593Smuzhiyun  * following added to such license:
12*4882a593Smuzhiyun  *
13*4882a593Smuzhiyun  *      As a special exception, the copyright holders of this software give you
14*4882a593Smuzhiyun  * permission to link this software with independent modules, and to copy and
15*4882a593Smuzhiyun  * distribute the resulting executable under terms of your choice, provided that
16*4882a593Smuzhiyun  * you also meet, for each linked independent module, the terms and conditions of
17*4882a593Smuzhiyun  * the license of that module.  An independent module is a module which is not
18*4882a593Smuzhiyun  * derived from this software.  The special exception does not apply to any
19*4882a593Smuzhiyun  * modifications of the software.
20*4882a593Smuzhiyun  *
21*4882a593Smuzhiyun  *
22*4882a593Smuzhiyun  * <<Broadcom-WL-IPTag/Dual:>>
23*4882a593Smuzhiyun  */
24*4882a593Smuzhiyun 
25*4882a593Smuzhiyun #ifndef	_siutils_h_
26*4882a593Smuzhiyun #define	_siutils_h_
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun #include <osl_decl.h>
29*4882a593Smuzhiyun 
30*4882a593Smuzhiyun /* Make the d11 core(s) selectable by the user config... */
31*4882a593Smuzhiyun #ifndef D11_CORE_UNIT_MASK
32*4882a593Smuzhiyun /* By default we allow all d11 cores to be used */
33*4882a593Smuzhiyun #define D11_CORE_UNIT_MASK 0xFFFFFFFFu
34*4882a593Smuzhiyun #endif
35*4882a593Smuzhiyun 
36*4882a593Smuzhiyun /* Generic interrupt bit mask definitions */
37*4882a593Smuzhiyun enum bcm_int_reg_idx {
38*4882a593Smuzhiyun 	BCM_INT_REG_IDX_0 = 0,
39*4882a593Smuzhiyun 	BCM_INT_REG_IDX_1 = 1,
40*4882a593Smuzhiyun 	/* temp work around to avoid > 50K invalidation on 4388a0-roml */
41*4882a593Smuzhiyun #ifndef ROM_COMPAT_INT_REG_IDX
42*4882a593Smuzhiyun 	BCM_INT_REG_IDX_2 = 2,
43*4882a593Smuzhiyun #endif /* ROM_COMPAT_INT_REG_IDX */
44*4882a593Smuzhiyun 	BCM_INT_REGS_NUM
45*4882a593Smuzhiyun };
46*4882a593Smuzhiyun 
47*4882a593Smuzhiyun typedef struct bcm_int_bitmask {
48*4882a593Smuzhiyun 	uint32 bits[BCM_INT_REGS_NUM];
49*4882a593Smuzhiyun } bcm_int_bitmask_t;
50*4882a593Smuzhiyun 
51*4882a593Smuzhiyun #ifndef ROM_COMPAT_INT_REG_IDX
52*4882a593Smuzhiyun 
53*4882a593Smuzhiyun #define BCM_INT_BITMASK_IS_EQUAL(b, cmp) (\
54*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_0] == (cmp)->bits[BCM_INT_REG_IDX_0] && \
55*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_1] == (cmp)->bits[BCM_INT_REG_IDX_1] && \
56*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_2] == (cmp)->bits[BCM_INT_REG_IDX_2])
57*4882a593Smuzhiyun 
58*4882a593Smuzhiyun #define BCM_INT_BITMASK_IS_ZERO(b) (\
59*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_0] == 0 && \
60*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_1] == 0 && \
61*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_2] == 0)
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun #define BCM_INT_BITMASK_SET(to, from) do { \
64*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_0] = (from)->bits[BCM_INT_REG_IDX_0]; \
65*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_1] = (from)->bits[BCM_INT_REG_IDX_1]; \
66*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_2] = (from)->bits[BCM_INT_REG_IDX_2]; \
67*4882a593Smuzhiyun } while (0)
68*4882a593Smuzhiyun #define BCM_INT_BITMASK_OR(to, from) do { \
69*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_0] |= (from)->bits[BCM_INT_REG_IDX_0]; \
70*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_1] |= (from)->bits[BCM_INT_REG_IDX_1]; \
71*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_2] |= (from)->bits[BCM_INT_REG_IDX_2]; \
72*4882a593Smuzhiyun } while (0)
73*4882a593Smuzhiyun 
74*4882a593Smuzhiyun #define BCM_INT_BITMASK_AND(to, mask) do { \
75*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_0] &= (mask)->bits[BCM_INT_REG_IDX_0]; \
76*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_1] &= (mask)->bits[BCM_INT_REG_IDX_1]; \
77*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_2] &= (mask)->bits[BCM_INT_REG_IDX_2]; \
78*4882a593Smuzhiyun } while (0)
79*4882a593Smuzhiyun 
80*4882a593Smuzhiyun #else
81*4882a593Smuzhiyun 
82*4882a593Smuzhiyun #define BCM_INT_BITMASK_IS_EQUAL(b, cmp) (\
83*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_0] == (cmp)->bits[BCM_INT_REG_IDX_0] && \
84*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_1] == (cmp)->bits[BCM_INT_REG_IDX_1]) \
85*4882a593Smuzhiyun 
86*4882a593Smuzhiyun #define BCM_INT_BITMASK_IS_ZERO(b) (\
87*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_0] == 0 && \
88*4882a593Smuzhiyun 	(b)->bits[BCM_INT_REG_IDX_1] == 0)
89*4882a593Smuzhiyun 
90*4882a593Smuzhiyun #define BCM_INT_BITMASK_SET(to, from) do { \
91*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_0] = (from)->bits[BCM_INT_REG_IDX_0]; \
92*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_1] = (from)->bits[BCM_INT_REG_IDX_1]; \
93*4882a593Smuzhiyun } while (0)
94*4882a593Smuzhiyun 
95*4882a593Smuzhiyun #define BCM_INT_BITMASK_OR(to, from) do { \
96*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_0] |= (from)->bits[BCM_INT_REG_IDX_0]; \
97*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_1] |= (from)->bits[BCM_INT_REG_IDX_1]; \
98*4882a593Smuzhiyun } while (0)
99*4882a593Smuzhiyun 
100*4882a593Smuzhiyun #define BCM_INT_BITMASK_AND(to, mask) do { \
101*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_0] &= (mask)->bits[BCM_INT_REG_IDX_0]; \
102*4882a593Smuzhiyun 	(to)->bits[BCM_INT_REG_IDX_1] &= (mask)->bits[BCM_INT_REG_IDX_1]; \
103*4882a593Smuzhiyun } while (0)
104*4882a593Smuzhiyun 
105*4882a593Smuzhiyun #endif /* ROM_COMPAT_INT_REG_IDX */
106*4882a593Smuzhiyun 
107*4882a593Smuzhiyun #define WARM_BOOT	0xA0B0C0D0
108*4882a593Smuzhiyun 
109*4882a593Smuzhiyun typedef struct si_axi_error_info si_axi_error_info_t;
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun #ifdef AXI_TIMEOUTS_NIC
112*4882a593Smuzhiyun #define SI_MAX_ERRLOG_SIZE	4
113*4882a593Smuzhiyun typedef struct si_axi_error
114*4882a593Smuzhiyun {
115*4882a593Smuzhiyun 	uint32 error;
116*4882a593Smuzhiyun 	uint32 coreid;
117*4882a593Smuzhiyun 	uint32 errlog_lo;
118*4882a593Smuzhiyun 	uint32 errlog_hi;
119*4882a593Smuzhiyun 	uint32 errlog_id;
120*4882a593Smuzhiyun 	uint32 errlog_flags;
121*4882a593Smuzhiyun 	uint32 errlog_status;
122*4882a593Smuzhiyun } si_axi_error_t;
123*4882a593Smuzhiyun 
124*4882a593Smuzhiyun struct si_axi_error_info
125*4882a593Smuzhiyun {
126*4882a593Smuzhiyun 	uint32 count;
127*4882a593Smuzhiyun 	si_axi_error_t axi_error[SI_MAX_ERRLOG_SIZE];
128*4882a593Smuzhiyun };
129*4882a593Smuzhiyun #endif /* AXI_TIMEOUTS_NIC */
130*4882a593Smuzhiyun 
131*4882a593Smuzhiyun /**
132*4882a593Smuzhiyun  * Data structure to export all chip specific common variables
133*4882a593Smuzhiyun  *   public (read-only) portion of siutils handle returned by si_attach()/si_kattach()
134*4882a593Smuzhiyun  */
135*4882a593Smuzhiyun struct si_pub {
136*4882a593Smuzhiyun 	bool	issim;			/**< chip is in simulation or emulation */
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun 	uint16	socitype;		/**< SOCI_SB, SOCI_AI */
139*4882a593Smuzhiyun 	int16	socirev;		/**< SOC interconnect rev */
140*4882a593Smuzhiyun 
141*4882a593Smuzhiyun 	uint16	bustype;		/**< SI_BUS, PCI_BUS */
142*4882a593Smuzhiyun 	uint16	buscoretype;		/**< PCI_CORE_ID, PCIE_CORE_ID */
143*4882a593Smuzhiyun 	int16	buscorerev;		/**< buscore rev */
144*4882a593Smuzhiyun 	uint16	buscoreidx;		/**< buscore index */
145*4882a593Smuzhiyun 
146*4882a593Smuzhiyun 	int16	ccrev;			/**< chip common core rev */
147*4882a593Smuzhiyun 	uint32	cccaps;			/**< chip common capabilities */
148*4882a593Smuzhiyun 	uint32  cccaps_ext;			/**< chip common capabilities extension */
149*4882a593Smuzhiyun 	int16	pmurev;			/**< pmu core rev */
150*4882a593Smuzhiyun 	uint32	pmucaps;		/**< pmu capabilities */
151*4882a593Smuzhiyun 
152*4882a593Smuzhiyun 	uint32	boardtype;		/**< board type */
153*4882a593Smuzhiyun 	uint32	boardrev;               /* board rev */
154*4882a593Smuzhiyun 	uint32	boardvendor;		/**< board vendor */
155*4882a593Smuzhiyun 	uint32	boardflags;		/**< board flags */
156*4882a593Smuzhiyun 	uint32	boardflags2;		/**< board flags2 */
157*4882a593Smuzhiyun 	uint32	boardflags4;		/**< board flags4 */
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun 	uint32	chip;			/**< chip number */
160*4882a593Smuzhiyun 	uint16	chiprev;		/**< chip revision */
161*4882a593Smuzhiyun 	uint16	chippkg;		/**< chip package option */
162*4882a593Smuzhiyun 	uint32	chipst;			/**< chip status */
163*4882a593Smuzhiyun 
164*4882a593Smuzhiyun 	int16	gcirev;			/**< gci core rev */
165*4882a593Smuzhiyun 	int16	lhlrev;			/**< gci core rev */
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun 	uint32	lpflags;		/**< low power flags */
168*4882a593Smuzhiyun 	uint32	enum_base;	/**< backplane address where the chipcommon core resides */
169*4882a593Smuzhiyun 	bool	_multibp_enable;
170*4882a593Smuzhiyun 	bool	rffe_debug_mode;
171*4882a593Smuzhiyun 	bool	rffe_elnabyp_mode;
172*4882a593Smuzhiyun 
173*4882a593Smuzhiyun 	si_axi_error_info_t * err_info;
174*4882a593Smuzhiyun };
175*4882a593Smuzhiyun 
176*4882a593Smuzhiyun /* for HIGH_ONLY driver, the si_t must be writable to allow states sync from BMAC to HIGH driver
177*4882a593Smuzhiyun  * for monolithic driver, it is readonly to prevent accident change
178*4882a593Smuzhiyun  */
179*4882a593Smuzhiyun typedef struct si_pub si_t;
180*4882a593Smuzhiyun 
181*4882a593Smuzhiyun /*
182*4882a593Smuzhiyun  * Many of the routines below take an 'sih' handle as their first arg.
183*4882a593Smuzhiyun  * Allocate this by calling si_attach().  Free it by calling si_detach().
184*4882a593Smuzhiyun  * At any one time, the sih is logically focused on one particular si core
185*4882a593Smuzhiyun  * (the "current core").
186*4882a593Smuzhiyun  * Use si_setcore() or si_setcoreidx() to change the association to another core.
187*4882a593Smuzhiyun  */
188*4882a593Smuzhiyun #define	SI_OSH		NULL	/**< Use for si_kattach when no osh is available */
189*4882a593Smuzhiyun 
190*4882a593Smuzhiyun #ifndef SOCI_NCI_BUS
191*4882a593Smuzhiyun #define	BADIDX		(SI_MAXCORES + 1)
192*4882a593Smuzhiyun #else
193*4882a593Smuzhiyun #define	BADIDX		(0xffffu)	/* MAXCORES will be dynamically calculated for NCI. */
194*4882a593Smuzhiyun #endif /* SOCI_NCI_BUS */
195*4882a593Smuzhiyun 
196*4882a593Smuzhiyun /* clkctl xtal what flags */
197*4882a593Smuzhiyun #define	XTAL			0x1	/**< primary crystal oscillator (2050) */
198*4882a593Smuzhiyun #define	PLL			0x2	/**< main chip pll */
199*4882a593Smuzhiyun 
200*4882a593Smuzhiyun /* clkctl clk mode */
201*4882a593Smuzhiyun #define	CLK_FAST		0	/**< force fast (pll) clock */
202*4882a593Smuzhiyun #define	CLK_DYNAMIC		2	/**< enable dynamic clock control */
203*4882a593Smuzhiyun 
204*4882a593Smuzhiyun /* GPIO usage priorities */
205*4882a593Smuzhiyun #define GPIO_DRV_PRIORITY	0	/**< Driver */
206*4882a593Smuzhiyun #define GPIO_APP_PRIORITY	1	/**< Application */
207*4882a593Smuzhiyun #define GPIO_HI_PRIORITY	2	/**< Highest priority. Ignore GPIO reservation */
208*4882a593Smuzhiyun 
209*4882a593Smuzhiyun /* GPIO pull up/down */
210*4882a593Smuzhiyun #define GPIO_PULLUP		0
211*4882a593Smuzhiyun #define GPIO_PULLDN		1
212*4882a593Smuzhiyun 
213*4882a593Smuzhiyun /* GPIO event regtype */
214*4882a593Smuzhiyun #define GPIO_REGEVT		0	/**< GPIO register event */
215*4882a593Smuzhiyun #define GPIO_REGEVT_INTMSK	1	/**< GPIO register event int mask */
216*4882a593Smuzhiyun #define GPIO_REGEVT_INTPOL	2	/**< GPIO register event int polarity */
217*4882a593Smuzhiyun 
218*4882a593Smuzhiyun /* device path */
219*4882a593Smuzhiyun #define SI_DEVPATH_BUFSZ	16	/**< min buffer size in bytes */
220*4882a593Smuzhiyun 
221*4882a593Smuzhiyun /* SI routine enumeration: to be used by update function with multiple hooks */
222*4882a593Smuzhiyun #define	SI_DOATTACH	1
223*4882a593Smuzhiyun #define SI_PCIDOWN	2	/**< wireless interface is down */
224*4882a593Smuzhiyun #define SI_PCIUP	3	/**< wireless interface is up */
225*4882a593Smuzhiyun 
226*4882a593Smuzhiyun #ifdef SR_DEBUG
227*4882a593Smuzhiyun #define PMU_RES		31
228*4882a593Smuzhiyun #endif /* SR_DEBUG */
229*4882a593Smuzhiyun 
230*4882a593Smuzhiyun /* "access" param defines for si_seci_access() below */
231*4882a593Smuzhiyun #define SECI_ACCESS_STATUSMASK_SET	0
232*4882a593Smuzhiyun #define SECI_ACCESS_INTRS			1
233*4882a593Smuzhiyun #define SECI_ACCESS_UART_CTS		2
234*4882a593Smuzhiyun #define SECI_ACCESS_UART_RTS		3
235*4882a593Smuzhiyun #define SECI_ACCESS_UART_RXEMPTY	4
236*4882a593Smuzhiyun #define SECI_ACCESS_UART_GETC		5
237*4882a593Smuzhiyun #define SECI_ACCESS_UART_TXFULL		6
238*4882a593Smuzhiyun #define SECI_ACCESS_UART_PUTC		7
239*4882a593Smuzhiyun #define SECI_ACCESS_STATUSMASK_GET	8
240*4882a593Smuzhiyun 
241*4882a593Smuzhiyun #if defined(BCMQT)
242*4882a593Smuzhiyun #define	ISSIM_ENAB(sih)	TRUE
243*4882a593Smuzhiyun #else /* !defined(BCMQT) */
244*4882a593Smuzhiyun #define	ISSIM_ENAB(sih)	FALSE
245*4882a593Smuzhiyun #endif /* defined(BCMQT) */
246*4882a593Smuzhiyun 
247*4882a593Smuzhiyun #if defined(ATE_BUILD)
248*4882a593Smuzhiyun #define ATE_BLD_ENAB(sih)	TRUE
249*4882a593Smuzhiyun #else
250*4882a593Smuzhiyun #define ATE_BLD_ENAB(sih)	FALSE
251*4882a593Smuzhiyun #endif
252*4882a593Smuzhiyun 
253*4882a593Smuzhiyun #define INVALID_ADDR (0xFFFFFFFFu)
254*4882a593Smuzhiyun 
255*4882a593Smuzhiyun /* PMU clock/power control */
256*4882a593Smuzhiyun #if defined(BCMPMUCTL)
257*4882a593Smuzhiyun #define PMUCTL_ENAB(sih)	(BCMPMUCTL)
258*4882a593Smuzhiyun #else
259*4882a593Smuzhiyun #define PMUCTL_ENAB(sih)	((sih)->cccaps & CC_CAP_PMU)
260*4882a593Smuzhiyun #endif
261*4882a593Smuzhiyun 
262*4882a593Smuzhiyun #if defined(BCMAOBENAB)
263*4882a593Smuzhiyun #define AOB_ENAB(sih)  (BCMAOBENAB)
264*4882a593Smuzhiyun #else
265*4882a593Smuzhiyun #define AOB_ENAB(sih)	((sih)->ccrev >= 35 ? \
266*4882a593Smuzhiyun 			((sih)->cccaps_ext & CC_CAP_EXT_AOB_PRESENT) : 0)
267*4882a593Smuzhiyun #endif /* BCMAOBENAB */
268*4882a593Smuzhiyun 
269*4882a593Smuzhiyun /* chipcommon clock/power control (exclusive with PMU's) */
270*4882a593Smuzhiyun #if defined(BCMPMUCTL) && BCMPMUCTL
271*4882a593Smuzhiyun #define CCCTL_ENAB(sih)		(0)
272*4882a593Smuzhiyun #define CCPLL_ENAB(sih)		(0)
273*4882a593Smuzhiyun #else
274*4882a593Smuzhiyun #define CCCTL_ENAB(sih)		((sih)->cccaps & CC_CAP_PWR_CTL)
275*4882a593Smuzhiyun #define CCPLL_ENAB(sih)		((sih)->cccaps & CC_CAP_PLL_MASK)
276*4882a593Smuzhiyun #endif
277*4882a593Smuzhiyun 
278*4882a593Smuzhiyun typedef void (*gci_gpio_handler_t)(uint32 stat, void *arg);
279*4882a593Smuzhiyun 
280*4882a593Smuzhiyun typedef void (*wci2_handler_t)(void *ctx, char *buf, int len);
281*4882a593Smuzhiyun 
282*4882a593Smuzhiyun /* External BT Coex enable mask */
283*4882a593Smuzhiyun #define CC_BTCOEX_EN_MASK  0x01
284*4882a593Smuzhiyun /* External PA enable mask */
285*4882a593Smuzhiyun #define GPIO_CTRL_EPA_EN_MASK 0x40
286*4882a593Smuzhiyun /* WL/BT control enable mask */
287*4882a593Smuzhiyun #define GPIO_CTRL_5_6_EN_MASK 0x60
288*4882a593Smuzhiyun #define GPIO_CTRL_7_6_EN_MASK 0xC0
289*4882a593Smuzhiyun #define GPIO_OUT_7_EN_MASK 0x80
290*4882a593Smuzhiyun 
291*4882a593Smuzhiyun #define UCODE_WAKE_STATUS_BIT	1
292*4882a593Smuzhiyun 
293*4882a593Smuzhiyun #if defined(BCMDONGLEHOST)
294*4882a593Smuzhiyun 
295*4882a593Smuzhiyun /* CR4 specific defines used by the host driver */
296*4882a593Smuzhiyun #define SI_CR4_CAP			(0x04)
297*4882a593Smuzhiyun #define SI_CR4_BANKIDX		(0x40)
298*4882a593Smuzhiyun #define SI_CR4_BANKINFO		(0x44)
299*4882a593Smuzhiyun #define SI_CR4_BANKPDA		(0x4C)
300*4882a593Smuzhiyun 
301*4882a593Smuzhiyun #define	ARMCR4_TCBBNB_MASK	0xf0
302*4882a593Smuzhiyun #define	ARMCR4_TCBBNB_SHIFT	4
303*4882a593Smuzhiyun #define	ARMCR4_TCBANB_MASK	0xf
304*4882a593Smuzhiyun #define	ARMCR4_TCBANB_SHIFT	0
305*4882a593Smuzhiyun 
306*4882a593Smuzhiyun #define	SICF_CPUHALT		(0x0020)
307*4882a593Smuzhiyun #define	ARMCR4_BSZ_MASK		0x7f
308*4882a593Smuzhiyun #define	ARMCR4_BUNITSZ_MASK	0x200
309*4882a593Smuzhiyun #define	ARMCR4_BSZ_8K		8192
310*4882a593Smuzhiyun #define	ARMCR4_BSZ_1K		1024
311*4882a593Smuzhiyun #endif /* BCMDONGLEHOST */
312*4882a593Smuzhiyun #define	SI_BPIND_1BYTE		0x1
313*4882a593Smuzhiyun #define	SI_BPIND_2BYTE		0x3
314*4882a593Smuzhiyun #define	SI_BPIND_4BYTE		0xF
315*4882a593Smuzhiyun 
316*4882a593Smuzhiyun #define GET_GCI_OFFSET(sih, gci_reg)	\
317*4882a593Smuzhiyun 	(AOB_ENAB(sih)? OFFSETOF(gciregs_t, gci_reg) : OFFSETOF(chipcregs_t, gci_reg))
318*4882a593Smuzhiyun 
319*4882a593Smuzhiyun #define GET_GCI_CORE(sih)	\
320*4882a593Smuzhiyun 	(AOB_ENAB(sih)? si_findcoreidx(sih, GCI_CORE_ID, 0) : SI_CC_IDX)
321*4882a593Smuzhiyun 
322*4882a593Smuzhiyun #define VARBUF_PRIO_INVALID		0u
323*4882a593Smuzhiyun #define VARBUF_PRIO_NVRAM		1u
324*4882a593Smuzhiyun #define VARBUF_PRIO_SROM		2u
325*4882a593Smuzhiyun #define VARBUF_PRIO_OTP			3u
326*4882a593Smuzhiyun #define VARBUF_PRIO_SH_SFLASH		4u
327*4882a593Smuzhiyun 
328*4882a593Smuzhiyun #define BT_IN_RESET_BIT_SHIFT		19u
329*4882a593Smuzhiyun #define BT_IN_PDS_BIT_SHIFT		10u
330*4882a593Smuzhiyun 
331*4882a593Smuzhiyun /* === exported functions === */
332*4882a593Smuzhiyun extern si_t *si_attach(uint pcidev, osl_t *osh, volatile void *regs, uint bustype,
333*4882a593Smuzhiyun                        void *sdh, char **vars, uint *varsz);
334*4882a593Smuzhiyun extern si_t *si_kattach(osl_t *osh);
335*4882a593Smuzhiyun extern void si_detach(si_t *sih);
336*4882a593Smuzhiyun extern volatile void *si_d11_switch_addrbase(si_t *sih, uint coreunit);
337*4882a593Smuzhiyun extern uint si_corelist(const si_t *sih, uint coreid[]);
338*4882a593Smuzhiyun extern uint si_coreid(const si_t *sih);
339*4882a593Smuzhiyun extern uint si_flag(si_t *sih);
340*4882a593Smuzhiyun extern uint si_flag_alt(const si_t *sih);
341*4882a593Smuzhiyun extern uint si_intflag(si_t *sih);
342*4882a593Smuzhiyun extern uint si_coreidx(const si_t *sih);
343*4882a593Smuzhiyun extern uint si_get_num_cores(const si_t *sih);
344*4882a593Smuzhiyun extern uint si_coreunit(const si_t *sih);
345*4882a593Smuzhiyun extern uint si_corevendor(const si_t *sih);
346*4882a593Smuzhiyun extern uint si_corerev(const si_t *sih);
347*4882a593Smuzhiyun extern uint si_corerev_minor(const si_t *sih);
348*4882a593Smuzhiyun extern void *si_osh(si_t *sih);
349*4882a593Smuzhiyun extern void si_setosh(si_t *sih, osl_t *osh);
350*4882a593Smuzhiyun extern int si_backplane_access(si_t *sih, uint addr, uint size, uint *val, bool read);
351*4882a593Smuzhiyun 
352*4882a593Smuzhiyun /* precommit failed when this is removed */
353*4882a593Smuzhiyun /* BLAZAR_BRANCH_101_10_DHD_002/build/dhd/linux-fc30/brix-brcm */
354*4882a593Smuzhiyun /* TBD: Revisit later */
355*4882a593Smuzhiyun #ifdef BCMINTERNAL
356*4882a593Smuzhiyun extern int si_backplane_access_64(si_t *sih, uint addr, uint size,
357*4882a593Smuzhiyun     uint64 *val, bool read);
358*4882a593Smuzhiyun #endif /* BCMINTERNAL */
359*4882a593Smuzhiyun 
360*4882a593Smuzhiyun extern uint si_corereg(si_t *sih, uint coreidx, uint regoff, uint mask, uint val);
361*4882a593Smuzhiyun extern uint si_corereg_writeonly(si_t *sih, uint coreidx, uint regoff, uint mask, uint val);
362*4882a593Smuzhiyun extern uint si_pmu_corereg(si_t *sih, uint32 idx, uint regoff, uint mask, uint val);
363*4882a593Smuzhiyun extern volatile uint32 *si_corereg_addr(si_t *sih, uint coreidx, uint regoff);
364*4882a593Smuzhiyun extern volatile void *si_coreregs(const si_t *sih);
365*4882a593Smuzhiyun extern uint si_wrapperreg(const si_t *sih, uint32 offset, uint32 mask, uint32 val);
366*4882a593Smuzhiyun extern uint si_core_wrapperreg(si_t *sih, uint32 coreidx, uint32 offset, uint32 mask, uint32 val);
367*4882a593Smuzhiyun extern void *si_wrapperregs(const si_t *sih);
368*4882a593Smuzhiyun extern uint32 si_core_cflags(const si_t *sih, uint32 mask, uint32 val);
369*4882a593Smuzhiyun extern void si_core_cflags_wo(const si_t *sih, uint32 mask, uint32 val);
370*4882a593Smuzhiyun extern uint32 si_core_sflags(const si_t *sih, uint32 mask, uint32 val);
371*4882a593Smuzhiyun extern void si_commit(si_t *sih);
372*4882a593Smuzhiyun extern bool si_iscoreup(const si_t *sih);
373*4882a593Smuzhiyun extern uint si_numcoreunits(const si_t *sih, uint coreid);
374*4882a593Smuzhiyun extern uint si_numd11coreunits(const si_t *sih);
375*4882a593Smuzhiyun extern uint si_findcoreidx(const si_t *sih, uint coreid, uint coreunit);
376*4882a593Smuzhiyun extern uint si_findcoreid(const si_t *sih, uint coreidx);
377*4882a593Smuzhiyun extern volatile void *si_setcoreidx(si_t *sih, uint coreidx);
378*4882a593Smuzhiyun extern volatile void *si_setcore(si_t *sih, uint coreid, uint coreunit);
379*4882a593Smuzhiyun extern uint32 si_oobr_baseaddr(const si_t *sih, bool second);
380*4882a593Smuzhiyun #if !defined(BCMDONGLEHOST)
381*4882a593Smuzhiyun extern uint si_corereg_ifup(si_t *sih, uint core_id, uint regoff, uint mask, uint val);
382*4882a593Smuzhiyun extern void si_lowpwr_opt(si_t *sih);
383*4882a593Smuzhiyun #endif /* !defined(BCMDONGLEHOST */
384*4882a593Smuzhiyun extern volatile void *si_switch_core(si_t *sih, uint coreid, uint *origidx,
385*4882a593Smuzhiyun 	bcm_int_bitmask_t *intr_val);
386*4882a593Smuzhiyun extern void si_restore_core(si_t *sih, uint coreid, bcm_int_bitmask_t *intr_val);
387*4882a593Smuzhiyun #ifdef USE_NEW_COREREV_API
388*4882a593Smuzhiyun extern uint si_corerev_ext(si_t *sih, uint coreid, uint coreunit);
389*4882a593Smuzhiyun #else
390*4882a593Smuzhiyun uint si_get_corerev(si_t *sih, uint core_id);
391*4882a593Smuzhiyun #endif
392*4882a593Smuzhiyun extern int si_numaddrspaces(const si_t *sih);
393*4882a593Smuzhiyun extern uint32 si_addrspace(const si_t *sih, uint spidx, uint baidx);
394*4882a593Smuzhiyun extern uint32 si_addrspacesize(const si_t *sih, uint spidx, uint baidx);
395*4882a593Smuzhiyun extern void si_coreaddrspaceX(const si_t *sih, uint asidx, uint32 *addr, uint32 *size);
396*4882a593Smuzhiyun extern int si_corebist(const si_t *sih);
397*4882a593Smuzhiyun extern void si_core_reset(si_t *sih, uint32 bits, uint32 resetbits);
398*4882a593Smuzhiyun extern void si_core_disable(const si_t *sih, uint32 bits);
399*4882a593Smuzhiyun extern uint32 si_clock_rate(uint32 pll_type, uint32 n, uint32 m);
400*4882a593Smuzhiyun extern uint si_chip_hostif(const si_t *sih);
401*4882a593Smuzhiyun extern uint32 si_clock(si_t *sih);
402*4882a593Smuzhiyun extern uint32 si_alp_clock(si_t *sih); /* returns [Hz] units */
403*4882a593Smuzhiyun extern uint32 si_ilp_clock(si_t *sih); /* returns [Hz] units */
404*4882a593Smuzhiyun extern void si_pci_setup(si_t *sih, uint coremask);
405*4882a593Smuzhiyun extern int si_pcie_setup(si_t *sih, uint coreidx);
406*4882a593Smuzhiyun extern void si_setint(const si_t *sih, int siflag);
407*4882a593Smuzhiyun extern bool si_backplane64(const si_t *sih);
408*4882a593Smuzhiyun extern void si_register_intr_callback(si_t *sih, void *intrsoff_fn, void *intrsrestore_fn,
409*4882a593Smuzhiyun 	void *intrsenabled_fn, void *intr_arg);
410*4882a593Smuzhiyun extern void si_deregister_intr_callback(si_t *sih);
411*4882a593Smuzhiyun extern void si_clkctl_init(si_t *sih);
412*4882a593Smuzhiyun extern uint16 si_clkctl_fast_pwrup_delay(si_t *sih);
413*4882a593Smuzhiyun extern bool si_clkctl_cc(si_t *sih, uint mode);
414*4882a593Smuzhiyun extern int si_clkctl_xtal(si_t *sih, uint what, bool on);
415*4882a593Smuzhiyun extern void si_btcgpiowar(si_t *sih);
416*4882a593Smuzhiyun extern bool si_deviceremoved(const si_t *sih);
417*4882a593Smuzhiyun extern void si_set_device_removed(si_t *sih, bool status);
418*4882a593Smuzhiyun extern uint32 si_sysmem_size(si_t *sih);
419*4882a593Smuzhiyun extern uint32 si_socram_size(si_t *sih);
420*4882a593Smuzhiyun extern uint32 si_socram_srmem_size(si_t *sih);
421*4882a593Smuzhiyun extern void si_socram_set_bankpda(si_t *sih, uint32 bankidx, uint32 bankpda);
422*4882a593Smuzhiyun extern bool si_is_bus_mpu_present(si_t *sih);
423*4882a593Smuzhiyun 
424*4882a593Smuzhiyun extern void si_watchdog(si_t *sih, uint ticks);
425*4882a593Smuzhiyun extern void si_watchdog_ms(si_t *sih, uint32 ms);
426*4882a593Smuzhiyun extern uint32 si_watchdog_msticks(void);
427*4882a593Smuzhiyun extern volatile void *si_gpiosetcore(si_t *sih);
428*4882a593Smuzhiyun extern uint32 si_gpiocontrol(si_t *sih, uint32 mask, uint32 val, uint8 priority);
429*4882a593Smuzhiyun extern uint32 si_gpioouten(si_t *sih, uint32 mask, uint32 val, uint8 priority);
430*4882a593Smuzhiyun extern uint32 si_gpioout(si_t *sih, uint32 mask, uint32 val, uint8 priority);
431*4882a593Smuzhiyun extern uint32 si_gpioin(si_t *sih);
432*4882a593Smuzhiyun extern uint32 si_gpiointpolarity(si_t *sih, uint32 mask, uint32 val, uint8 priority);
433*4882a593Smuzhiyun extern uint32 si_gpiointmask(si_t *sih, uint32 mask, uint32 val, uint8 priority);
434*4882a593Smuzhiyun extern uint32 si_gpioeventintmask(si_t *sih, uint32 mask, uint32 val, uint8 priority);
435*4882a593Smuzhiyun extern uint32 si_gpioled(si_t *sih, uint32 mask, uint32 val);
436*4882a593Smuzhiyun extern uint32 si_gpioreserve(const si_t *sih, uint32 gpio_num, uint8 priority);
437*4882a593Smuzhiyun extern uint32 si_gpiorelease(const si_t *sih, uint32 gpio_num, uint8 priority);
438*4882a593Smuzhiyun extern uint32 si_gpiopull(si_t *sih, bool updown, uint32 mask, uint32 val);
439*4882a593Smuzhiyun extern uint32 si_gpioevent(si_t *sih, uint regtype, uint32 mask, uint32 val);
440*4882a593Smuzhiyun extern uint32 si_gpio_int_enable(si_t *sih, bool enable);
441*4882a593Smuzhiyun extern void si_gci_uart_init(si_t *sih, osl_t *osh, uint8 seci_mode);
442*4882a593Smuzhiyun extern void si_gci_enable_gpio(si_t *sih, uint8 gpio, uint32 mask, uint32 value);
443*4882a593Smuzhiyun extern uint8 si_gci_host_wake_gpio_init(si_t *sih);
444*4882a593Smuzhiyun extern uint8 si_gci_time_sync_gpio_init(si_t *sih);
445*4882a593Smuzhiyun extern void si_gci_host_wake_gpio_enable(si_t *sih, uint8 gpio, bool state);
446*4882a593Smuzhiyun extern void si_gci_time_sync_gpio_enable(si_t *sih, uint8 gpio, bool state);
447*4882a593Smuzhiyun extern void si_gci_host_wake_gpio_tristate(si_t *sih, uint8 gpio, bool state);
448*4882a593Smuzhiyun extern int si_gpio_enable(si_t *sih, uint32 mask);
449*4882a593Smuzhiyun 
450*4882a593Smuzhiyun extern void si_invalidate_second_bar0win(si_t *sih);
451*4882a593Smuzhiyun 
452*4882a593Smuzhiyun extern void si_gci_shif_config_wake_pin(si_t *sih, uint8 gpio_n,
453*4882a593Smuzhiyun 		uint8 wake_events, bool gci_gpio);
454*4882a593Smuzhiyun extern void si_shif_int_enable(si_t *sih, uint8 gpio_n, uint8 wake_events, bool enable);
455*4882a593Smuzhiyun 
456*4882a593Smuzhiyun /* GCI interrupt handlers */
457*4882a593Smuzhiyun extern void si_gci_handler_process(si_t *sih);
458*4882a593Smuzhiyun 
459*4882a593Smuzhiyun extern void si_enable_gpio_wake(si_t *sih, uint8 *wake_mask, uint8 *cur_status, uint8 gci_gpio,
460*4882a593Smuzhiyun 	uint32 pmu_cc2_mask, uint32 pmu_cc2_value);
461*4882a593Smuzhiyun 
462*4882a593Smuzhiyun /* GCI GPIO event handlers */
463*4882a593Smuzhiyun extern void *si_gci_gpioint_handler_register(si_t *sih, uint8 gpio, uint8 sts,
464*4882a593Smuzhiyun 	gci_gpio_handler_t cb, void *arg);
465*4882a593Smuzhiyun extern void si_gci_gpioint_handler_unregister(si_t *sih, void* gci_i);
466*4882a593Smuzhiyun 
467*4882a593Smuzhiyun extern void si_gci_gpio_chipcontrol_ex(si_t *si, uint8 gpoi, uint8 opt);
468*4882a593Smuzhiyun extern uint8 si_gci_gpio_status(si_t *sih, uint8 gci_gpio, uint8 mask, uint8 value);
469*4882a593Smuzhiyun extern void si_gci_config_wake_pin(si_t *sih, uint8 gpio_n, uint8 wake_events,
470*4882a593Smuzhiyun 	bool gci_gpio);
471*4882a593Smuzhiyun extern void si_gci_free_wake_pin(si_t *sih, uint8 gpio_n);
472*4882a593Smuzhiyun #if !defined(BCMDONGLEHOST)
473*4882a593Smuzhiyun extern uint8 si_gci_gpio_wakemask(si_t *sih, uint8 gpio, uint8 mask, uint8 value);
474*4882a593Smuzhiyun extern uint8 si_gci_gpio_intmask(si_t *sih, uint8 gpio, uint8 mask, uint8 value);
475*4882a593Smuzhiyun #endif /* !defined(BCMDONGLEHOST) */
476*4882a593Smuzhiyun 
477*4882a593Smuzhiyun /* Wake-on-wireless-LAN (WOWL) */
478*4882a593Smuzhiyun extern bool si_pci_pmestat(const si_t *sih);
479*4882a593Smuzhiyun extern void si_pci_pmeclr(const si_t *sih);
480*4882a593Smuzhiyun extern void si_pci_pmeen(const si_t *sih);
481*4882a593Smuzhiyun extern void si_pci_pmestatclr(const si_t *sih);
482*4882a593Smuzhiyun extern uint si_pcie_readreg(void *sih, uint addrtype, uint offset);
483*4882a593Smuzhiyun extern uint si_pcie_writereg(void *sih, uint addrtype, uint offset, uint val);
484*4882a593Smuzhiyun 
485*4882a593Smuzhiyun #ifdef BCMSDIO
486*4882a593Smuzhiyun extern void si_sdio_init(si_t *sih);
487*4882a593Smuzhiyun #endif
488*4882a593Smuzhiyun 
489*4882a593Smuzhiyun extern uint16 si_d11_devid(si_t *sih);
490*4882a593Smuzhiyun extern int si_corepciid(si_t *sih, uint func, uint16 *pcivendor, uint16 *pcidevice,
491*4882a593Smuzhiyun 	uint8 *pciclass, uint8 *pcisubclass, uint8 *pciprogif, uint8 *pciheader);
492*4882a593Smuzhiyun 
493*4882a593Smuzhiyun extern uint32 si_seci_access(si_t *sih, uint32 val, int access);
494*4882a593Smuzhiyun extern volatile void* si_seci_init(si_t *sih, uint8 seci_mode);
495*4882a593Smuzhiyun extern void si_seci_clk_force(si_t *sih, bool val);
496*4882a593Smuzhiyun extern bool si_seci_clk_force_status(si_t *sih);
497*4882a593Smuzhiyun 
498*4882a593Smuzhiyun #if (defined(BCMECICOEX) && !defined(BCMDONGLEHOST))
499*4882a593Smuzhiyun extern bool si_eci(const si_t *sih);
500*4882a593Smuzhiyun extern int si_eci_init(si_t *sih);
501*4882a593Smuzhiyun extern void si_eci_notify_bt(si_t *sih, uint32 mask, uint32 val, bool interrupt);
502*4882a593Smuzhiyun extern bool si_seci(const si_t *sih);
503*4882a593Smuzhiyun extern void* si_gci_init(si_t *sih);
504*4882a593Smuzhiyun extern void si_seci_down(si_t *sih);
505*4882a593Smuzhiyun extern void si_seci_upd(si_t *sih, bool enable);
506*4882a593Smuzhiyun extern bool si_gci(const si_t *sih);
507*4882a593Smuzhiyun extern bool si_sraon(const si_t *sih);
508*4882a593Smuzhiyun #else
509*4882a593Smuzhiyun #define si_eci(sih) 0
510*4882a593Smuzhiyun #define si_eci_init(sih) 0
511*4882a593Smuzhiyun #define si_eci_notify_bt(sih, type, val)  (0)
512*4882a593Smuzhiyun #define si_seci(sih) 0
513*4882a593Smuzhiyun #define si_seci_upd(sih, a)	do {} while (0)
514*4882a593Smuzhiyun #define si_gci_init(sih) NULL
515*4882a593Smuzhiyun #define si_seci_down(sih) do {} while (0)
516*4882a593Smuzhiyun #define si_gci(sih) 0
517*4882a593Smuzhiyun #define si_sraon(sih) 0
518*4882a593Smuzhiyun #endif /* BCMECICOEX */
519*4882a593Smuzhiyun 
520*4882a593Smuzhiyun /* OTP status */
521*4882a593Smuzhiyun extern bool si_is_otp_disabled(const si_t *sih);
522*4882a593Smuzhiyun extern bool si_is_otp_powered(si_t *sih);
523*4882a593Smuzhiyun extern void si_otp_power(si_t *sih, bool on, uint32* min_res_mask);
524*4882a593Smuzhiyun 
525*4882a593Smuzhiyun /* SPROM availability */
526*4882a593Smuzhiyun extern bool si_is_sprom_available(si_t *sih);
527*4882a593Smuzhiyun #ifdef SI_SPROM_PROBE
528*4882a593Smuzhiyun extern void si_sprom_init(si_t *sih);
529*4882a593Smuzhiyun #endif /* SI_SPROM_PROBE */
530*4882a593Smuzhiyun 
531*4882a593Smuzhiyun /* SFlash availability */
532*4882a593Smuzhiyun bool si_is_sflash_available(const si_t *sih);
533*4882a593Smuzhiyun 
534*4882a593Smuzhiyun /* OTP/SROM CIS stuff */
535*4882a593Smuzhiyun extern int si_cis_source(const si_t *sih);
536*4882a593Smuzhiyun #define CIS_DEFAULT	0
537*4882a593Smuzhiyun #define CIS_SROM	1
538*4882a593Smuzhiyun #define CIS_OTP		2
539*4882a593Smuzhiyun 
540*4882a593Smuzhiyun /* Fab-id information */
541*4882a593Smuzhiyun #define	DEFAULT_FAB	0x0	/**< Original/first fab used for this chip */
542*4882a593Smuzhiyun #define	CSM_FAB7	0x1	/**< CSM Fab7 chip */
543*4882a593Smuzhiyun #define	TSMC_FAB12	0x2	/**< TSMC Fab12/Fab14 chip */
544*4882a593Smuzhiyun #define	SMIC_FAB4	0x3	/**< SMIC Fab4 chip */
545*4882a593Smuzhiyun 
546*4882a593Smuzhiyun /* bp_ind_access default timeout */
547*4882a593Smuzhiyun #define BP_ACCESS_TO (500u * 1000u)
548*4882a593Smuzhiyun 
549*4882a593Smuzhiyun extern uint16 BCMATTACHFN(si_fabid)(si_t *sih);
550*4882a593Smuzhiyun extern uint16 BCMINITFN(si_chipid)(const si_t *sih);
551*4882a593Smuzhiyun 
552*4882a593Smuzhiyun /*
553*4882a593Smuzhiyun  * Build device path. Path size must be >= SI_DEVPATH_BUFSZ.
554*4882a593Smuzhiyun  * The returned path is NULL terminated and has trailing '/'.
555*4882a593Smuzhiyun  * Return 0 on success, nonzero otherwise.
556*4882a593Smuzhiyun  */
557*4882a593Smuzhiyun extern int si_devpath(const si_t *sih, char *path, int size);
558*4882a593Smuzhiyun extern int si_devpath_pcie(const si_t *sih, char *path, int size);
559*4882a593Smuzhiyun /* Read variable with prepending the devpath to the name */
560*4882a593Smuzhiyun extern char *si_getdevpathvar(const si_t *sih, const char *name);
561*4882a593Smuzhiyun extern int si_getdevpathintvar(const si_t *sih, const char *name);
562*4882a593Smuzhiyun extern char *si_coded_devpathvar(const si_t *sih, char *varname, int var_len, const char *name);
563*4882a593Smuzhiyun 
564*4882a593Smuzhiyun /* === HW PR WARs === */
565*4882a593Smuzhiyun extern uint8 si_pcieclkreq(const si_t *sih, uint32 mask, uint32 val);
566*4882a593Smuzhiyun extern uint32 si_pcielcreg(const si_t *sih, uint32 mask, uint32 val);
567*4882a593Smuzhiyun extern uint8 si_pcieltrenable(const si_t *sih, uint32 mask, uint32 val);
568*4882a593Smuzhiyun extern uint8 si_pcieobffenable(const si_t *sih, uint32 mask, uint32 val);
569*4882a593Smuzhiyun extern uint32 si_pcieltr_reg(const si_t *sih, uint32 reg, uint32 mask, uint32 val);
570*4882a593Smuzhiyun extern uint32 si_pcieltrspacing_reg(const si_t *sih, uint32 mask, uint32 val);
571*4882a593Smuzhiyun extern uint32 si_pcieltrhysteresiscnt_reg(const si_t *sih, uint32 mask, uint32 val);
572*4882a593Smuzhiyun extern void si_pcie_set_error_injection(const si_t *sih, uint32 mode);
573*4882a593Smuzhiyun extern void si_pcie_set_L1substate(const si_t *sih, uint32 substate);
574*4882a593Smuzhiyun #ifndef BCM_BOOTLOADER
575*4882a593Smuzhiyun extern uint32 si_pcie_get_L1substate(const si_t *sih);
576*4882a593Smuzhiyun #endif /* BCM_BOOTLOADER */
577*4882a593Smuzhiyun extern void si_pci_down(const si_t *sih);
578*4882a593Smuzhiyun extern void si_pci_up(const si_t *sih);
579*4882a593Smuzhiyun extern void si_pci_sleep(const si_t *sih);
580*4882a593Smuzhiyun extern void si_pcie_war_ovr_update(const si_t *sih, uint8 aspm);
581*4882a593Smuzhiyun extern void si_pcie_power_save_enable(const si_t *sih, bool enable);
582*4882a593Smuzhiyun extern int si_pci_fixcfg(si_t *sih);
583*4882a593Smuzhiyun extern bool si_is_warmboot(void);
584*4882a593Smuzhiyun 
585*4882a593Smuzhiyun extern void si_chipcontrl_restore(si_t *sih, uint32 val);
586*4882a593Smuzhiyun extern uint32 si_chipcontrl_read(si_t *sih);
587*4882a593Smuzhiyun extern void si_chipcontrl_srom4360(si_t *sih, bool on);
588*4882a593Smuzhiyun extern void si_srom_clk_set(si_t *sih); /**< for chips with fast BP clock */
589*4882a593Smuzhiyun extern void si_btc_enable_chipcontrol(si_t *sih);
590*4882a593Smuzhiyun extern void si_pmu_avb_clk_set(si_t *sih, osl_t *osh, bool set_flag);
591*4882a593Smuzhiyun /* === debug routines === */
592*4882a593Smuzhiyun 
593*4882a593Smuzhiyun extern bool si_taclear(si_t *sih, bool details);
594*4882a593Smuzhiyun 
595*4882a593Smuzhiyun #ifdef BCMDBG
596*4882a593Smuzhiyun extern void si_view(si_t *sih, bool verbose);
597*4882a593Smuzhiyun extern void si_viewall(si_t *sih, bool verbose);
598*4882a593Smuzhiyun #endif /* BCMDBG */
599*4882a593Smuzhiyun #if defined(BCMDBG) || defined(BCMDBG_DUMP) || defined(BCMDBG_PHYDUMP) || \
600*4882a593Smuzhiyun 	defined(WLTEST)
601*4882a593Smuzhiyun struct bcmstrbuf;
602*4882a593Smuzhiyun extern int si_dump_pcieinfo(const si_t *sih, struct bcmstrbuf *b);
603*4882a593Smuzhiyun extern void si_dump_pmuregs(si_t *sih, struct bcmstrbuf *b);
604*4882a593Smuzhiyun extern int si_dump_pcieregs(const si_t *sih, struct bcmstrbuf *b);
605*4882a593Smuzhiyun #endif /* BCMDBG || BCMDBG_DUMP || WLTEST */
606*4882a593Smuzhiyun 
607*4882a593Smuzhiyun #if defined(BCMDBG) || defined(BCMDBG_DUMP) || defined(BCMDBG_PHYDUMP)
608*4882a593Smuzhiyun extern void si_dump(const si_t *sih, struct bcmstrbuf *b);
609*4882a593Smuzhiyun extern void si_ccreg_dump(si_t *sih, struct bcmstrbuf *b);
610*4882a593Smuzhiyun extern void si_clkctl_dump(si_t *sih, struct bcmstrbuf *b);
611*4882a593Smuzhiyun extern int si_gpiodump(si_t *sih, struct bcmstrbuf *b);
612*4882a593Smuzhiyun 
613*4882a593Smuzhiyun extern void si_dumpregs(si_t *sih, struct bcmstrbuf *b);
614*4882a593Smuzhiyun #endif /* BCMDBG || BCMDBG_DUMP || BCMDBG_PHYDUMP */
615*4882a593Smuzhiyun 
616*4882a593Smuzhiyun extern uint32 si_ccreg(si_t *sih, uint32 offset, uint32 mask, uint32 val);
617*4882a593Smuzhiyun extern uint32 si_pciereg(const si_t *sih, uint32 offset, uint32 mask, uint32 val, uint type);
618*4882a593Smuzhiyun extern int si_bpind_access(si_t *sih, uint32 addr_high, uint32 addr_low,
619*4882a593Smuzhiyun 	int32* data, bool read, uint32 us_timeout);
620*4882a593Smuzhiyun extern void sih_write_sraon(si_t *sih, int offset, int len, const uint32* data);
621*4882a593Smuzhiyun #ifdef SR_DEBUG
622*4882a593Smuzhiyun extern void si_dump_pmu(si_t *sih, void *pmu_var);
623*4882a593Smuzhiyun extern void si_pmu_keep_on(const si_t *sih, int32 int_val);
624*4882a593Smuzhiyun extern uint32 si_pmu_keep_on_get(const si_t *sih);
625*4882a593Smuzhiyun extern uint32 si_power_island_set(si_t *sih, uint32 int_val);
626*4882a593Smuzhiyun extern uint32 si_power_island_get(si_t *sih);
627*4882a593Smuzhiyun #endif /* SR_DEBUG */
628*4882a593Smuzhiyun 
629*4882a593Smuzhiyun extern uint32 si_pcieserdesreg(const si_t *sih, uint32 mdioslave, uint32 offset,
630*4882a593Smuzhiyun 	uint32 mask, uint32 val);
631*4882a593Smuzhiyun extern void si_pcie_set_request_size(const si_t *sih, uint16 size);
632*4882a593Smuzhiyun extern uint16 si_pcie_get_request_size(const si_t *sih);
633*4882a593Smuzhiyun extern void si_pcie_set_maxpayload_size(const si_t *sih, uint16 size);
634*4882a593Smuzhiyun extern uint16 si_pcie_get_maxpayload_size(const si_t *sih);
635*4882a593Smuzhiyun extern uint16 si_pcie_get_ssid(const si_t *sih);
636*4882a593Smuzhiyun extern uint32 si_pcie_get_bar0(const si_t *sih);
637*4882a593Smuzhiyun extern int si_pcie_configspace_cache(const si_t *sih);
638*4882a593Smuzhiyun extern int si_pcie_configspace_restore(const si_t *sih);
639*4882a593Smuzhiyun extern int si_pcie_configspace_get(const si_t *sih, uint8 *buf, uint size);
640*4882a593Smuzhiyun 
641*4882a593Smuzhiyun #ifndef BCMDONGLEHOST
642*4882a593Smuzhiyun extern void si_muxenab(si_t *sih, uint32 w);
643*4882a593Smuzhiyun extern uint32 si_clear_backplane_to(si_t *sih);
644*4882a593Smuzhiyun extern void si_slave_wrapper_add(si_t *sih);
645*4882a593Smuzhiyun 
646*4882a593Smuzhiyun #ifdef AXI_TIMEOUTS_NIC
647*4882a593Smuzhiyun extern uint32 si_clear_backplane_to_fast(void *sih, void *addr);
648*4882a593Smuzhiyun #endif /* AXI_TIMEOUTS_NIC */
649*4882a593Smuzhiyun 
650*4882a593Smuzhiyun #if defined(AXI_TIMEOUTS) || defined(AXI_TIMEOUTS_NIC)
651*4882a593Smuzhiyun extern uint32 si_clear_backplane_to_per_core(si_t *sih, uint coreid, uint coreunit, void *wrap);
652*4882a593Smuzhiyun #endif /* AXI_TIMEOUTS || AXI_TIMEOUTS_NIC */
653*4882a593Smuzhiyun #endif /* !BCMDONGLEHOST */
654*4882a593Smuzhiyun 
655*4882a593Smuzhiyun extern uint32 si_findcoreidx_by_axiid(const si_t *sih, uint32 axiid);
656*4882a593Smuzhiyun extern void si_wrapper_get_last_error(const si_t *sih, uint32 *error_status, uint32 *core,
657*4882a593Smuzhiyun 	uint32 *lo, uint32 *hi, uint32 *id);
658*4882a593Smuzhiyun extern uint32 si_get_axi_timeout_reg(const si_t *sih);
659*4882a593Smuzhiyun 
660*4882a593Smuzhiyun #ifdef AXI_TIMEOUTS_NIC
661*4882a593Smuzhiyun extern const si_axi_error_info_t * si_get_axi_errlog_info(const si_t *sih);
662*4882a593Smuzhiyun extern void si_reset_axi_errlog_info(const si_t * sih);
663*4882a593Smuzhiyun #endif /* AXI_TIMEOUTS_NIC */
664*4882a593Smuzhiyun 
665*4882a593Smuzhiyun extern void si_update_backplane_timeouts(const si_t *sih, bool enable, uint32 timeout, uint32 cid);
666*4882a593Smuzhiyun 
667*4882a593Smuzhiyun #if defined(BCMDONGLEHOST)
668*4882a593Smuzhiyun extern uint32 si_tcm_size(si_t *sih);
669*4882a593Smuzhiyun extern bool si_has_flops(si_t *sih);
670*4882a593Smuzhiyun #endif /* BCMDONGLEHOST */
671*4882a593Smuzhiyun 
672*4882a593Smuzhiyun extern int si_set_sromctl(si_t *sih, uint32 value);
673*4882a593Smuzhiyun extern uint32 si_get_sromctl(si_t *sih);
674*4882a593Smuzhiyun 
675*4882a593Smuzhiyun extern uint32 si_gci_direct(si_t *sih, uint offset, uint32 mask, uint32 val);
676*4882a593Smuzhiyun extern uint32 si_gci_indirect(si_t *sih, uint regidx, uint offset, uint32 mask, uint32 val);
677*4882a593Smuzhiyun extern uint32 si_gci_output(si_t *sih, uint reg, uint32 mask, uint32 val);
678*4882a593Smuzhiyun extern uint32 si_gci_input(si_t *sih, uint reg);
679*4882a593Smuzhiyun extern uint32 si_gci_int_enable(si_t *sih, bool enable);
680*4882a593Smuzhiyun extern void si_gci_reset(si_t *sih);
681*4882a593Smuzhiyun #ifdef BCMLTECOEX
682*4882a593Smuzhiyun extern void si_ercx_init(si_t *sih, uint32 ltecx_mux, uint32 ltecx_padnum,
683*4882a593Smuzhiyun 	uint32 ltecx_fnsel, uint32 ltecx_gcigpio);
684*4882a593Smuzhiyun #endif /* BCMLTECOEX */
685*4882a593Smuzhiyun #if defined(BCMLTECOEX) && !defined(WLTEST)
686*4882a593Smuzhiyun extern int si_wci2_rxfifo_handler_register(si_t *sih, wci2_handler_t rx_cb, void *ctx);
687*4882a593Smuzhiyun extern void si_wci2_rxfifo_handler_unregister(si_t *sih);
688*4882a593Smuzhiyun #endif /* BCMLTECOEX && !WLTEST */
689*4882a593Smuzhiyun extern void si_gci_seci_init(si_t *sih);
690*4882a593Smuzhiyun extern void si_wci2_init(si_t *sih, uint8 baudrate, uint32 ltecx_mux, uint32 ltecx_padnum,
691*4882a593Smuzhiyun 	uint32 ltecx_fnsel, uint32 ltecx_gcigpio, uint32 xtalfreq);
692*4882a593Smuzhiyun 
693*4882a593Smuzhiyun extern bool si_btcx_wci2_init(si_t *sih);
694*4882a593Smuzhiyun 
695*4882a593Smuzhiyun extern void si_gci_set_functionsel(si_t *sih, uint32 pin, uint8 fnsel);
696*4882a593Smuzhiyun extern uint32 si_gci_get_functionsel(si_t *sih, uint32 pin);
697*4882a593Smuzhiyun extern void si_gci_clear_functionsel(si_t *sih, uint8 fnsel);
698*4882a593Smuzhiyun extern uint8 si_gci_get_chipctrlreg_idx(uint32 pin, uint32 *regidx, uint32 *pos);
699*4882a593Smuzhiyun extern uint32 si_gci_chipcontrol(si_t *sih, uint reg, uint32 mask, uint32 val);
700*4882a593Smuzhiyun extern uint32 si_gci_chipstatus(si_t *sih, uint reg);
701*4882a593Smuzhiyun extern uint8 si_enable_device_wake(si_t *sih, uint8 *wake_status, uint8 *cur_status);
702*4882a593Smuzhiyun extern uint8 si_get_device_wake_opt(si_t *sih);
703*4882a593Smuzhiyun extern void si_swdenable(si_t *sih, uint32 swdflag);
704*4882a593Smuzhiyun extern uint8 si_enable_perst_wake(si_t *sih, uint8 *perst_wake_mask, uint8 *perst_cur_status);
705*4882a593Smuzhiyun 
706*4882a593Smuzhiyun extern uint32 si_get_pmu_reg_addr(si_t *sih, uint32 offset);
707*4882a593Smuzhiyun #define CHIPCTRLREG1 0x1
708*4882a593Smuzhiyun #define CHIPCTRLREG2 0x2
709*4882a593Smuzhiyun #define CHIPCTRLREG3 0x3
710*4882a593Smuzhiyun #define CHIPCTRLREG4 0x4
711*4882a593Smuzhiyun #define CHIPCTRLREG5 0x5
712*4882a593Smuzhiyun #define MINRESMASKREG 0x618
713*4882a593Smuzhiyun #define MAXRESMASKREG 0x61c
714*4882a593Smuzhiyun #define CHIPCTRLADDR 0x650
715*4882a593Smuzhiyun #define CHIPCTRLDATA 0x654
716*4882a593Smuzhiyun #define RSRCTABLEADDR 0x620
717*4882a593Smuzhiyun #define RSRCUPDWNTIME 0x628
718*4882a593Smuzhiyun #define PMUREG_RESREQ_MASK 0x68c
719*4882a593Smuzhiyun 
720*4882a593Smuzhiyun void si_update_masks(si_t *sih);
721*4882a593Smuzhiyun void si_force_islanding(si_t *sih, bool enable);
722*4882a593Smuzhiyun extern uint32 si_pmu_res_req_timer_clr(si_t *sih);
723*4882a593Smuzhiyun extern void si_pmu_rfldo(si_t *sih, bool on);
724*4882a593Smuzhiyun extern void si_pcie_ltr_war(const si_t *sih);
725*4882a593Smuzhiyun extern void si_pcie_hw_LTR_war(const si_t *sih);
726*4882a593Smuzhiyun extern void si_pcie_hw_L1SS_war(const si_t *sih);
727*4882a593Smuzhiyun extern void si_pciedev_crwlpciegen2(const si_t *sih);
728*4882a593Smuzhiyun extern void si_pcie_prep_D3(const si_t *sih, bool enter_D3);
729*4882a593Smuzhiyun extern void si_pciedev_reg_pm_clk_period(const si_t *sih);
730*4882a593Smuzhiyun extern void si_pcie_disable_oobselltr(const si_t *sih);
731*4882a593Smuzhiyun extern uint32 si_raw_reg(const si_t *sih, uint32 reg, uint32 val, uint32 wrire_req);
732*4882a593Smuzhiyun 
733*4882a593Smuzhiyun /* Macro to enable clock gating changes in different cores */
734*4882a593Smuzhiyun #define MEM_CLK_GATE_BIT	5
735*4882a593Smuzhiyun #define GCI_CLK_GATE_BIT	18
736*4882a593Smuzhiyun 
737*4882a593Smuzhiyun #define USBAPP_CLK_BIT		0
738*4882a593Smuzhiyun #define PCIE_CLK_BIT		3
739*4882a593Smuzhiyun #define ARMCR4_DBG_CLK_BIT	4
740*4882a593Smuzhiyun #define SAMPLE_SYNC_CLK_BIT	17
741*4882a593Smuzhiyun #define PCIE_TL_CLK_BIT		18
742*4882a593Smuzhiyun #define HQ_REQ_BIT		24
743*4882a593Smuzhiyun #define PLL_DIV2_BIT_START	9
744*4882a593Smuzhiyun #define PLL_DIV2_MASK		(0x37 << PLL_DIV2_BIT_START)
745*4882a593Smuzhiyun #define PLL_DIV2_DIS_OP		(0x37 << PLL_DIV2_BIT_START)
746*4882a593Smuzhiyun 
747*4882a593Smuzhiyun #define pmu_corereg(si, cc_idx, member, mask, val) \
748*4882a593Smuzhiyun 	(AOB_ENAB(si) ? \
749*4882a593Smuzhiyun 		si_pmu_corereg(si, si_findcoreidx(si, PMU_CORE_ID, 0), \
750*4882a593Smuzhiyun 			       OFFSETOF(pmuregs_t, member), mask, val): \
751*4882a593Smuzhiyun 		si_pmu_corereg(si, cc_idx, OFFSETOF(chipcregs_t, member), mask, val))
752*4882a593Smuzhiyun 
753*4882a593Smuzhiyun #define PMU_REG(si, member, mask, val) \
754*4882a593Smuzhiyun 	(AOB_ENAB(si) ? \
755*4882a593Smuzhiyun 		si_corereg(si, si_findcoreidx(si, PMU_CORE_ID, 0), \
756*4882a593Smuzhiyun 			OFFSETOF(pmuregs_t, member), mask, val): \
757*4882a593Smuzhiyun 		si_corereg(si, SI_CC_IDX, OFFSETOF(chipcregs_t, member), mask, val))
758*4882a593Smuzhiyun 
759*4882a593Smuzhiyun /* Used only for the regs present in the pmu core and not present in the old cc core */
760*4882a593Smuzhiyun #define PMU_REG_NEW(si, member, mask, val) \
761*4882a593Smuzhiyun 		si_corereg(si, si_findcoreidx(si, PMU_CORE_ID, 0), \
762*4882a593Smuzhiyun 			OFFSETOF(pmuregs_t, member), mask, val)
763*4882a593Smuzhiyun 
764*4882a593Smuzhiyun #define GCI_REG(si, offset, mask, val) \
765*4882a593Smuzhiyun 		(AOB_ENAB(si) ? \
766*4882a593Smuzhiyun 			si_corereg(si, si_findcoreidx(si, GCI_CORE_ID, 0), \
767*4882a593Smuzhiyun 				offset, mask, val): \
768*4882a593Smuzhiyun 			si_corereg(si, SI_CC_IDX, offset, mask, val))
769*4882a593Smuzhiyun 
770*4882a593Smuzhiyun /* Used only for the regs present in the gci core and not present in the old cc core */
771*4882a593Smuzhiyun #define GCI_REG_NEW(si, member, mask, val) \
772*4882a593Smuzhiyun 		si_corereg(si, si_findcoreidx(si, GCI_CORE_ID, 0), \
773*4882a593Smuzhiyun 			OFFSETOF(gciregs_t, member), mask, val)
774*4882a593Smuzhiyun 
775*4882a593Smuzhiyun #define LHL_REG(si, member, mask, val) \
776*4882a593Smuzhiyun 		si_corereg(si, si_findcoreidx(si, GCI_CORE_ID, 0), \
777*4882a593Smuzhiyun 			OFFSETOF(gciregs_t, member), mask, val)
778*4882a593Smuzhiyun 
779*4882a593Smuzhiyun #define CHIPC_REG(si, member, mask, val) \
780*4882a593Smuzhiyun 		si_corereg(si, SI_CC_IDX, OFFSETOF(chipcregs_t, member), mask, val)
781*4882a593Smuzhiyun 
782*4882a593Smuzhiyun /* GCI Macros */
783*4882a593Smuzhiyun #define ALLONES_32				0xFFFFFFFF
784*4882a593Smuzhiyun #define GCI_CCTL_SECIRST_OFFSET			0 /**< SeciReset */
785*4882a593Smuzhiyun #define GCI_CCTL_RSTSL_OFFSET			1 /**< ResetSeciLogic */
786*4882a593Smuzhiyun #define GCI_CCTL_SECIEN_OFFSET			2 /**< EnableSeci  */
787*4882a593Smuzhiyun #define GCI_CCTL_FSL_OFFSET			3 /**< ForceSeciOutLow */
788*4882a593Smuzhiyun #define GCI_CCTL_SMODE_OFFSET			4 /**< SeciOpMode, 6:4 */
789*4882a593Smuzhiyun #define GCI_CCTL_US_OFFSET			7 /**< UpdateSeci */
790*4882a593Smuzhiyun #define GCI_CCTL_BRKONSLP_OFFSET		8 /**< BreakOnSleep */
791*4882a593Smuzhiyun #define GCI_CCTL_SILOWTOUT_OFFSET		9 /**< SeciInLowTimeout, 10:9 */
792*4882a593Smuzhiyun #define GCI_CCTL_RSTOCC_OFFSET			11 /**< ResetOffChipCoex */
793*4882a593Smuzhiyun #define GCI_CCTL_ARESEND_OFFSET			12 /**< AutoBTSigResend */
794*4882a593Smuzhiyun #define GCI_CCTL_FGCR_OFFSET			16 /**< ForceGciClkReq */
795*4882a593Smuzhiyun #define GCI_CCTL_FHCRO_OFFSET			17 /**< ForceHWClockReqOff */
796*4882a593Smuzhiyun #define GCI_CCTL_FREGCLK_OFFSET			18 /**< ForceRegClk */
797*4882a593Smuzhiyun #define GCI_CCTL_FSECICLK_OFFSET		19 /**< ForceSeciClk */
798*4882a593Smuzhiyun #define GCI_CCTL_FGCA_OFFSET			20 /**< ForceGciClkAvail */
799*4882a593Smuzhiyun #define GCI_CCTL_FGCAV_OFFSET			21 /**< ForceGciClkAvailValue */
800*4882a593Smuzhiyun #define GCI_CCTL_SCS_OFFSET			24 /**< SeciClkStretch, 31:24 */
801*4882a593Smuzhiyun #define GCI_CCTL_SCS				25 /* SeciClkStretch */
802*4882a593Smuzhiyun 
803*4882a593Smuzhiyun #define GCI_MODE_UART				0x0
804*4882a593Smuzhiyun #define GCI_MODE_SECI				0x1
805*4882a593Smuzhiyun #define GCI_MODE_BTSIG				0x2
806*4882a593Smuzhiyun #define GCI_MODE_GPIO				0x3
807*4882a593Smuzhiyun #define GCI_MODE_MASK				0x7
808*4882a593Smuzhiyun 
809*4882a593Smuzhiyun #define GCI_CCTL_LOWTOUT_DIS			0x0
810*4882a593Smuzhiyun #define GCI_CCTL_LOWTOUT_10BIT			0x1
811*4882a593Smuzhiyun #define GCI_CCTL_LOWTOUT_20BIT			0x2
812*4882a593Smuzhiyun #define GCI_CCTL_LOWTOUT_30BIT			0x3
813*4882a593Smuzhiyun #define GCI_CCTL_LOWTOUT_MASK			0x3
814*4882a593Smuzhiyun 
815*4882a593Smuzhiyun #define GCI_CCTL_SCS_DEF			0x19
816*4882a593Smuzhiyun #define GCI_CCTL_SCS_MASK			0xFF
817*4882a593Smuzhiyun 
818*4882a593Smuzhiyun #define GCI_SECIIN_MODE_OFFSET			0
819*4882a593Smuzhiyun #define GCI_SECIIN_GCIGPIO_OFFSET		4
820*4882a593Smuzhiyun #define GCI_SECIIN_RXID2IP_OFFSET		8
821*4882a593Smuzhiyun 
822*4882a593Smuzhiyun #define GCI_SECIIN_MODE_MASK                    0x7
823*4882a593Smuzhiyun #define GCI_SECIIN_GCIGPIO_MASK                 0xF
824*4882a593Smuzhiyun 
825*4882a593Smuzhiyun #define GCI_SECIOUT_MODE_OFFSET			0
826*4882a593Smuzhiyun #define GCI_SECIOUT_GCIGPIO_OFFSET		4
827*4882a593Smuzhiyun #define	GCI_SECIOUT_LOOPBACK_OFFSET		8
828*4882a593Smuzhiyun #define GCI_SECIOUT_SECIINRELATED_OFFSET	16
829*4882a593Smuzhiyun 
830*4882a593Smuzhiyun #define GCI_SECIOUT_MODE_MASK                   0x7
831*4882a593Smuzhiyun #define GCI_SECIOUT_GCIGPIO_MASK                0xF
832*4882a593Smuzhiyun #define GCI_SECIOUT_SECIINRELATED_MASK          0x1
833*4882a593Smuzhiyun 
834*4882a593Smuzhiyun #define GCI_SECIOUT_SECIINRELATED               0x1
835*4882a593Smuzhiyun 
836*4882a593Smuzhiyun #define GCI_SECIAUX_RXENABLE_OFFSET		0
837*4882a593Smuzhiyun #define GCI_SECIFIFO_RXENABLE_OFFSET		16
838*4882a593Smuzhiyun 
839*4882a593Smuzhiyun #define GCI_SECITX_ENABLE_OFFSET		0
840*4882a593Smuzhiyun 
841*4882a593Smuzhiyun #define GCI_GPIOCTL_INEN_OFFSET			0
842*4882a593Smuzhiyun #define GCI_GPIOCTL_OUTEN_OFFSET		1
843*4882a593Smuzhiyun #define GCI_GPIOCTL_PDN_OFFSET			4
844*4882a593Smuzhiyun 
845*4882a593Smuzhiyun #define GCI_GPIOIDX_OFFSET			16
846*4882a593Smuzhiyun 
847*4882a593Smuzhiyun #define GCI_LTECX_SECI_ID			0 /**< SECI port for LTECX */
848*4882a593Smuzhiyun #define GCI_LTECX_TXCONF_EN_OFFSET		2
849*4882a593Smuzhiyun #define GCI_LTECX_PRISEL_EN_OFFSET		3
850*4882a593Smuzhiyun 
851*4882a593Smuzhiyun /* To access per GCI bit registers */
852*4882a593Smuzhiyun #define GCI_REG_WIDTH				32
853*4882a593Smuzhiyun 
854*4882a593Smuzhiyun /* number of event summary bits */
855*4882a593Smuzhiyun #define GCI_EVENT_NUM_BITS			32
856*4882a593Smuzhiyun 
857*4882a593Smuzhiyun /* gci event bits per core */
858*4882a593Smuzhiyun #define GCI_EVENT_BITS_PER_CORE	4
859*4882a593Smuzhiyun #define GCI_EVENT_HWBIT_1			1
860*4882a593Smuzhiyun #define GCI_EVENT_HWBIT_2			2
861*4882a593Smuzhiyun #define GCI_EVENT_SWBIT_1			3
862*4882a593Smuzhiyun #define GCI_EVENT_SWBIT_2			4
863*4882a593Smuzhiyun 
864*4882a593Smuzhiyun #define GCI_MBDATA_TOWLAN_POS	96
865*4882a593Smuzhiyun #define GCI_MBACK_TOWLAN_POS	104
866*4882a593Smuzhiyun #define GCI_WAKE_TOWLAN_PO		112
867*4882a593Smuzhiyun #define GCI_SWREADY_POS			120
868*4882a593Smuzhiyun 
869*4882a593Smuzhiyun /* GCI bit positions */
870*4882a593Smuzhiyun /* GCI [127:000] = WLAN [127:0] */
871*4882a593Smuzhiyun #define GCI_WLAN_IP_ID				0
872*4882a593Smuzhiyun #define GCI_WLAN_BEGIN				0
873*4882a593Smuzhiyun #define GCI_WLAN_PRIO_POS			(GCI_WLAN_BEGIN + 4)
874*4882a593Smuzhiyun #define GCI_WLAN_PERST_POS			(GCI_WLAN_BEGIN + 15)
875*4882a593Smuzhiyun 
876*4882a593Smuzhiyun /* GCI [255:128] = BT [127:0] */
877*4882a593Smuzhiyun #define GCI_BT_IP_ID					1
878*4882a593Smuzhiyun #define GCI_BT_BEGIN					128
879*4882a593Smuzhiyun #define GCI_BT_MBDATA_TOWLAN_POS	(GCI_BT_BEGIN + GCI_MBDATA_TOWLAN_POS)
880*4882a593Smuzhiyun #define GCI_BT_MBACK_TOWLAN_POS	(GCI_BT_BEGIN + GCI_MBACK_TOWLAN_POS)
881*4882a593Smuzhiyun #define GCI_BT_WAKE_TOWLAN_POS	(GCI_BT_BEGIN + GCI_WAKE_TOWLAN_PO)
882*4882a593Smuzhiyun #define GCI_BT_SWREADY_POS			(GCI_BT_BEGIN + GCI_SWREADY_POS)
883*4882a593Smuzhiyun 
884*4882a593Smuzhiyun /* GCI [639:512] = LTE [127:0] */
885*4882a593Smuzhiyun #define GCI_LTE_IP_ID				4
886*4882a593Smuzhiyun #define GCI_LTE_BEGIN				512
887*4882a593Smuzhiyun #define GCI_LTE_FRAMESYNC_POS			(GCI_LTE_BEGIN + 0)
888*4882a593Smuzhiyun #define GCI_LTE_RX_POS				(GCI_LTE_BEGIN + 1)
889*4882a593Smuzhiyun #define GCI_LTE_TX_POS				(GCI_LTE_BEGIN + 2)
890*4882a593Smuzhiyun #define GCI_LTE_WCI2TYPE_POS			(GCI_LTE_BEGIN + 48)
891*4882a593Smuzhiyun #define GCI_LTE_WCI2TYPE_MASK			7
892*4882a593Smuzhiyun #define GCI_LTE_AUXRXDVALID_POS			(GCI_LTE_BEGIN + 56)
893*4882a593Smuzhiyun 
894*4882a593Smuzhiyun /* Reg Index corresponding to ECI bit no x of ECI space */
895*4882a593Smuzhiyun #define GCI_REGIDX(x)				((x)/GCI_REG_WIDTH)
896*4882a593Smuzhiyun /* Bit offset of ECI bit no x in 32-bit words */
897*4882a593Smuzhiyun #define GCI_BITOFFSET(x)			((x)%GCI_REG_WIDTH)
898*4882a593Smuzhiyun 
899*4882a593Smuzhiyun #define GCI_ECI_HW0(ip_id)	(((ip_id) * GCI_EVENT_BITS_PER_CORE) + 0)
900*4882a593Smuzhiyun #define GCI_ECI_HW1(ip_id)	(((ip_id) * GCI_EVENT_BITS_PER_CORE) + 1)
901*4882a593Smuzhiyun #define GCI_ECI_SW0(ip_id)	(((ip_id) * GCI_EVENT_BITS_PER_CORE) + 2)
902*4882a593Smuzhiyun #define GCI_ECI_SW1(ip_id)	(((ip_id) * GCI_EVENT_BITS_PER_CORE) + 3)
903*4882a593Smuzhiyun 
904*4882a593Smuzhiyun /* BT SMEM Control Register 0 */
905*4882a593Smuzhiyun #define GCI_BT_SMEM_CTRL0_SUBCORE_ENABLE_PKILL	(1 << 28)
906*4882a593Smuzhiyun 
907*4882a593Smuzhiyun /* GCI RXFIFO Common control */
908*4882a593Smuzhiyun #define GCI_RXFIFO_CTRL_AUX_EN		0xFF
909*4882a593Smuzhiyun #define GCI_RXFIFO_CTRL_FIFO_EN		0xFF00
910*4882a593Smuzhiyun #define GCI_RXFIFO_CTRL_FIFO_TYPE2_EN	0x400
911*4882a593Smuzhiyun 
912*4882a593Smuzhiyun /* End - GCI Macros */
913*4882a593Smuzhiyun 
914*4882a593Smuzhiyun extern void si_pll_sr_reinit(si_t *sih);
915*4882a593Smuzhiyun extern void si_pll_closeloop(si_t *sih);
916*4882a593Smuzhiyun extern uint si_num_slaveports(const si_t *sih, uint coreid);
917*4882a593Smuzhiyun extern uint32 si_get_slaveport_addr(si_t *sih, uint spidx, uint baidx,
918*4882a593Smuzhiyun 	uint core_id, uint coreunit);
919*4882a593Smuzhiyun extern uint32 si_get_d11_slaveport_addr(si_t *sih, uint spidx,
920*4882a593Smuzhiyun 	uint baidx, uint coreunit);
921*4882a593Smuzhiyun void si_introff(const si_t *sih, bcm_int_bitmask_t *intr_val);
922*4882a593Smuzhiyun void si_intrrestore(const si_t *sih, bcm_int_bitmask_t *intr_val);
923*4882a593Smuzhiyun bool si_get_nvram_rfldo3p3_war(const si_t *sih);
924*4882a593Smuzhiyun void si_nvram_res_masks(const si_t *sih, uint32 *min_mask, uint32 *max_mask);
925*4882a593Smuzhiyun extern uint32 si_xtalfreq(const si_t *sih);
926*4882a593Smuzhiyun extern uint8 si_getspurmode(const si_t *sih);
927*4882a593Smuzhiyun extern uint32 si_get_openloop_dco_code(const si_t *sih);
928*4882a593Smuzhiyun extern void si_set_openloop_dco_code(si_t *sih, uint32 openloop_dco_code);
929*4882a593Smuzhiyun extern uint32 si_wrapper_dump_buf_size(const si_t *sih);
930*4882a593Smuzhiyun extern uint32 si_wrapper_dump_binary(const si_t *sih, uchar *p);
931*4882a593Smuzhiyun extern uint32 si_wrapper_dump_last_timeout(const si_t *sih, uint32 *error, uint32 *core,
932*4882a593Smuzhiyun 	uint32 *ba, uchar *p);
933*4882a593Smuzhiyun 
934*4882a593Smuzhiyun /* SR Power Control */
935*4882a593Smuzhiyun extern uint32 si_srpwr_request(const si_t *sih, uint32 mask, uint32 val);
936*4882a593Smuzhiyun extern uint32 si_srpwr_request_on_rev80(si_t *sih, uint32 mask, uint32 val,
937*4882a593Smuzhiyun 	uint32 ucode_awake);
938*4882a593Smuzhiyun extern uint32 si_srpwr_stat_spinwait(const si_t *sih, uint32 mask, uint32 val);
939*4882a593Smuzhiyun extern uint32 si_srpwr_stat(si_t *sih);
940*4882a593Smuzhiyun extern uint32 si_srpwr_domain(si_t *sih);
941*4882a593Smuzhiyun extern uint32 si_srpwr_domain_all_mask(const si_t *sih);
942*4882a593Smuzhiyun extern uint8 si_srpwr_domain_wl(si_t *sih);
943*4882a593Smuzhiyun extern uint32 si_srpwr_bt_status(si_t *sih);
944*4882a593Smuzhiyun /* SR Power Control */
945*4882a593Smuzhiyun bool si_srpwr_cap(si_t *sih);
946*4882a593Smuzhiyun #define SRPWR_CAP(sih) (si_srpwr_cap(sih))
947*4882a593Smuzhiyun 
948*4882a593Smuzhiyun #ifdef BCMSRPWR
949*4882a593Smuzhiyun 	extern bool _bcmsrpwr;
950*4882a593Smuzhiyun #if defined(ROM_ENAB_RUNTIME_CHECK) || !defined(DONGLEBUILD)
951*4882a593Smuzhiyun 	#define SRPWR_ENAB()    (_bcmsrpwr)
952*4882a593Smuzhiyun #elif defined(BCMSRPWR_DISABLED)
953*4882a593Smuzhiyun 	#define SRPWR_ENAB()    (0)
954*4882a593Smuzhiyun #else
955*4882a593Smuzhiyun 	#define SRPWR_ENAB()    (1)
956*4882a593Smuzhiyun #endif
957*4882a593Smuzhiyun #else
958*4882a593Smuzhiyun 	#define SRPWR_ENAB()            (0)
959*4882a593Smuzhiyun #endif /* BCMSRPWR */
960*4882a593Smuzhiyun 
961*4882a593Smuzhiyun /*
962*4882a593Smuzhiyun  * Multi-BackPlane architecture.  Each can power up/down independently.
963*4882a593Smuzhiyun  *   Common backplane: shared between BT and WL
964*4882a593Smuzhiyun  *      ChipC, PCIe, GCI, PMU, SRs
965*4882a593Smuzhiyun  *      HW powers up as needed
966*4882a593Smuzhiyun  *   WL BackPlane (WLBP):
967*4882a593Smuzhiyun  *      ARM, TCM, Main, Aux
968*4882a593Smuzhiyun  *      Host needs to power up
969*4882a593Smuzhiyun  */
970*4882a593Smuzhiyun #define MULTIBP_CAP(sih)	(BCM4378_CHIP(sih->chip) || \
971*4882a593Smuzhiyun 				BCM4387_CHIP(sih->chip) || BCM4388_CHIP(sih->chip) || \
972*4882a593Smuzhiyun 				BCM4389_CHIP(sih->chip) || BCM4385_CHIP(sih->chip) || \
973*4882a593Smuzhiyun 				BCM4376_CHIP(sih->chip) || BCM4397_CHIP(sih->chip))
974*4882a593Smuzhiyun #define MULTIBP_ENAB(sih)      ((sih) && (sih)->_multibp_enable)
975*4882a593Smuzhiyun 
976*4882a593Smuzhiyun #ifdef DONGLEBUILD
977*4882a593Smuzhiyun extern bool si_check_enable_backplane_log(const si_t *sih);
978*4882a593Smuzhiyun #endif /* DONGLEBUILD */
979*4882a593Smuzhiyun 
980*4882a593Smuzhiyun uint32 si_enum_base(uint devid);
981*4882a593Smuzhiyun 
982*4882a593Smuzhiyun /* Default ARM PLL freq 4369/4368 */
983*4882a593Smuzhiyun #define ARMPLL_FREQ_400MHZ             (400u)
984*4882a593Smuzhiyun #define ARMPLL_FREQ_800MHZ	       (800u)
985*4882a593Smuzhiyun /* ARM PLL freq computed using chip defaults is 1002.8235 Mhz */
986*4882a593Smuzhiyun #define ARMPLL_FREQ_1000MHZ	       (1003u)
987*4882a593Smuzhiyun 
988*4882a593Smuzhiyun extern uint8 si_lhl_ps_mode(const si_t *sih);
989*4882a593Smuzhiyun extern uint32 si_get_armpllclkfreq(const si_t *sih);
990*4882a593Smuzhiyun uint8 si_get_ccidiv(const si_t *sih);
991*4882a593Smuzhiyun extern uint8 si_hib_ext_wakeup_isenab(const si_t *sih);
992*4882a593Smuzhiyun 
993*4882a593Smuzhiyun #ifdef UART_TRAP_DBG
994*4882a593Smuzhiyun void si_dump_APB_Bridge_registers(const si_t *sih);
995*4882a593Smuzhiyun #endif /* UART_TRAP_DBG */
996*4882a593Smuzhiyun void si_force_clocks(const si_t *sih, uint clock_state);
997*4882a593Smuzhiyun 
998*4882a593Smuzhiyun #if defined(BCMSDIODEV_ENABLED) && defined(ATE_BUILD)
999*4882a593Smuzhiyun bool si_chipcap_sdio_ate_only(const si_t *sih);
1000*4882a593Smuzhiyun #endif /* BCMSDIODEV_ENABLED && ATE_BUILD */
1001*4882a593Smuzhiyun 
1002*4882a593Smuzhiyun /* indicates to the siutils how the PICe BAR0 is mappend.
1003*4882a593Smuzhiyun  * here is the current scheme, which are all using BAR0:
1004*4882a593Smuzhiyun  * id     enum       wrapper
1005*4882a593Smuzhiyun  * ====   =========  =========
1006*4882a593Smuzhiyun  *    0   0000-0FFF  1000-1FFF
1007*4882a593Smuzhiyun  *    1   4000-4FFF  5000-5FFF
1008*4882a593Smuzhiyun  *    2   9000-9FFF  A000-AFFF
1009*4882a593Smuzhiyun  * >= 3   not supported
1010*4882a593Smuzhiyun  */
1011*4882a593Smuzhiyun void si_set_slice_id(si_t *sih, uint8 slice);
1012*4882a593Smuzhiyun uint8 si_get_slice_id(const si_t *sih);
1013*4882a593Smuzhiyun 
1014*4882a593Smuzhiyun /* query the d11 core type */
1015*4882a593Smuzhiyun #define D11_CORE_TYPE_NORM	0u
1016*4882a593Smuzhiyun #define D11_CORE_TYPE_SCAN	1u
1017*4882a593Smuzhiyun uint si_core_d11_type(si_t *sih, uint coreunit);
1018*4882a593Smuzhiyun 
1019*4882a593Smuzhiyun /* check if the package option allows the d11 core */
1020*4882a593Smuzhiyun bool si_pkgopt_d11_allowed(si_t *sih, uint coreuint);
1021*4882a593Smuzhiyun 
1022*4882a593Smuzhiyun /* return if scan core is present */
1023*4882a593Smuzhiyun bool si_scan_core_present(const si_t *sih);
1024*4882a593Smuzhiyun void si_configure_pwrthrottle_gpio(si_t *sih, uint8 pwrthrottle_gpio_pin);
1025*4882a593Smuzhiyun void si_configure_onbody_gpio(si_t *sih, uint8 onbody_gpio_pin);
1026*4882a593Smuzhiyun 
1027*4882a593Smuzhiyun /* check if HWA core present */
1028*4882a593Smuzhiyun bool si_hwa_present(const si_t *sih);
1029*4882a593Smuzhiyun 
1030*4882a593Smuzhiyun /* check if SYSMEM present */
1031*4882a593Smuzhiyun bool si_sysmem_present(const si_t *sih);
1032*4882a593Smuzhiyun 
1033*4882a593Smuzhiyun /* return BT state */
1034*4882a593Smuzhiyun bool si_btc_bt_status_in_reset(si_t *sih);
1035*4882a593Smuzhiyun bool si_btc_bt_status_in_pds(si_t *sih);
1036*4882a593Smuzhiyun int si_btc_bt_pds_wakeup_force(si_t *sih, bool force);
1037*4882a593Smuzhiyun 
1038*4882a593Smuzhiyun /* RFFE RFEM Functions */
1039*4882a593Smuzhiyun #ifndef BCMDONGLEHOST
1040*4882a593Smuzhiyun void si_rffe_rfem_init(si_t *sih);
1041*4882a593Smuzhiyun void si_rffe_set_debug_mode(si_t *sih, bool enable);
1042*4882a593Smuzhiyun bool si_rffe_get_debug_mode(si_t *sih);
1043*4882a593Smuzhiyun int si_rffe_set_elnabyp_mode(si_t *sih, uint8 mode);
1044*4882a593Smuzhiyun int8 si_rffe_get_elnabyp_mode(si_t *sih);
1045*4882a593Smuzhiyun int si_rffe_rfem_read(si_t *sih, uint8 dev_id, uint8 antenna, uint16 reg_addr, uint32 *val);
1046*4882a593Smuzhiyun int si_rffe_rfem_write(si_t *sih, uint8 dev_id, uint8 antenna, uint16 reg_addr, uint32 data);
1047*4882a593Smuzhiyun #endif /* !BCMDONGLEHOST */
1048*4882a593Smuzhiyun extern void si_jtag_udr_pwrsw_main_toggle(si_t *sih, bool on);
1049*4882a593Smuzhiyun extern int si_pmu_res_state_pwrsw_main_wait(si_t *sih);
1050*4882a593Smuzhiyun extern uint32 si_d11_core_sssr_addr(si_t *sih, uint unit, uint32 *sssr_dmp_sz);
1051*4882a593Smuzhiyun 
1052*4882a593Smuzhiyun #ifdef USE_LHL_TIMER
1053*4882a593Smuzhiyun /* Get current HIB time API */
1054*4882a593Smuzhiyun uint32 si_cur_hib_time(si_t *sih);
1055*4882a593Smuzhiyun #endif
1056*4882a593Smuzhiyun 
1057*4882a593Smuzhiyun #endif	/* _siutils_h_ */
1058