xref: /freebsd/sys/contrib/dev/broadcom/brcm80211/include/chipcommon.h (revision b4c3e9b5b09c829b4135aff738bd2893ed052377)
1*b4c3e9b5SBjoern A. Zeeb // SPDX-License-Identifier: ISC
2*b4c3e9b5SBjoern A. Zeeb /*
3*b4c3e9b5SBjoern A. Zeeb  * Copyright (c) 2010 Broadcom Corporation
4*b4c3e9b5SBjoern A. Zeeb  */
5*b4c3e9b5SBjoern A. Zeeb 
6*b4c3e9b5SBjoern A. Zeeb #ifndef	_SBCHIPC_H
7*b4c3e9b5SBjoern A. Zeeb #define	_SBCHIPC_H
8*b4c3e9b5SBjoern A. Zeeb 
9*b4c3e9b5SBjoern A. Zeeb #include "defs.h"		/* for PAD macro */
10*b4c3e9b5SBjoern A. Zeeb 
11*b4c3e9b5SBjoern A. Zeeb #define CHIPCREGOFFS(field)	offsetof(struct chipcregs, field)
12*b4c3e9b5SBjoern A. Zeeb 
13*b4c3e9b5SBjoern A. Zeeb struct chipcregs {
14*b4c3e9b5SBjoern A. Zeeb 	u32 chipid;		/* 0x0 */
15*b4c3e9b5SBjoern A. Zeeb 	u32 capabilities;
16*b4c3e9b5SBjoern A. Zeeb 	u32 corecontrol;	/* corerev >= 1 */
17*b4c3e9b5SBjoern A. Zeeb 	u32 bist;
18*b4c3e9b5SBjoern A. Zeeb 
19*b4c3e9b5SBjoern A. Zeeb 	/* OTP */
20*b4c3e9b5SBjoern A. Zeeb 	u32 otpstatus;	/* 0x10, corerev >= 10 */
21*b4c3e9b5SBjoern A. Zeeb 	u32 otpcontrol;
22*b4c3e9b5SBjoern A. Zeeb 	u32 otpprog;
23*b4c3e9b5SBjoern A. Zeeb 	u32 otplayout;	/* corerev >= 23 */
24*b4c3e9b5SBjoern A. Zeeb 
25*b4c3e9b5SBjoern A. Zeeb 	/* Interrupt control */
26*b4c3e9b5SBjoern A. Zeeb 	u32 intstatus;	/* 0x20 */
27*b4c3e9b5SBjoern A. Zeeb 	u32 intmask;
28*b4c3e9b5SBjoern A. Zeeb 
29*b4c3e9b5SBjoern A. Zeeb 	/* Chip specific regs */
30*b4c3e9b5SBjoern A. Zeeb 	u32 chipcontrol;	/* 0x28, rev >= 11 */
31*b4c3e9b5SBjoern A. Zeeb 	u32 chipstatus;	/* 0x2c, rev >= 11 */
32*b4c3e9b5SBjoern A. Zeeb 
33*b4c3e9b5SBjoern A. Zeeb 	/* Jtag Master */
34*b4c3e9b5SBjoern A. Zeeb 	u32 jtagcmd;		/* 0x30, rev >= 10 */
35*b4c3e9b5SBjoern A. Zeeb 	u32 jtagir;
36*b4c3e9b5SBjoern A. Zeeb 	u32 jtagdr;
37*b4c3e9b5SBjoern A. Zeeb 	u32 jtagctrl;
38*b4c3e9b5SBjoern A. Zeeb 
39*b4c3e9b5SBjoern A. Zeeb 	/* serial flash interface registers */
40*b4c3e9b5SBjoern A. Zeeb 	u32 flashcontrol;	/* 0x40 */
41*b4c3e9b5SBjoern A. Zeeb 	u32 flashaddress;
42*b4c3e9b5SBjoern A. Zeeb 	u32 flashdata;
43*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[1];
44*b4c3e9b5SBjoern A. Zeeb 
45*b4c3e9b5SBjoern A. Zeeb 	/* Silicon backplane configuration broadcast control */
46*b4c3e9b5SBjoern A. Zeeb 	u32 broadcastaddress;	/* 0x50 */
47*b4c3e9b5SBjoern A. Zeeb 	u32 broadcastdata;
48*b4c3e9b5SBjoern A. Zeeb 
49*b4c3e9b5SBjoern A. Zeeb 	/* gpio - cleared only by power-on-reset */
50*b4c3e9b5SBjoern A. Zeeb 	u32 gpiopullup;	/* 0x58, corerev >= 20 */
51*b4c3e9b5SBjoern A. Zeeb 	u32 gpiopulldown;	/* 0x5c, corerev >= 20 */
52*b4c3e9b5SBjoern A. Zeeb 	u32 gpioin;		/* 0x60 */
53*b4c3e9b5SBjoern A. Zeeb 	u32 gpioout;		/* 0x64 */
54*b4c3e9b5SBjoern A. Zeeb 	u32 gpioouten;	/* 0x68 */
55*b4c3e9b5SBjoern A. Zeeb 	u32 gpiocontrol;	/* 0x6C */
56*b4c3e9b5SBjoern A. Zeeb 	u32 gpiointpolarity;	/* 0x70 */
57*b4c3e9b5SBjoern A. Zeeb 	u32 gpiointmask;	/* 0x74 */
58*b4c3e9b5SBjoern A. Zeeb 
59*b4c3e9b5SBjoern A. Zeeb 	/* GPIO events corerev >= 11 */
60*b4c3e9b5SBjoern A. Zeeb 	u32 gpioevent;
61*b4c3e9b5SBjoern A. Zeeb 	u32 gpioeventintmask;
62*b4c3e9b5SBjoern A. Zeeb 
63*b4c3e9b5SBjoern A. Zeeb 	/* Watchdog timer */
64*b4c3e9b5SBjoern A. Zeeb 	u32 watchdog;	/* 0x80 */
65*b4c3e9b5SBjoern A. Zeeb 
66*b4c3e9b5SBjoern A. Zeeb 	/* GPIO events corerev >= 11 */
67*b4c3e9b5SBjoern A. Zeeb 	u32 gpioeventintpolarity;
68*b4c3e9b5SBjoern A. Zeeb 
69*b4c3e9b5SBjoern A. Zeeb 	/* GPIO based LED powersave registers corerev >= 16 */
70*b4c3e9b5SBjoern A. Zeeb 	u32 gpiotimerval;	/* 0x88 */
71*b4c3e9b5SBjoern A. Zeeb 	u32 gpiotimeroutmask;
72*b4c3e9b5SBjoern A. Zeeb 
73*b4c3e9b5SBjoern A. Zeeb 	/* clock control */
74*b4c3e9b5SBjoern A. Zeeb 	u32 clockcontrol_n;	/* 0x90 */
75*b4c3e9b5SBjoern A. Zeeb 	u32 clockcontrol_sb;	/* aka m0 */
76*b4c3e9b5SBjoern A. Zeeb 	u32 clockcontrol_pci;	/* aka m1 */
77*b4c3e9b5SBjoern A. Zeeb 	u32 clockcontrol_m2;	/* mii/uart/mipsref */
78*b4c3e9b5SBjoern A. Zeeb 	u32 clockcontrol_m3;	/* cpu */
79*b4c3e9b5SBjoern A. Zeeb 	u32 clkdiv;		/* corerev >= 3 */
80*b4c3e9b5SBjoern A. Zeeb 	u32 gpiodebugsel;	/* corerev >= 28 */
81*b4c3e9b5SBjoern A. Zeeb 	u32 capabilities_ext;	/* 0xac  */
82*b4c3e9b5SBjoern A. Zeeb 
83*b4c3e9b5SBjoern A. Zeeb 	/* pll delay registers (corerev >= 4) */
84*b4c3e9b5SBjoern A. Zeeb 	u32 pll_on_delay;	/* 0xb0 */
85*b4c3e9b5SBjoern A. Zeeb 	u32 fref_sel_delay;
86*b4c3e9b5SBjoern A. Zeeb 	u32 slow_clk_ctl;	/* 5 < corerev < 10 */
87*b4c3e9b5SBjoern A. Zeeb 	u32 PAD;
88*b4c3e9b5SBjoern A. Zeeb 
89*b4c3e9b5SBjoern A. Zeeb 	/* Instaclock registers (corerev >= 10) */
90*b4c3e9b5SBjoern A. Zeeb 	u32 system_clk_ctl;	/* 0xc0 */
91*b4c3e9b5SBjoern A. Zeeb 	u32 clkstatestretch;
92*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[2];
93*b4c3e9b5SBjoern A. Zeeb 
94*b4c3e9b5SBjoern A. Zeeb 	/* Indirect backplane access (corerev >= 22) */
95*b4c3e9b5SBjoern A. Zeeb 	u32 bp_addrlow;	/* 0xd0 */
96*b4c3e9b5SBjoern A. Zeeb 	u32 bp_addrhigh;
97*b4c3e9b5SBjoern A. Zeeb 	u32 bp_data;
98*b4c3e9b5SBjoern A. Zeeb 	u32 PAD;
99*b4c3e9b5SBjoern A. Zeeb 	u32 bp_indaccess;
100*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[3];
101*b4c3e9b5SBjoern A. Zeeb 
102*b4c3e9b5SBjoern A. Zeeb 	/* More clock dividers (corerev >= 32) */
103*b4c3e9b5SBjoern A. Zeeb 	u32 clkdiv2;
104*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[2];
105*b4c3e9b5SBjoern A. Zeeb 
106*b4c3e9b5SBjoern A. Zeeb 	/* In AI chips, pointer to erom */
107*b4c3e9b5SBjoern A. Zeeb 	u32 eromptr;		/* 0xfc */
108*b4c3e9b5SBjoern A. Zeeb 
109*b4c3e9b5SBjoern A. Zeeb 	/* ExtBus control registers (corerev >= 3) */
110*b4c3e9b5SBjoern A. Zeeb 	u32 pcmcia_config;	/* 0x100 */
111*b4c3e9b5SBjoern A. Zeeb 	u32 pcmcia_memwait;
112*b4c3e9b5SBjoern A. Zeeb 	u32 pcmcia_attrwait;
113*b4c3e9b5SBjoern A. Zeeb 	u32 pcmcia_iowait;
114*b4c3e9b5SBjoern A. Zeeb 	u32 ide_config;
115*b4c3e9b5SBjoern A. Zeeb 	u32 ide_memwait;
116*b4c3e9b5SBjoern A. Zeeb 	u32 ide_attrwait;
117*b4c3e9b5SBjoern A. Zeeb 	u32 ide_iowait;
118*b4c3e9b5SBjoern A. Zeeb 	u32 prog_config;
119*b4c3e9b5SBjoern A. Zeeb 	u32 prog_waitcount;
120*b4c3e9b5SBjoern A. Zeeb 	u32 flash_config;
121*b4c3e9b5SBjoern A. Zeeb 	u32 flash_waitcount;
122*b4c3e9b5SBjoern A. Zeeb 	u32 SECI_config;	/* 0x130 SECI configuration */
123*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[3];
124*b4c3e9b5SBjoern A. Zeeb 
125*b4c3e9b5SBjoern A. Zeeb 	/* Enhanced Coexistence Interface (ECI) registers (corerev >= 21) */
126*b4c3e9b5SBjoern A. Zeeb 	u32 eci_output;	/* 0x140 */
127*b4c3e9b5SBjoern A. Zeeb 	u32 eci_control;
128*b4c3e9b5SBjoern A. Zeeb 	u32 eci_inputlo;
129*b4c3e9b5SBjoern A. Zeeb 	u32 eci_inputmi;
130*b4c3e9b5SBjoern A. Zeeb 	u32 eci_inputhi;
131*b4c3e9b5SBjoern A. Zeeb 	u32 eci_inputintpolaritylo;
132*b4c3e9b5SBjoern A. Zeeb 	u32 eci_inputintpolaritymi;
133*b4c3e9b5SBjoern A. Zeeb 	u32 eci_inputintpolarityhi;
134*b4c3e9b5SBjoern A. Zeeb 	u32 eci_intmasklo;
135*b4c3e9b5SBjoern A. Zeeb 	u32 eci_intmaskmi;
136*b4c3e9b5SBjoern A. Zeeb 	u32 eci_intmaskhi;
137*b4c3e9b5SBjoern A. Zeeb 	u32 eci_eventlo;
138*b4c3e9b5SBjoern A. Zeeb 	u32 eci_eventmi;
139*b4c3e9b5SBjoern A. Zeeb 	u32 eci_eventhi;
140*b4c3e9b5SBjoern A. Zeeb 	u32 eci_eventmasklo;
141*b4c3e9b5SBjoern A. Zeeb 	u32 eci_eventmaskmi;
142*b4c3e9b5SBjoern A. Zeeb 	u32 eci_eventmaskhi;
143*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[3];
144*b4c3e9b5SBjoern A. Zeeb 
145*b4c3e9b5SBjoern A. Zeeb 	/* SROM interface (corerev >= 32) */
146*b4c3e9b5SBjoern A. Zeeb 	u32 sromcontrol;	/* 0x190 */
147*b4c3e9b5SBjoern A. Zeeb 	u32 sromaddress;
148*b4c3e9b5SBjoern A. Zeeb 	u32 sromdata;
149*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[17];
150*b4c3e9b5SBjoern A. Zeeb 
151*b4c3e9b5SBjoern A. Zeeb 	/* Clock control and hardware workarounds (corerev >= 20) */
152*b4c3e9b5SBjoern A. Zeeb 	u32 clk_ctl_st;	/* 0x1e0 */
153*b4c3e9b5SBjoern A. Zeeb 	u32 hw_war;
154*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[70];
155*b4c3e9b5SBjoern A. Zeeb 
156*b4c3e9b5SBjoern A. Zeeb 	/* UARTs */
157*b4c3e9b5SBjoern A. Zeeb 	u8 uart0data;	/* 0x300 */
158*b4c3e9b5SBjoern A. Zeeb 	u8 uart0imr;
159*b4c3e9b5SBjoern A. Zeeb 	u8 uart0fcr;
160*b4c3e9b5SBjoern A. Zeeb 	u8 uart0lcr;
161*b4c3e9b5SBjoern A. Zeeb 	u8 uart0mcr;
162*b4c3e9b5SBjoern A. Zeeb 	u8 uart0lsr;
163*b4c3e9b5SBjoern A. Zeeb 	u8 uart0msr;
164*b4c3e9b5SBjoern A. Zeeb 	u8 uart0scratch;
165*b4c3e9b5SBjoern A. Zeeb 	u8 PAD[248];		/* corerev >= 1 */
166*b4c3e9b5SBjoern A. Zeeb 
167*b4c3e9b5SBjoern A. Zeeb 	u8 uart1data;	/* 0x400 */
168*b4c3e9b5SBjoern A. Zeeb 	u8 uart1imr;
169*b4c3e9b5SBjoern A. Zeeb 	u8 uart1fcr;
170*b4c3e9b5SBjoern A. Zeeb 	u8 uart1lcr;
171*b4c3e9b5SBjoern A. Zeeb 	u8 uart1mcr;
172*b4c3e9b5SBjoern A. Zeeb 	u8 uart1lsr;
173*b4c3e9b5SBjoern A. Zeeb 	u8 uart1msr;
174*b4c3e9b5SBjoern A. Zeeb 	u8 uart1scratch;
175*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[62];
176*b4c3e9b5SBjoern A. Zeeb 
177*b4c3e9b5SBjoern A. Zeeb 	/* save/restore, corerev >= 48 */
178*b4c3e9b5SBjoern A. Zeeb 	u32 sr_capability;          /* 0x500 */
179*b4c3e9b5SBjoern A. Zeeb 	u32 sr_control0;            /* 0x504 */
180*b4c3e9b5SBjoern A. Zeeb 	u32 sr_control1;            /* 0x508 */
181*b4c3e9b5SBjoern A. Zeeb 	u32 gpio_control;           /* 0x50C */
182*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[60];
183*b4c3e9b5SBjoern A. Zeeb 
184*b4c3e9b5SBjoern A. Zeeb 	/* PMU registers (corerev >= 20) */
185*b4c3e9b5SBjoern A. Zeeb 	u32 pmucontrol;	/* 0x600 */
186*b4c3e9b5SBjoern A. Zeeb 	u32 pmucapabilities;
187*b4c3e9b5SBjoern A. Zeeb 	u32 pmustatus;
188*b4c3e9b5SBjoern A. Zeeb 	u32 res_state;
189*b4c3e9b5SBjoern A. Zeeb 	u32 res_pending;
190*b4c3e9b5SBjoern A. Zeeb 	u32 pmutimer;
191*b4c3e9b5SBjoern A. Zeeb 	u32 min_res_mask;
192*b4c3e9b5SBjoern A. Zeeb 	u32 max_res_mask;
193*b4c3e9b5SBjoern A. Zeeb 	u32 res_table_sel;
194*b4c3e9b5SBjoern A. Zeeb 	u32 res_dep_mask;
195*b4c3e9b5SBjoern A. Zeeb 	u32 res_updn_timer;
196*b4c3e9b5SBjoern A. Zeeb 	u32 res_timer;
197*b4c3e9b5SBjoern A. Zeeb 	u32 clkstretch;
198*b4c3e9b5SBjoern A. Zeeb 	u32 pmuwatchdog;
199*b4c3e9b5SBjoern A. Zeeb 	u32 gpiosel;		/* 0x638, rev >= 1 */
200*b4c3e9b5SBjoern A. Zeeb 	u32 gpioenable;	/* 0x63c, rev >= 1 */
201*b4c3e9b5SBjoern A. Zeeb 	u32 res_req_timer_sel;
202*b4c3e9b5SBjoern A. Zeeb 	u32 res_req_timer;
203*b4c3e9b5SBjoern A. Zeeb 	u32 res_req_mask;
204*b4c3e9b5SBjoern A. Zeeb 	u32 pmucapabilities_ext; /* 0x64c, pmurev >=15 */
205*b4c3e9b5SBjoern A. Zeeb 	u32 chipcontrol_addr;	/* 0x650 */
206*b4c3e9b5SBjoern A. Zeeb 	u32 chipcontrol_data;	/* 0x654 */
207*b4c3e9b5SBjoern A. Zeeb 	u32 regcontrol_addr;
208*b4c3e9b5SBjoern A. Zeeb 	u32 regcontrol_data;
209*b4c3e9b5SBjoern A. Zeeb 	u32 pllcontrol_addr;
210*b4c3e9b5SBjoern A. Zeeb 	u32 pllcontrol_data;
211*b4c3e9b5SBjoern A. Zeeb 	u32 pmustrapopt;	/* 0x668, corerev >= 28 */
212*b4c3e9b5SBjoern A. Zeeb 	u32 pmu_xtalfreq;	/* 0x66C, pmurev >= 10 */
213*b4c3e9b5SBjoern A. Zeeb 	u32 retention_ctl;          /* 0x670, pmurev >= 15 */
214*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[3];
215*b4c3e9b5SBjoern A. Zeeb 	u32 retention_grpidx;       /* 0x680 */
216*b4c3e9b5SBjoern A. Zeeb 	u32 retention_grpctl;       /* 0x684 */
217*b4c3e9b5SBjoern A. Zeeb 	u32 PAD[94];
218*b4c3e9b5SBjoern A. Zeeb 	u16 sromotp[768];
219*b4c3e9b5SBjoern A. Zeeb };
220*b4c3e9b5SBjoern A. Zeeb 
221*b4c3e9b5SBjoern A. Zeeb /* chipid */
222*b4c3e9b5SBjoern A. Zeeb #define	CID_ID_MASK		0x0000ffff	/* Chip Id mask */
223*b4c3e9b5SBjoern A. Zeeb #define	CID_REV_MASK		0x000f0000	/* Chip Revision mask */
224*b4c3e9b5SBjoern A. Zeeb #define	CID_REV_SHIFT		16	/* Chip Revision shift */
225*b4c3e9b5SBjoern A. Zeeb #define	CID_PKG_MASK		0x00f00000	/* Package Option mask */
226*b4c3e9b5SBjoern A. Zeeb #define	CID_PKG_SHIFT		20	/* Package Option shift */
227*b4c3e9b5SBjoern A. Zeeb #define	CID_CC_MASK		0x0f000000	/* CoreCount (corerev >= 4) */
228*b4c3e9b5SBjoern A. Zeeb #define CID_CC_SHIFT		24
229*b4c3e9b5SBjoern A. Zeeb #define	CID_TYPE_MASK		0xf0000000	/* Chip Type */
230*b4c3e9b5SBjoern A. Zeeb #define CID_TYPE_SHIFT		28
231*b4c3e9b5SBjoern A. Zeeb 
232*b4c3e9b5SBjoern A. Zeeb /* capabilities */
233*b4c3e9b5SBjoern A. Zeeb #define	CC_CAP_UARTS_MASK	0x00000003	/* Number of UARTs */
234*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_MIPSEB		0x00000004	/* MIPS is in big-endian mode */
235*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_UCLKSEL		0x00000018	/* UARTs clock select */
236*b4c3e9b5SBjoern A. Zeeb /* UARTs are driven by internal divided clock */
237*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_UINTCLK		0x00000008
238*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_UARTGPIO		0x00000020	/* UARTs own GPIOs 15:12 */
239*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_EXTBUS_MASK	0x000000c0	/* External bus mask */
240*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_EXTBUS_NONE	0x00000000	/* No ExtBus present */
241*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_EXTBUS_FULL	0x00000040	/* ExtBus: PCMCIA, IDE & Prog */
242*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_EXTBUS_PROG	0x00000080	/* ExtBus: ProgIf only */
243*b4c3e9b5SBjoern A. Zeeb #define	CC_CAP_FLASH_MASK	0x00000700	/* Type of flash */
244*b4c3e9b5SBjoern A. Zeeb #define	CC_CAP_PLL_MASK		0x00038000	/* Type of PLL */
245*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_PWR_CTL		0x00040000	/* Power control */
246*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_OTPSIZE		0x00380000	/* OTP Size (0 = none) */
247*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_OTPSIZE_SHIFT	19	/* OTP Size shift */
248*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_OTPSIZE_BASE	5	/* OTP Size base */
249*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_JTAGP		0x00400000	/* JTAG Master Present */
250*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_ROM		0x00800000	/* Internal boot rom active */
251*b4c3e9b5SBjoern A. Zeeb #define CC_CAP_BKPLN64		0x08000000	/* 64-bit backplane */
252*b4c3e9b5SBjoern A. Zeeb #define	CC_CAP_PMU		0x10000000	/* PMU Present, rev >= 20 */
253*b4c3e9b5SBjoern A. Zeeb #define	CC_CAP_SROM		0x40000000	/* Srom Present, rev >= 32 */
254*b4c3e9b5SBjoern A. Zeeb /* Nand flash present, rev >= 35 */
255*b4c3e9b5SBjoern A. Zeeb #define	CC_CAP_NFLASH		0x80000000
256*b4c3e9b5SBjoern A. Zeeb 
257*b4c3e9b5SBjoern A. Zeeb #define	CC_CAP2_SECI		0x00000001	/* SECI Present, rev >= 36 */
258*b4c3e9b5SBjoern A. Zeeb /* GSIO (spi/i2c) present, rev >= 37 */
259*b4c3e9b5SBjoern A. Zeeb #define	CC_CAP2_GSIO		0x00000002
260*b4c3e9b5SBjoern A. Zeeb 
261*b4c3e9b5SBjoern A. Zeeb /* sr_control0, rev >= 48 */
262*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_ENABLE_MASK			BIT(0)
263*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_ENABLE_SHIFT		0
264*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_EN_SR_ENG_CLK_SHIFT	1 /* sr_clk to sr_memory enable */
265*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_RSRC_TRIGGER_SHIFT	2 /* Rising edge resource trigger 0 to
266*b4c3e9b5SBjoern A. Zeeb 					   * sr_engine
267*b4c3e9b5SBjoern A. Zeeb 					   */
268*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_MIN_DIV_SHIFT	6 /* Min division value for fast clk
269*b4c3e9b5SBjoern A. Zeeb 					   * in sr_engine
270*b4c3e9b5SBjoern A. Zeeb 					   */
271*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_EN_SBC_STBY_SHIFT		16
272*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_EN_SR_ALP_CLK_MASK_SHIFT	18
273*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_EN_SR_HT_CLK_SHIFT		19
274*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_ALLOW_PIC_SHIFT	20 /* Allow pic to separate power
275*b4c3e9b5SBjoern A. Zeeb 					    * domains
276*b4c3e9b5SBjoern A. Zeeb 					    */
277*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_MAX_SR_LQ_CLK_CNT_SHIFT	25
278*b4c3e9b5SBjoern A. Zeeb #define CC_SR_CTL0_EN_MEM_DISABLE_FOR_SLEEP	30
279*b4c3e9b5SBjoern A. Zeeb 
280*b4c3e9b5SBjoern A. Zeeb /* pmucapabilities */
281*b4c3e9b5SBjoern A. Zeeb #define PCAP_REV_MASK	0x000000ff
282*b4c3e9b5SBjoern A. Zeeb #define PCAP_RC_MASK	0x00001f00
283*b4c3e9b5SBjoern A. Zeeb #define PCAP_RC_SHIFT	8
284*b4c3e9b5SBjoern A. Zeeb #define PCAP_TC_MASK	0x0001e000
285*b4c3e9b5SBjoern A. Zeeb #define PCAP_TC_SHIFT	13
286*b4c3e9b5SBjoern A. Zeeb #define PCAP_PC_MASK	0x001e0000
287*b4c3e9b5SBjoern A. Zeeb #define PCAP_PC_SHIFT	17
288*b4c3e9b5SBjoern A. Zeeb #define PCAP_VC_MASK	0x01e00000
289*b4c3e9b5SBjoern A. Zeeb #define PCAP_VC_SHIFT	21
290*b4c3e9b5SBjoern A. Zeeb #define PCAP_CC_MASK	0x1e000000
291*b4c3e9b5SBjoern A. Zeeb #define PCAP_CC_SHIFT	25
292*b4c3e9b5SBjoern A. Zeeb #define PCAP5_PC_MASK	0x003e0000	/* PMU corerev >= 5 */
293*b4c3e9b5SBjoern A. Zeeb #define PCAP5_PC_SHIFT	17
294*b4c3e9b5SBjoern A. Zeeb #define PCAP5_VC_MASK	0x07c00000
295*b4c3e9b5SBjoern A. Zeeb #define PCAP5_VC_SHIFT	22
296*b4c3e9b5SBjoern A. Zeeb #define PCAP5_CC_MASK	0xf8000000
297*b4c3e9b5SBjoern A. Zeeb #define PCAP5_CC_SHIFT	27
298*b4c3e9b5SBjoern A. Zeeb /* pmucapabilites_ext PMU rev >= 15 */
299*b4c3e9b5SBjoern A. Zeeb #define PCAPEXT_SR_SUPPORTED_MASK	(1 << 1)
300*b4c3e9b5SBjoern A. Zeeb /* retention_ctl PMU rev >= 15 */
301*b4c3e9b5SBjoern A. Zeeb #define PMU_RCTL_MACPHY_DISABLE_MASK        (1 << 26)
302*b4c3e9b5SBjoern A. Zeeb #define PMU_RCTL_LOGIC_DISABLE_MASK         (1 << 27)
303*b4c3e9b5SBjoern A. Zeeb 
304*b4c3e9b5SBjoern A. Zeeb 
305*b4c3e9b5SBjoern A. Zeeb /*
306*b4c3e9b5SBjoern A. Zeeb * Maximum delay for the PMU state transition in us.
307*b4c3e9b5SBjoern A. Zeeb * This is an upper bound intended for spinwaits etc.
308*b4c3e9b5SBjoern A. Zeeb */
309*b4c3e9b5SBjoern A. Zeeb #define PMU_MAX_TRANSITION_DLY	15000
310*b4c3e9b5SBjoern A. Zeeb 
311*b4c3e9b5SBjoern A. Zeeb #endif				/* _SBCHIPC_H */
312