xref: /OK3568_Linux_fs/external/rkwifibt/drivers/bcmdhd/include/bcmdevs.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Broadcom device-specific manifest constants.
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Copyright (C) 2020, Broadcom.
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  *      Unless you and Broadcom execute a separate written software license
7*4882a593Smuzhiyun  * agreement governing use of this software, this software is licensed to you
8*4882a593Smuzhiyun  * under the terms of the GNU General Public License version 2 (the "GPL"),
9*4882a593Smuzhiyun  * available at http://www.broadcom.com/licenses/GPLv2.php, with the
10*4882a593Smuzhiyun  * following added to such license:
11*4882a593Smuzhiyun  *
12*4882a593Smuzhiyun  *      As a special exception, the copyright holders of this software give you
13*4882a593Smuzhiyun  * permission to link this software with independent modules, and to copy and
14*4882a593Smuzhiyun  * distribute the resulting executable under terms of your choice, provided that
15*4882a593Smuzhiyun  * you also meet, for each linked independent module, the terms and conditions of
16*4882a593Smuzhiyun  * the license of that module.  An independent module is a module which is not
17*4882a593Smuzhiyun  * derived from this software.  The special exception does not apply to any
18*4882a593Smuzhiyun  * modifications of the software.
19*4882a593Smuzhiyun  *
20*4882a593Smuzhiyun  *
21*4882a593Smuzhiyun  * <<Broadcom-WL-IPTag/Dual:>>
22*4882a593Smuzhiyun  */
23*4882a593Smuzhiyun 
24*4882a593Smuzhiyun #ifndef	_BCMDEVS_H
25*4882a593Smuzhiyun #define	_BCMDEVS_H
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun /* PCI vendor IDs */
28*4882a593Smuzhiyun #define	VENDOR_EPIGRAM		0xfeda
29*4882a593Smuzhiyun #define	VENDOR_BROADCOM		0x14e4
30*4882a593Smuzhiyun #define	VENDOR_3COM		0x10b7
31*4882a593Smuzhiyun #define	VENDOR_NETGEAR		0x1385
32*4882a593Smuzhiyun #define	VENDOR_DIAMOND		0x1092
33*4882a593Smuzhiyun #define	VENDOR_INTEL		0x8086
34*4882a593Smuzhiyun #define	VENDOR_DELL		0x1028
35*4882a593Smuzhiyun #define	VENDOR_HP		0x103c
36*4882a593Smuzhiyun #define	VENDOR_HP_COMPAQ	0x0e11
37*4882a593Smuzhiyun #define	VENDOR_APPLE		0x106b
38*4882a593Smuzhiyun #define VENDOR_SI_IMAGE		0x1095		/* Silicon Image, used by Arasan SDIO Host */
39*4882a593Smuzhiyun #define VENDOR_BUFFALO		0x1154		/* Buffalo vendor id */
40*4882a593Smuzhiyun #define VENDOR_TI		0x104c		/* Texas Instruments */
41*4882a593Smuzhiyun #define VENDOR_RICOH		0x1180		/* Ricoh */
42*4882a593Smuzhiyun #define VENDOR_JMICRON		0x197b
43*4882a593Smuzhiyun 
44*4882a593Smuzhiyun /* precommit failed when this is removed */
45*4882a593Smuzhiyun /* BLAZAR_BRANCH_101_10_DHD_001/build/dhd/linux-fc19/brix-brcm */
46*4882a593Smuzhiyun /* TBD: Revisit later */
47*4882a593Smuzhiyun #ifdef BCMINTERNAL
48*4882a593Smuzhiyun #define VENDOR_JINVANI		0x1947		/* Jinvani Systech, Inc. */
49*4882a593Smuzhiyun #endif
50*4882a593Smuzhiyun 
51*4882a593Smuzhiyun /* PCMCIA vendor IDs */
52*4882a593Smuzhiyun #define	VENDOR_BROADCOM_PCMCIA	0x02d0
53*4882a593Smuzhiyun 
54*4882a593Smuzhiyun /* SDIO vendor IDs */
55*4882a593Smuzhiyun #define	VENDOR_BROADCOM_SDIO	0x00BF
56*4882a593Smuzhiyun 
57*4882a593Smuzhiyun /* DONGLE VID/PIDs */
58*4882a593Smuzhiyun #define BCM_DNGL_VID		0x0a5c
59*4882a593Smuzhiyun #define BCM_DNGL_BL_PID_4328	0xbd12
60*4882a593Smuzhiyun #define BCM_DNGL_BL_PID_4332	0xbd18
61*4882a593Smuzhiyun #define BCM_DNGL_BL_PID_4360	0xbd1d
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun #define BCM_DNGL_BDC_PID	0x0bdc
64*4882a593Smuzhiyun #define BCM_DNGL_JTAG_PID	0x4a44
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun /* Pseudo IDs */
67*4882a593Smuzhiyun #define FPGA_JTAGM_ID		0x43f0		/* FPGA jtagm device id */
68*4882a593Smuzhiyun #define BCM_JTAGM_ID		0x43f1		/* BCM jtagm device id */
69*4882a593Smuzhiyun #define SDIOH_FPGA_ID		0x43f2		/* sdio host fpga */
70*4882a593Smuzhiyun #define BCM_SDIOH_ID		0x43f3		/* BCM sdio host id */
71*4882a593Smuzhiyun #define SDIOD_FPGA_ID		0x43f4		/* sdio device fpga */
72*4882a593Smuzhiyun #define SPIH_FPGA_ID		0x43f5		/* PCI SPI Host Controller FPGA */
73*4882a593Smuzhiyun #define BCM_SPIH_ID		0x43f6		/* Synopsis SPI Host Controller */
74*4882a593Smuzhiyun #define MIMO_FPGA_ID		0x43f8		/* FPGA mimo minimacphy device id */
75*4882a593Smuzhiyun #define BCM_JTAGM2_ID		0x43f9		/* BCM alternate jtagm device id */
76*4882a593Smuzhiyun #define SDHCI_FPGA_ID		0x43fa		/* Standard SDIO Host Controller FPGA */
77*4882a593Smuzhiyun #define	BCM4710_DEVICE_ID	0x4710		/* 4710 primary function 0 */
78*4882a593Smuzhiyun #define	BCM47XX_AUDIO_ID	0x4711		/* 47xx audio codec */
79*4882a593Smuzhiyun #define	BCM47XX_V90_ID		0x4712		/* 47xx v90 codec */
80*4882a593Smuzhiyun #define	BCM47XX_ENET_ID		0x4713		/* 47xx enet */
81*4882a593Smuzhiyun #define	BCM47XX_EXT_ID		0x4714		/* 47xx external i/f */
82*4882a593Smuzhiyun #define	BCM47XX_GMAC_ID		0x4715		/* 47xx Unimac based GbE */
83*4882a593Smuzhiyun #define	BCM47XX_USBH_ID		0x4716		/* 47xx usb host */
84*4882a593Smuzhiyun #define	BCM47XX_USBD_ID		0x4717		/* 47xx usb device */
85*4882a593Smuzhiyun #define	BCM47XX_IPSEC_ID	0x4718		/* 47xx ipsec */
86*4882a593Smuzhiyun #define	BCM47XX_ROBO_ID		0x4719		/* 47xx/53xx roboswitch core */
87*4882a593Smuzhiyun #define	BCM47XX_USB20H_ID	0x471a		/* 47xx usb 2.0 host */
88*4882a593Smuzhiyun #define	BCM47XX_USB20D_ID	0x471b		/* 47xx usb 2.0 device */
89*4882a593Smuzhiyun #define	BCM47XX_ATA100_ID	0x471d		/* 47xx parallel ATA */
90*4882a593Smuzhiyun #define	BCM47XX_SATAXOR_ID	0x471e		/* 47xx serial ATA & XOR DMA */
91*4882a593Smuzhiyun #define	BCM47XX_GIGETH_ID	0x471f		/* 47xx GbE (5700) */
92*4882a593Smuzhiyun #define	BCM47XX_USB30H_ID	0x472a		/* 47xx usb 3.0 host */
93*4882a593Smuzhiyun #define	BCM47XX_USB30D_ID	0x472b		/* 47xx usb 3.0 device */
94*4882a593Smuzhiyun #define	BCM47XX_USBHUB_ID	0x472c		/* 47xx usb hub */
95*4882a593Smuzhiyun #define BCM47XX_SMBUS_EMU_ID	0x47fe		/* 47xx emulated SMBus device */
96*4882a593Smuzhiyun #define	BCM47XX_XOR_EMU_ID	0x47ff		/* 47xx emulated XOR engine */
97*4882a593Smuzhiyun #define JINVANI_SDIOH_ID	0x4743		/* Jinvani SDIO Gold Host */
98*4882a593Smuzhiyun #define BCM27XX_SDIOH_ID	0x2702		/* BCM27xx Standard SDIO Host */
99*4882a593Smuzhiyun #define PCIXX21_FLASHMEDIA_ID	0x803b		/* TI PCI xx21 Standard Host Controller */
100*4882a593Smuzhiyun #define PCIXX21_SDIOH_ID	0x803c		/* TI PCI xx21 Standard Host Controller */
101*4882a593Smuzhiyun #define R5C822_SDIOH_ID		0x0822		/* Ricoh Co Ltd R5C822 SD/SDIO/MMC/MS/MSPro Host */
102*4882a593Smuzhiyun #define JMICRON_SDIOH_ID	0x2381		/* JMicron Standard SDIO Host Controller */
103*4882a593Smuzhiyun 
104*4882a593Smuzhiyun /* PCI Device IDs */
105*4882a593Smuzhiyun /* DEPRECATED but used */
106*4882a593Smuzhiyun #define	BCM4318_D11G_ID		0x4318		/* 4318 802.11b/g id */
107*4882a593Smuzhiyun /* DEPRECATED */
108*4882a593Smuzhiyun 
109*4882a593Smuzhiyun #define BCM4360_D11AC_ID	0x43a0
110*4882a593Smuzhiyun #define BCM4360_D11AC2G_ID	0x43a1
111*4882a593Smuzhiyun #define BCM4360_D11AC5G_ID	0x43a2
112*4882a593Smuzhiyun #define BCM4352_D11AC_ID	0x43b1		/* 4352 802.11ac dualband device */
113*4882a593Smuzhiyun #define BCM4352_D11AC2G_ID	0x43b2		/* 4352 802.11ac 2.4G device */
114*4882a593Smuzhiyun #define BCM4352_D11AC5G_ID	0x43b3		/* 4352 802.11ac 5G device */
115*4882a593Smuzhiyun #define BCM43602_D11AC_ID	0x43ba		/* ac dualband PCI devid SPROM programmed */
116*4882a593Smuzhiyun #define BCM43602_D11AC2G_ID	0x43bb		/* 43602 802.11ac 2.4G device */
117*4882a593Smuzhiyun #define BCM43602_D11AC5G_ID	0x43bc		/* 43602 802.11ac 5G device */
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun #define BCM43012_D11N_ID	0xA804		/* 43012 802.11n dualband device */
120*4882a593Smuzhiyun #define BCM43012_D11N2G_ID	0xA805		/* 43012 802.11n 2.4G device */
121*4882a593Smuzhiyun #define BCM43012_D11N5G_ID	0xA806		/* 43012 802.11n 5G device */
122*4882a593Smuzhiyun #define BCM43014_D11N_ID	0x4495		/* 43014 802.11n dualband device */
123*4882a593Smuzhiyun #define BCM43014_D11N2G_ID	0x4496		/* 43014 802.11n 2.4G device */
124*4882a593Smuzhiyun #define BCM43014_D11N5G_ID	0x4497		/* 43014 802.11n 5G device */
125*4882a593Smuzhiyun #define BCM43013_D11N_ID	0x4498		/* 43013 802.11n dualband device */
126*4882a593Smuzhiyun #define BCM43013_D11N2G_ID	0x4499		/* 43013 802.11n 2.4G device */
127*4882a593Smuzhiyun #define BCM43013_D11N5G_ID	0x449a		/* 43013 802.11n 5G device */
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun /* PCI Subsystem ID */
130*4882a593Smuzhiyun #define BCM4376_D11AX_ID	0x4445		/* 4376 802.11ax dualband device */
131*4882a593Smuzhiyun #define BCM4376_D11AX2G_ID	0x4436		/* 4376 802.11ax 2.4G device */
132*4882a593Smuzhiyun #define BCM4376_D11AX5G_ID	0x4437		/* 4376 802.11ax 5G device */
133*4882a593Smuzhiyun 
134*4882a593Smuzhiyun #define BCM4378_D11AX_ID	0x4425		/* 4378 802.11ax dualband device */
135*4882a593Smuzhiyun #define BCM4378_D11AX2G_ID	0x4426		/* 4378 802.11ax 2.4G device */
136*4882a593Smuzhiyun #define BCM4378_D11AX5G_ID	0x4427		/* 4378 802.11ax 5G device */
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun #define BCM4387_D11AX_ID	0x4433		/* 4387 802.11ax dualband device */
139*4882a593Smuzhiyun #define BCM4388_D11AX_ID	0x4434		/* 4388 802.11ax dualband device */
140*4882a593Smuzhiyun #define BCM4385_D11AX_ID	0x4442		/* 4385 802.11ax dualband device */
141*4882a593Smuzhiyun #define BCM4389_D11AX_ID	0x4441		/* 4389 802.11ax dualband device */
142*4882a593Smuzhiyun #define BCM4397_D11AX_ID	0x4443		/* 4397 802.11ax dualband device */
143*4882a593Smuzhiyun 
144*4882a593Smuzhiyun #define BCM4362_D11AX_ID	0x4490		/* 4362 802.11ax dualband device */
145*4882a593Smuzhiyun #define BCM4362_D11AX2G_ID	0x4491		/* 4362 802.11ax 2.4G device */
146*4882a593Smuzhiyun #define BCM4362_D11AX5G_ID	0x4492		/* 4362 802.11ax 5G device */
147*4882a593Smuzhiyun #define BCM43751_D11AX_ID	0x449a		/* 43751 802.11ac dualband device */
148*4882a593Smuzhiyun #define BCM43751_D11AX2G_ID	0x449b		/* 43751 802.11ac 2.4G device */
149*4882a593Smuzhiyun #define BCM43751_D11AX5G_ID	0x449c		/* 43751 802.11ac 5G device */
150*4882a593Smuzhiyun #define BCM43752_D11AX_ID	0x449d		/* 43752 802.11ax dualband device */
151*4882a593Smuzhiyun #define BCM43752_D11AX2G_ID	0x449e		/* 43752 802.11ax 2.4G device */
152*4882a593Smuzhiyun #define BCM43752_D11AX5G_ID	0x449f		/* 43752 802.11ax 5G device */
153*4882a593Smuzhiyun 
154*4882a593Smuzhiyun /* TBD change below values */
155*4882a593Smuzhiyun #define BCM4369_D11AX_ID	0x4470		/* 4369 802.11ax dualband device */
156*4882a593Smuzhiyun #define BCM4369_D11AX2G_ID	0x4471		/* 4369 802.11ax 2.4G device */
157*4882a593Smuzhiyun #define BCM4369_D11AX5G_ID	0x4472		/* 4369 802.11ax 5G device */
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun #define BCM4375_D11AX_ID	0x4475		/* 4375 802.11ax dualband device */
160*4882a593Smuzhiyun #define BCM4375_D11AX2G_ID	0x4476		/* 4375 802.11ax 2.4G device */
161*4882a593Smuzhiyun #define BCM4375_D11AX5G_ID	0x4477		/* 4375 802.11ax 5G device */
162*4882a593Smuzhiyun 
163*4882a593Smuzhiyun #define BCM4377_D11AX_ID	0x4480		/* 4377 802.11ax dualband device */
164*4882a593Smuzhiyun #define BCM4377_D11AX2G_ID	0x4481		/* 4377 802.11ax 2.4G device */
165*4882a593Smuzhiyun #define BCM4377_D11AX5G_ID	0x4482		/* 4377 802.11ax 5G device */
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun /* 4377 802.11ax dualband device with multifunction */
168*4882a593Smuzhiyun #define BCM4377_M_D11AX_ID	0x4488
169*4882a593Smuzhiyun 
170*4882a593Smuzhiyun /* Chip IDs */
171*4882a593Smuzhiyun 
172*4882a593Smuzhiyun #define BCM43143_CHIP_ID	43143		/* 43143 chipcommon chipid */
173*4882a593Smuzhiyun #define	BCM43242_CHIP_ID	43242		/* 43242 chipcommon chipid */
174*4882a593Smuzhiyun #define	BCM43460_CHIP_ID	43460		/* 4360  chipcommon chipid (OTP, RBBU) */
175*4882a593Smuzhiyun #define BCM4360_CHIP_ID		0x4360          /* 4360 chipcommon chipid */
176*4882a593Smuzhiyun #define BCM43362_CHIP_ID	43362		/* 43362 chipcommon chipid */
177*4882a593Smuzhiyun #define BCM4330_CHIP_ID		0x4330		/* 4330 chipcommon chipid */
178*4882a593Smuzhiyun #define	BCM4324_CHIP_ID		0x4324		/* 4324 chipcommon chipid */
179*4882a593Smuzhiyun #define BCM4334_CHIP_ID		0x4334		/* 4334 chipcommon chipid */
180*4882a593Smuzhiyun #define BCM4335_CHIP_ID		0x4335		/* 4335 chipcommon chipid */
181*4882a593Smuzhiyun #define BCM4339_CHIP_ID		0x4339		/* 4339 chipcommon chipid */
182*4882a593Smuzhiyun #define BCM4352_CHIP_ID		0x4352          /* 4352 chipcommon chipid */
183*4882a593Smuzhiyun #define BCM43526_CHIP_ID	0xAA06
184*4882a593Smuzhiyun #define BCM43340_CHIP_ID	43340		/* 43340 chipcommon chipid */
185*4882a593Smuzhiyun #define BCM43341_CHIP_ID	43341		/* 43341 chipcommon chipid */
186*4882a593Smuzhiyun #define BCM43562_CHIP_ID	0xAA2A          /* 43562 chipcommon chipid */
187*4882a593Smuzhiyun #define	BCM43012_CHIP_ID	0xA804          /* 43012 chipcommon chipid */
188*4882a593Smuzhiyun #define	BCM43013_CHIP_ID	0xA805          /* 43013 chipcommon chipid */
189*4882a593Smuzhiyun #define	BCM43014_CHIP_ID	0xA806          /* 43014 chipcommon chipid */
190*4882a593Smuzhiyun #define	BCM4369_CHIP_ID		0x4369          /* 4369 chipcommon chipid */
191*4882a593Smuzhiyun #define BCM4375_CHIP_ID		0x4375          /* 4375 chipcommon chipid */
192*4882a593Smuzhiyun #define BCM4376_CHIP_ID		0x4376          /* 4376 chipcommon chipid */
193*4882a593Smuzhiyun #define BCM4354_CHIP_ID		0x4354          /* 4354 chipcommon chipid */
194*4882a593Smuzhiyun #define BCM4356_CHIP_ID		0x4356          /* 4356 chipcommon chipid */
195*4882a593Smuzhiyun #define BCM4371_CHIP_ID		0x4371          /* 4371 chipcommon chipid */
196*4882a593Smuzhiyun #define BCM43569_CHIP_ID	0xAA31          /* 43569 chipcommon chipid */
197*4882a593Smuzhiyun 
198*4882a593Smuzhiyun #define BCM4345_CHIP_ID		0x4345		/* 4345 chipcommon chipid */
199*4882a593Smuzhiyun #define BCM43454_CHIP_ID	43454		/* 43454 chipcommon chipid */
200*4882a593Smuzhiyun #define BCM43430_CHIP_ID	43430		/* 43430 chipcommon chipid */
201*4882a593Smuzhiyun #define BCM4359_CHIP_ID		0x4359		/* 4359 chipcommon chipid */
202*4882a593Smuzhiyun #define BCM4362_CHIP_ID		0x4362          /* 4362 chipcommon chipid */
203*4882a593Smuzhiyun #define BCM43751_CHIP_ID	0xAAE7          /* 43751 chipcommon chipid */
204*4882a593Smuzhiyun #define BCM43752_CHIP_ID	0xAAE8          /* 43752 chipcommon chipid */
205*4882a593Smuzhiyun #define BCM4369_CHIP_ID		0x4369          /* 4369 chipcommon chipid */
206*4882a593Smuzhiyun #define BCM4377_CHIP_ID		0x4377          /* 4377 chipcommon chipid */
207*4882a593Smuzhiyun #define BCM4378_CHIP_ID		0x4378          /* 4378 chipcommon chipid */
208*4882a593Smuzhiyun #define BCM4385_CHIP_ID		0x4385          /* 4385 chipcommon chipid */
209*4882a593Smuzhiyun #define BCM4387_CHIP_ID		0x4387          /* 4387 chipcommon chipid */
210*4882a593Smuzhiyun #define BCM4388_CHIP_ID		0x4388          /* 4388 chipcommon chipid */
211*4882a593Smuzhiyun #define BCM4389_CHIP_ID		0x4389          /* 4389 chipcommon chipid */
212*4882a593Smuzhiyun #define BCM4397_CHIP_ID		0x4397          /* 4397 chipcommon chipid */
213*4882a593Smuzhiyun 
214*4882a593Smuzhiyun #define BCM4362_CHIP(chipid)	(CHIPID(chipid) == BCM4362_CHIP_ID)
215*4882a593Smuzhiyun #define BCM4362_CHIP_GRPID	BCM4362_CHIP_ID
216*4882a593Smuzhiyun 
217*4882a593Smuzhiyun #define BCM4369_CHIP(chipid)	((CHIPID(chipid) == BCM4369_CHIP_ID) || \
218*4882a593Smuzhiyun 				(CHIPID(chipid) == BCM4377_CHIP_ID) || \
219*4882a593Smuzhiyun 				(CHIPID(chipid) == BCM4375_CHIP_ID))
220*4882a593Smuzhiyun #define BCM4369_CHIP_GRPID		BCM4369_CHIP_ID: \
221*4882a593Smuzhiyun 					case BCM4377_CHIP_ID: \
222*4882a593Smuzhiyun 					case BCM4375_CHIP_ID
223*4882a593Smuzhiyun 
224*4882a593Smuzhiyun #define BCM4385_CHIP(chipid)	(CHIPID(chipid) == BCM4385_CHIP_ID)
225*4882a593Smuzhiyun #define BCM4385_CHIP_GRPID	BCM4385_CHIP_ID
226*4882a593Smuzhiyun 
227*4882a593Smuzhiyun #define BCM4378_CHIP(chipid)    (CHIPID(chipid) == BCM4378_CHIP_ID)
228*4882a593Smuzhiyun #define BCM4378_CHIP_GRPID	BCM4378_CHIP_ID
229*4882a593Smuzhiyun 
230*4882a593Smuzhiyun #define BCM4376_CHIP_GRPID	BCM4376_CHIP_ID
231*4882a593Smuzhiyun #define BCM4376_CHIP(chipid)    (CHIPID(chipid) == BCM4376_CHIP_ID)
232*4882a593Smuzhiyun 
233*4882a593Smuzhiyun #define BCM4387_CHIP(chipid)    (CHIPID(chipid) == BCM4387_CHIP_ID)
234*4882a593Smuzhiyun #define BCM4387_CHIP_GRPID	BCM4387_CHIP_ID
235*4882a593Smuzhiyun 
236*4882a593Smuzhiyun #define BCM4388_CHIP(chipid)	(CHIPID(chipid) == BCM4388_CHIP_ID)
237*4882a593Smuzhiyun #define BCM4388_CHIP_GRPID	BCM4388_CHIP_ID
238*4882a593Smuzhiyun 
239*4882a593Smuzhiyun #define BCM4389_CHIP(chipid)	(CHIPID(chipid) == BCM4389_CHIP_ID)
240*4882a593Smuzhiyun #define BCM4389_CHIP_GRPID	BCM4389_CHIP_ID
241*4882a593Smuzhiyun 
242*4882a593Smuzhiyun #define BCM4397_CHIP(chipid)	(CHIPID(chipid) == BCM4397_CHIP_ID)
243*4882a593Smuzhiyun #define BCM4397_CHIP_GRPID	BCM4397_CHIP_ID
244*4882a593Smuzhiyun 
245*4882a593Smuzhiyun #define BCM43602_CHIP_ID	0xaa52		/* 43602 chipcommon chipid */
246*4882a593Smuzhiyun #define BCM43462_CHIP_ID	0xa9c6		/* 43462 chipcommon chipid */
247*4882a593Smuzhiyun #define BCM43522_CHIP_ID	0xaa02		/* 43522 chipcommon chipid */
248*4882a593Smuzhiyun #define BCM43602_CHIP(chipid)	((CHIPID(chipid) == BCM43602_CHIP_ID) || \
249*4882a593Smuzhiyun 				(CHIPID(chipid) == BCM43462_CHIP_ID) || \
250*4882a593Smuzhiyun 				(CHIPID(chipid) == BCM43522_CHIP_ID)) /* 43602 variations */
251*4882a593Smuzhiyun #define BCM43012_CHIP(chipid)	((CHIPID(chipid) == BCM43012_CHIP_ID) || \
252*4882a593Smuzhiyun 				(CHIPID(chipid) == BCM43013_CHIP_ID) || \
253*4882a593Smuzhiyun 				(CHIPID(chipid) == BCM43014_CHIP_ID))
254*4882a593Smuzhiyun #define CASE_BCM43602_CHIP		case BCM43602_CHIP_ID: /* fallthrough */ \
255*4882a593Smuzhiyun 				case BCM43462_CHIP_ID: /* fallthrough */ \
256*4882a593Smuzhiyun 				case BCM43522_CHIP_ID
257*4882a593Smuzhiyun 
258*4882a593Smuzhiyun /* Package IDs */
259*4882a593Smuzhiyun 
260*4882a593Smuzhiyun #define HDLSIM_PKG_ID		14		/* HDL simulator package id */
261*4882a593Smuzhiyun #define HWSIM_PKG_ID		15		/* Hardware simulator package id */
262*4882a593Smuzhiyun 
263*4882a593Smuzhiyun #define PCIXX21_FLASHMEDIA0_ID	0x8033		/* TI PCI xx21 Standard Host Controller */
264*4882a593Smuzhiyun #define PCIXX21_SDIOH0_ID	0x8034		/* TI PCI xx21 Standard Host Controller */
265*4882a593Smuzhiyun 
266*4882a593Smuzhiyun #define BCM43602_12x12_PKG_ID	(0x1)	/* 12x12 pins package, used for e.g. router designs */
267*4882a593Smuzhiyun 
268*4882a593Smuzhiyun /* 43012 package ID's
269*4882a593Smuzhiyun     http://confluence.broadcom.com/display/WLAN/BCM43012+Variants%2Cpackage%2Cballmap%2Cfloorplan#
270*4882a593Smuzhiyun     BCM43012Variants,package,ballmap,floorplan-PackageOptions
271*4882a593Smuzhiyun */
272*4882a593Smuzhiyun #define BCM943012_WLCSPOLY_PKG_ID	0x0	/* WLCSP Oly package */
273*4882a593Smuzhiyun #define BCM943012_FCBGA_PKG_ID		0x3	/* FCBGA debug package */
274*4882a593Smuzhiyun #define BCM943012_WLCSPWE_PKG_ID	0x1	/* WLCSP WE package */
275*4882a593Smuzhiyun #define BCM943012_FCBGAWE_PKG_ID	0x5	/* FCBGA WE package */
276*4882a593Smuzhiyun #define BCM943012_WLBGA_PKG_ID		0x2	/* WLBGA package */
277*4882a593Smuzhiyun 
278*4882a593Smuzhiyun /* boardflags */
279*4882a593Smuzhiyun #define	BFL_BTC2WIRE		0x00000001  /* old 2wire Bluetooth coexistence, OBSOLETE */
280*4882a593Smuzhiyun #define BFL_BTCOEX      0x00000001      /* Board supports BTCOEX */
281*4882a593Smuzhiyun #define	BFL_PACTRL		0x00000002  /* Board has gpio 9 controlling the PA */
282*4882a593Smuzhiyun #define BFL_AIRLINEMODE	0x00000004  /* Board implements gpio radio disable indication */
283*4882a593Smuzhiyun #define	BFL_ADCDIV		0x00000008  /* Board has the rssi ADC divider */
284*4882a593Smuzhiyun #define BFL_DIS_256QAM		0x00000008
285*4882a593Smuzhiyun 					/* for 4360, this bit is to disable 256QAM support */
286*4882a593Smuzhiyun #define	BFL_ENETROBO		0x00000010  /* Board has robo switch or core */
287*4882a593Smuzhiyun #define	BFL_TSSIAVG		0x00000010  /* TSSI averaging for ACPHY chips */
288*4882a593Smuzhiyun #define	BFL_NOPLLDOWN		0x00000020  /* Not ok to power down the chip pll and oscillator */
289*4882a593Smuzhiyun #define	BFL_CCKHIPWR		0x00000040  /* Can do high-power CCK transmission */
290*4882a593Smuzhiyun #define	BFL_ENETADM		0x00000080  /* Board has ADMtek switch */
291*4882a593Smuzhiyun #define	BFL_ENETVLAN		0x00000100  /* Board has VLAN capability */
292*4882a593Smuzhiyun #define	BFL_LTECOEX		0x00000200  /* LTE Coex enabled */
293*4882a593Smuzhiyun #define BFL_NOPCI		0x00000400  /* Board leaves PCI floating */
294*4882a593Smuzhiyun #define BFL_FEM			0x00000800  /* Board supports the Front End Module */
295*4882a593Smuzhiyun #define BFL_EXTLNA		0x00001000  /* Board has an external LNA in 2.4GHz band */
296*4882a593Smuzhiyun #define BFL_HGPA		0x00002000  /* Board has a high gain PA */
297*4882a593Smuzhiyun #define	BFL_BTC2WIRE_ALTGPIO	0x00004000  /* Board's BTC 2wire is in the alternate gpios */
298*4882a593Smuzhiyun #define	BFL_ALTIQ		0x00008000  /* Alternate I/Q settings */
299*4882a593Smuzhiyun #define BFL_NOPA		0x00010000  /* Board has no PA */
300*4882a593Smuzhiyun #define BFL_RSSIINV		0x00020000  /* Board's RSSI uses positive slope(not TSSI) */
301*4882a593Smuzhiyun #define BFL_PAREF		0x00040000  /* Board uses the PARef LDO */
302*4882a593Smuzhiyun #define BFL_3TSWITCH		0x00080000  /* Board uses a triple throw switch shared with BT */
303*4882a593Smuzhiyun #define BFL_PHASESHIFT		0x00100000  /* Board can support phase shifter */
304*4882a593Smuzhiyun #define BFL_BUCKBOOST		0x00200000  /* Power topology uses BUCKBOOST */
305*4882a593Smuzhiyun #define BFL_FEM_BT		0x00400000  /* Board has FEM and switch to share antenna w/ BT */
306*4882a593Smuzhiyun #define BFL_NOCBUCK		0x00800000  /* Power topology doesn't use CBUCK */
307*4882a593Smuzhiyun #define BFL_CCKFAVOREVM		0x01000000  /* Favor CCK EVM over spectral mask */
308*4882a593Smuzhiyun #define BFL_PALDO		0x02000000  /* Power topology uses PALDO */
309*4882a593Smuzhiyun #define BFL_LNLDO2_2P5		0x04000000  /* Select 2.5V as LNLDO2 output voltage */
310*4882a593Smuzhiyun /* BFL_FASTPWR and BFL_UCPWRCTL_MININDX are non-overlaping features and use the same bit */
311*4882a593Smuzhiyun #define BFL_FASTPWR		0x08000000  /* Fast switch/antenna powerup (no POR WAR) */
312*4882a593Smuzhiyun #define BFL_UCPWRCTL_MININDX	0x08000000  /* Enforce min power index to avoid FEM damage */
313*4882a593Smuzhiyun #define BFL_EXTLNA_5GHz		0x10000000  /* Board has an external LNA in 5GHz band */
314*4882a593Smuzhiyun #define BFL_TRSW_1by2		0x20000000  /* Board has 2 TRSW's in 1by2 designs */
315*4882a593Smuzhiyun #define BFL_GAINBOOSTA01        0x20000000  /* 5g Gainboost for core0 and core1 */
316*4882a593Smuzhiyun #define BFL_LO_TRSW_R_5GHz	0x40000000  /* In 5G do not throw TRSW to T for clipLO gain */
317*4882a593Smuzhiyun #define BFL_ELNA_GAINDEF	0x80000000  /* Backoff InitGain based on elna_2g/5g field
318*4882a593Smuzhiyun 					     * when this flag is set
319*4882a593Smuzhiyun 					     */
320*4882a593Smuzhiyun #define BFL_EXTLNA_TX	0x20000000	/* Temp boardflag to indicate to */
321*4882a593Smuzhiyun 
322*4882a593Smuzhiyun /* boardflags2 */
323*4882a593Smuzhiyun #define BFL2_RXBB_INT_REG_DIS	0x00000001  /* Board has an external rxbb regulator */
324*4882a593Smuzhiyun #define BFL2_APLL_WAR		0x00000002  /* Flag to implement alternative A-band PLL settings */
325*4882a593Smuzhiyun #define BFL2_TXPWRCTRL_EN	0x00000004  /* Board permits enabling TX Power Control */
326*4882a593Smuzhiyun #define BFL2_2X4_DIV		0x00000008  /* Board supports the 2X4 diversity switch */
327*4882a593Smuzhiyun #define BFL2_5G_PWRGAIN		0x00000010  /* Board supports 5G band power gain */
328*4882a593Smuzhiyun #define BFL2_PCIEWAR_OVR	0x00000020  /* Board overrides ASPM and Clkreq settings */
329*4882a593Smuzhiyun #define BFL2_CAESERS_BRD	0x00000040  /* Board is Caesers brd (unused by sw) */
330*4882a593Smuzhiyun #define BFL2_WLCX_ATLAS		0x00000040  /* Board flag to initialize ECI for WLCX on FL-ATLAS */
331*4882a593Smuzhiyun #define BFL2_BTC3WIRE		0x00000080  /* Board support legacy 3 wire or 4 wire */
332*4882a593Smuzhiyun #define BFL2_BTCLEGACY          0x00000080  /* Board support legacy 3/4 wire, to replace
333*4882a593Smuzhiyun 					     * BFL2_BTC3WIRE
334*4882a593Smuzhiyun 					     */
335*4882a593Smuzhiyun #define BFL2_SKWRKFEM_BRD	0x00000100  /* 4321mcm93 board uses Skyworks FEM */
336*4882a593Smuzhiyun #define BFL2_SPUR_WAR		0x00000200  /* Board has a WAR for clock-harmonic spurs */
337*4882a593Smuzhiyun #define BFL2_GPLL_WAR		0x00000400  /* Flag to narrow G-band PLL loop b/w */
338*4882a593Smuzhiyun #define BFL2_TRISTATE_LED	0x00000800  /* Tri-state the LED */
339*4882a593Smuzhiyun #define BFL2_SINGLEANT_CCK	0x00001000  /* Tx CCK pkts on Ant 0 only */
340*4882a593Smuzhiyun #define BFL2_2G_SPUR_WAR	0x00002000  /* WAR to reduce and avoid clock-harmonic spurs in 2G */
341*4882a593Smuzhiyun #define BFL2_BPHY_ALL_TXCORES	0x00004000  /* Transmit bphy frames using all tx cores */
342*4882a593Smuzhiyun #define BFL2_FCC_BANDEDGE_WAR	0x00008000  /* Activates WAR to improve FCC bandedge performance */
343*4882a593Smuzhiyun #define BFL2_DAC_SPUR_IMPROVEMENT 0x00008000       /* Reducing DAC Spurs */
344*4882a593Smuzhiyun #define BFL2_GPLL_WAR2	        0x00010000  /* Flag to widen G-band PLL loop b/w */
345*4882a593Smuzhiyun #define BFL2_REDUCED_PA_TURNONTIME 0x00010000  /* Flag to reduce PA turn on Time */
346*4882a593Smuzhiyun #define BFL2_IPALVLSHIFT_3P3    0x00020000  /* Flag to Activate the PR 74115 PA Level Shift
347*4882a593Smuzhiyun 					     * Workaround where the gpaio pin is connected to 3.3V
348*4882a593Smuzhiyun 					     */
349*4882a593Smuzhiyun #define BFL2_INTERNDET_TXIQCAL  0x00040000  /* Use internal envelope detector for TX IQCAL */
350*4882a593Smuzhiyun #define BFL2_XTALBUFOUTEN       0x00080000  /* Keep the buffered Xtal output from radio on */
351*4882a593Smuzhiyun 				/* Most drivers will turn it off without this flag */
352*4882a593Smuzhiyun 				/* to save power. */
353*4882a593Smuzhiyun 
354*4882a593Smuzhiyun #define BFL2_ANAPACTRL_2G	0x00100000  /* 2G ext PAs are controlled by analog PA ctrl lines */
355*4882a593Smuzhiyun #define BFL2_ANAPACTRL_5G	0x00200000  /* 5G ext PAs are controlled by analog PA ctrl lines */
356*4882a593Smuzhiyun #define BFL2_ELNACTRL_TRSW_2G	0x00400000  /* AZW4329: 2G gmode_elna_gain controls TR Switch */
357*4882a593Smuzhiyun #define BFL2_BT_SHARE_ANT0	0x00800000  /* share core0 antenna with BT */
358*4882a593Smuzhiyun #define BFL2_TEMPSENSE_HIGHER	0x01000000  /* The tempsense threshold can sustain higher value
359*4882a593Smuzhiyun 					     * than programmed. The exact delta is decided by
360*4882a593Smuzhiyun 					     * driver per chip/boardtype. This can be used
361*4882a593Smuzhiyun 					     * when tempsense qualification happens after shipment
362*4882a593Smuzhiyun 					     */
363*4882a593Smuzhiyun #define BFL2_BTC3WIREONLY       0x02000000  /* standard 3 wire btc only.  4 wire not supported */
364*4882a593Smuzhiyun #define BFL2_PWR_NOMINAL	0x04000000  /* 0: power reduction on, 1: no power reduction */
365*4882a593Smuzhiyun #define BFL2_EXTLNA_PWRSAVE	0x08000000  /* boardflag to enable ucode to apply power save */
366*4882a593Smuzhiyun 						/* ucode control of eLNA during Tx */
367*4882a593Smuzhiyun #define BFL2_SDR_EN		0x20000000  /* SDR enabled or disabled */
368*4882a593Smuzhiyun #define BFL2_DYNAMIC_VMID	0x10000000  /* boardflag to enable dynamic Vmid idle TSSI CAL */
369*4882a593Smuzhiyun #define BFL2_LNA1BYPFORTR2G	0x40000000  /* acphy, enable lna1 bypass for clip gain, 2g */
370*4882a593Smuzhiyun #define BFL2_LNA1BYPFORTR5G	0x80000000  /* acphy, enable lna1 bypass for clip gain, 5g */
371*4882a593Smuzhiyun 
372*4882a593Smuzhiyun /* SROM 11 - 11ac boardflag definitions */
373*4882a593Smuzhiyun #define BFL_SROM11_BTCOEX  0x00000001  /* Board supports BTCOEX */
374*4882a593Smuzhiyun #define BFL_SROM11_WLAN_BT_SH_XTL  0x00000002  /* bluetooth and wlan share same crystal */
375*4882a593Smuzhiyun #define BFL_SROM11_EXTLNA	0x00001000  /* Board has an external LNA in 2.4GHz band */
376*4882a593Smuzhiyun #define BFL_SROM11_EPA_TURNON_TIME     0x00018000  /* 2 bits for different PA turn on times */
377*4882a593Smuzhiyun #define BFL_SROM11_EPA_TURNON_TIME_SHIFT  15
378*4882a593Smuzhiyun #define BFL_SROM11_PRECAL_TX_IDX	0x00040000  /* Dedicated TX IQLOCAL IDX values */
379*4882a593Smuzhiyun 				/* per subband, as derived from 43602A1 MCH5 */
380*4882a593Smuzhiyun #define BFL_SROM11_EXTLNA_5GHz	0x10000000  /* Board has an external LNA in 5GHz band */
381*4882a593Smuzhiyun #define BFL_SROM11_GAINBOOSTA01	0x20000000  /* 5g Gainboost for core0 and core1 */
382*4882a593Smuzhiyun #define BFL2_SROM11_APLL_WAR	0x00000002  /* Flag to implement alternative A-band PLL settings */
383*4882a593Smuzhiyun #define BFL2_SROM11_ANAPACTRL_2G  0x00100000  /* 2G ext PAs are ctrl-ed by analog PA ctrl lines */
384*4882a593Smuzhiyun #define BFL2_SROM11_ANAPACTRL_5G  0x00200000  /* 5G ext PAs are ctrl-ed by analog PA ctrl lines */
385*4882a593Smuzhiyun #define BFL2_SROM11_SINGLEANT_CCK	0x00001000  /* Tx CCK pkts on Ant 0 only */
386*4882a593Smuzhiyun #define BFL2_SROM11_EPA_ON_DURING_TXIQLOCAL    0x00020000  /* Keep ext. PA's on in TX IQLO CAL */
387*4882a593Smuzhiyun 
388*4882a593Smuzhiyun /* boardflags3 */
389*4882a593Smuzhiyun #define BFL3_FEMCTRL_SUB	  0x00000007  /* acphy, subrevs of femctrl on top of srom_femctrl */
390*4882a593Smuzhiyun #define BFL3_RCAL_WAR		  0x00000008  /* acphy, rcal war active on this board (4335a0) */
391*4882a593Smuzhiyun #define BFL3_TXGAINTBLID	  0x00000070  /* acphy, txgain table id */
392*4882a593Smuzhiyun #define BFL3_TXGAINTBLID_SHIFT	  0x4         /* acphy, txgain table id shift bit */
393*4882a593Smuzhiyun #define BFL3_TSSI_DIV_WAR	  0x00000080  /* acphy, Seperate paparam for 20/40/80 */
394*4882a593Smuzhiyun #define BFL3_TSSI_DIV_WAR_SHIFT	  0x7         /* acphy, Seperate paparam for 20/40/80 shift bit */
395*4882a593Smuzhiyun #define BFL3_FEMTBL_FROM_NVRAM    0x00000100  /* acphy, femctrl table is read from nvram */
396*4882a593Smuzhiyun #define BFL3_FEMTBL_FROM_NVRAM_SHIFT 0x8         /* acphy, femctrl table is read from nvram */
397*4882a593Smuzhiyun #define BFL3_AGC_CFG_2G           0x00000200  /* acphy, gain control configuration for 2G */
398*4882a593Smuzhiyun #define BFL3_AGC_CFG_5G           0x00000400  /* acphy, gain control configuration for 5G */
399*4882a593Smuzhiyun #define BFL3_PPR_BIT_EXT          0x00000800  /* acphy, bit position for 1bit extension for ppr */
400*4882a593Smuzhiyun #define BFL3_PPR_BIT_EXT_SHIFT    11          /* acphy, bit shift for 1bit extension for ppr */
401*4882a593Smuzhiyun #define BFL3_BBPLL_SPR_MODE_DIS	  0x00001000  /* acphy, disables bbpll spur modes */
402*4882a593Smuzhiyun #define BFL3_RCAL_OTP_VAL_EN      0x00002000  /* acphy, to read rcal_trim value from otp */
403*4882a593Smuzhiyun #define BFL3_2GTXGAINTBL_BLANK	  0x00004000  /* acphy, blank the first X ticks of 2g gaintbl */
404*4882a593Smuzhiyun #define BFL3_2GTXGAINTBL_BLANK_SHIFT 14       /* acphy, blank the first X ticks of 2g gaintbl */
405*4882a593Smuzhiyun #define BFL3_5GTXGAINTBL_BLANK	  0x00008000  /* acphy, blank the first X ticks of 5g gaintbl */
406*4882a593Smuzhiyun #define BFL3_5GTXGAINTBL_BLANK_SHIFT 15       /* acphy, blank the first X ticks of 5g gaintbl */
407*4882a593Smuzhiyun #define BFL3_PHASETRACK_MAX_ALPHABETA	  0x00010000  /* acphy, to max out alpha,beta to 511 */
408*4882a593Smuzhiyun #define BFL3_PHASETRACK_MAX_ALPHABETA_SHIFT 16       /* acphy, to max out alpha,beta to 511 */
409*4882a593Smuzhiyun /* acphy, to use backed off gaintbl for lte-coex */
410*4882a593Smuzhiyun #define BFL3_LTECOEX_GAINTBL_EN           0x00060000
411*4882a593Smuzhiyun /* acphy, to use backed off gaintbl for lte-coex */
412*4882a593Smuzhiyun #define BFL3_LTECOEX_GAINTBL_EN_SHIFT 17
413*4882a593Smuzhiyun #define BFL3_5G_SPUR_WAR          0x00080000  /* acphy, enable spur WAR in 5G band */
414*4882a593Smuzhiyun 
415*4882a593Smuzhiyun /* acphy: lpmode2g and lpmode_5g related boardflags */
416*4882a593Smuzhiyun #define BFL3_ACPHY_LPMODE_2G	  0x00300000  /* bits 20:21 for lpmode_2g choice */
417*4882a593Smuzhiyun #define BFL3_ACPHY_LPMODE_2G_SHIFT	  20
418*4882a593Smuzhiyun 
419*4882a593Smuzhiyun #define BFL3_ACPHY_LPMODE_5G	  0x00C00000  /* bits 22:23 for lpmode_5g choice */
420*4882a593Smuzhiyun #define BFL3_ACPHY_LPMODE_5G_SHIFT	  22
421*4882a593Smuzhiyun 
422*4882a593Smuzhiyun #define BFL3_1X1_RSDB_ANT	  0x01000000  /* to find if 2-ant RSDB board or 1-ant RSDB board */
423*4882a593Smuzhiyun #define BFL3_1X1_RSDB_ANT_SHIFT           24
424*4882a593Smuzhiyun 
425*4882a593Smuzhiyun #define BFL3_EXT_LPO_ISCLOCK      0x02000000  /* External LPO is clock, not x-tal */
426*4882a593Smuzhiyun #define BFL3_FORCE_INT_LPO_SEL    0x04000000  /* Force internal lpo */
427*4882a593Smuzhiyun #define BFL3_FORCE_EXT_LPO_SEL    0x08000000  /* Force external lpo */
428*4882a593Smuzhiyun 
429*4882a593Smuzhiyun #define BFL3_EN_BRCM_IMPBF        0x10000000  /* acphy, Allow BRCM Implicit TxBF */
430*4882a593Smuzhiyun 
431*4882a593Smuzhiyun #define BFL3_PADCAL_OTP_VAL_EN    0x20000000  /* acphy, to read pad cal values from otp */
432*4882a593Smuzhiyun 
433*4882a593Smuzhiyun #define BFL3_AVVMID_FROM_NVRAM    0x40000000  /* Read Av Vmid from NVRAM  */
434*4882a593Smuzhiyun #define BFL3_VLIN_EN_FROM_NVRAM    0x80000000  /* Read Vlin En from NVRAM  */
435*4882a593Smuzhiyun 
436*4882a593Smuzhiyun #define BFL3_AVVMID_FROM_NVRAM_SHIFT   30   /* Read Av Vmid from NVRAM  */
437*4882a593Smuzhiyun #define BFL3_VLIN_EN_FROM_NVRAM_SHIFT   31   /* Enable Vlin  from NVRAM  */
438*4882a593Smuzhiyun 
439*4882a593Smuzhiyun /* boardflags4 for SROM12/SROM13 */
440*4882a593Smuzhiyun 
441*4882a593Smuzhiyun /* To distinguigh between normal and 4dB pad board */
442*4882a593Smuzhiyun #define BFL4_SROM12_4dBPAD			(1u << 0)
443*4882a593Smuzhiyun 
444*4882a593Smuzhiyun /* Determine power detector type for 2G */
445*4882a593Smuzhiyun #define BFL4_SROM12_2G_DETTYPE			(1u << 1u)
446*4882a593Smuzhiyun 
447*4882a593Smuzhiyun /* Determine power detector type for 5G */
448*4882a593Smuzhiyun #define BFL4_SROM12_5G_DETTYPE			(1u << 2u)
449*4882a593Smuzhiyun 
450*4882a593Smuzhiyun /* using pa_dettype from SROM13 flags */
451*4882a593Smuzhiyun #define BFL4_SROM13_DETTYPE_EN			(1u << 3u)
452*4882a593Smuzhiyun 
453*4882a593Smuzhiyun /* using cck spur reduction setting */
454*4882a593Smuzhiyun #define BFL4_SROM13_CCK_SPUR_EN			(1u << 4u)
455*4882a593Smuzhiyun 
456*4882a593Smuzhiyun /* using 1.5V cbuck board */
457*4882a593Smuzhiyun #define BFL4_SROM13_1P5V_CBUCK			(1u << 7u)
458*4882a593Smuzhiyun 
459*4882a593Smuzhiyun /* Enable/disable bit for sw chain mask */
460*4882a593Smuzhiyun #define BFL4_SROM13_EN_SW_TXRXCHAIN_MASK	(1u << 8u)
461*4882a593Smuzhiyun 
462*4882a593Smuzhiyun #define BFL4_BTCOEX_OVER_SECI	0x00000400u	/* Enable btcoex over gci seci */
463*4882a593Smuzhiyun 
464*4882a593Smuzhiyun /* RFFE rFEM 5G and 2G present bit */
465*4882a593Smuzhiyun #define BFL4_FEM_RFFE		(1u << 21u)
466*4882a593Smuzhiyun 
467*4882a593Smuzhiyun /* papd params */
468*4882a593Smuzhiyun #define PAPD_TX_ATTN_2G 0xFF
469*4882a593Smuzhiyun #define PAPD_TX_ATTN_5G 0xFF00
470*4882a593Smuzhiyun #define PAPD_TX_ATTN_5G_SHIFT 8
471*4882a593Smuzhiyun #define PAPD_RX_ATTN_2G 0xFF
472*4882a593Smuzhiyun #define PAPD_RX_ATTN_5G 0xFF00
473*4882a593Smuzhiyun #define PAPD_RX_ATTN_5G_SHIFT 8
474*4882a593Smuzhiyun #define PAPD_CAL_IDX_2G 0xFF
475*4882a593Smuzhiyun #define PAPD_CAL_IDX_5G 0xFF00
476*4882a593Smuzhiyun #define PAPD_CAL_IDX_5G_SHIFT 8
477*4882a593Smuzhiyun #define PAPD_BBMULT_2G 0xFF
478*4882a593Smuzhiyun #define PAPD_BBMULT_5G 0xFF00
479*4882a593Smuzhiyun #define PAPD_BBMULT_5G_SHIFT 8
480*4882a593Smuzhiyun #define TIA_GAIN_MODE_2G 0xFF
481*4882a593Smuzhiyun #define TIA_GAIN_MODE_5G 0xFF00
482*4882a593Smuzhiyun #define TIA_GAIN_MODE_5G_SHIFT 8
483*4882a593Smuzhiyun #define PAPD_EPS_OFFSET_2G 0xFFFF
484*4882a593Smuzhiyun #define PAPD_EPS_OFFSET_5G 0xFFFF0000
485*4882a593Smuzhiyun #define PAPD_EPS_OFFSET_5G_SHIFT 16
486*4882a593Smuzhiyun #define PAPD_CALREF_DB_2G 0xFF
487*4882a593Smuzhiyun #define PAPD_CALREF_DB_5G 0xFF00
488*4882a593Smuzhiyun #define PAPD_CALREF_DB_5G_SHIFT 8
489*4882a593Smuzhiyun 
490*4882a593Smuzhiyun /* board specific GPIO assignment, gpio 0-3 are also customer-configurable led */
491*4882a593Smuzhiyun #define	BOARD_GPIO_BTC3W_IN	0x850	/* bit 4 is RF_ACTIVE, bit 6 is STATUS, bit 11 is PRI */
492*4882a593Smuzhiyun #define	BOARD_GPIO_BTC3W_OUT	0x020	/* bit 5 is TX_CONF */
493*4882a593Smuzhiyun #define	BOARD_GPIO_BTCMOD_IN	0x010	/* bit 4 is the alternate BT Coexistence Input */
494*4882a593Smuzhiyun #define	BOARD_GPIO_BTCMOD_OUT	0x020	/* bit 5 is the alternate BT Coexistence Out */
495*4882a593Smuzhiyun #define	BOARD_GPIO_BTC_IN	0x080	/* bit 7 is BT Coexistence Input */
496*4882a593Smuzhiyun #define	BOARD_GPIO_BTC_OUT	0x100	/* bit 8 is BT Coexistence Out */
497*4882a593Smuzhiyun #define	BOARD_GPIO_PACTRL	0x200	/* bit 9 controls the PA on new 4306 boards */
498*4882a593Smuzhiyun #define BOARD_GPIO_12		0x1000	/* gpio 12 */
499*4882a593Smuzhiyun #define BOARD_GPIO_13		0x2000	/* gpio 13 */
500*4882a593Smuzhiyun #define BOARD_GPIO_BTC4_IN	0x0800	/* gpio 11, coex4, in */
501*4882a593Smuzhiyun #define BOARD_GPIO_BTC4_BT	0x2000	/* gpio 12, coex4, bt active */
502*4882a593Smuzhiyun #define BOARD_GPIO_BTC4_STAT	0x4000	/* gpio 14, coex4, status */
503*4882a593Smuzhiyun #define BOARD_GPIO_BTC4_WLAN	0x8000	/* gpio 15, coex4, wlan active */
504*4882a593Smuzhiyun #define	BOARD_GPIO_1_WLAN_PWR	0x02	/* throttle WLAN power on X21 board */
505*4882a593Smuzhiyun #define	BOARD_GPIO_2_WLAN_PWR	0x04	/* throttle WLAN power on X29C board */
506*4882a593Smuzhiyun #define	BOARD_GPIO_3_WLAN_PWR	0x08	/* throttle WLAN power on X28 board */
507*4882a593Smuzhiyun #define	BOARD_GPIO_4_WLAN_PWR	0x10	/* throttle WLAN power on X19 board */
508*4882a593Smuzhiyun #define	BOARD_GPIO_13_WLAN_PWR	0x2000	/* throttle WLAN power on X14 board */
509*4882a593Smuzhiyun 
510*4882a593Smuzhiyun #define GPIO_BTC4W_OUT_4312  0x010  /* bit 4 is BT_IODISABLE */
511*4882a593Smuzhiyun 
512*4882a593Smuzhiyun #define	PCI_CFG_GPIO_SCS	0x10	/* PCI config space bit 4 for 4306c0 slow clock source */
513*4882a593Smuzhiyun #define PCI_CFG_GPIO_HWRAD	0x20	/* PCI config space GPIO 13 for hw radio disable */
514*4882a593Smuzhiyun #define PCI_CFG_GPIO_XTAL	0x40	/* PCI config space GPIO 14 for Xtal power-up */
515*4882a593Smuzhiyun #define PCI_CFG_GPIO_PLL	0x80	/* PCI config space GPIO 15 for PLL power-down */
516*4882a593Smuzhiyun 
517*4882a593Smuzhiyun /* need to be moved to a chip specific header file */
518*4882a593Smuzhiyun /* power control defines */
519*4882a593Smuzhiyun #define PLL_DELAY		150		/* us pll on delay */
520*4882a593Smuzhiyun #define FREF_DELAY		200		/* us fref change delay */
521*4882a593Smuzhiyun #define MIN_SLOW_CLK		32		/* us Slow clock period */
522*4882a593Smuzhiyun #define	XTAL_ON_DELAY		1000		/* us crystal power-on delay */
523*4882a593Smuzhiyun 
524*4882a593Smuzhiyun /* Board IDs */
525*4882a593Smuzhiyun 
526*4882a593Smuzhiyun /* Reference Board Types */
527*4882a593Smuzhiyun #define	BU4710_BOARD		0x0400
528*4882a593Smuzhiyun #define	VSIM4710_BOARD		0x0401
529*4882a593Smuzhiyun #define	QT4710_BOARD		0x0402
530*4882a593Smuzhiyun 
531*4882a593Smuzhiyun #define	BCM94710D_BOARD		0x041a
532*4882a593Smuzhiyun #define	BCM94710R1_BOARD	0x041b
533*4882a593Smuzhiyun #define	BCM94710R4_BOARD	0x041c
534*4882a593Smuzhiyun #define	BCM94710AP_BOARD	0x041d
535*4882a593Smuzhiyun 
536*4882a593Smuzhiyun #define	BU2050_BOARD		0x041f
537*4882a593Smuzhiyun 
538*4882a593Smuzhiyun /* BCM4318 boards */
539*4882a593Smuzhiyun #define BU4318_BOARD		0x0447
540*4882a593Smuzhiyun #define CB4318_BOARD		0x0448
541*4882a593Smuzhiyun #define MPG4318_BOARD		0x0449
542*4882a593Smuzhiyun #define MP4318_BOARD		0x044a
543*4882a593Smuzhiyun #define SD4318_BOARD		0x044b
544*4882a593Smuzhiyun #define	BCM94318MPGH_BOARD	0x0463
545*4882a593Smuzhiyun 
546*4882a593Smuzhiyun /* 4321 boards */
547*4882a593Smuzhiyun #define BU4321_BOARD		0x046b
548*4882a593Smuzhiyun #define BU4321E_BOARD		0x047c
549*4882a593Smuzhiyun #define MP4321_BOARD		0x046c
550*4882a593Smuzhiyun #define CB2_4321_BOARD		0x046d
551*4882a593Smuzhiyun #define CB2_4321_AG_BOARD	0x0066
552*4882a593Smuzhiyun #define MC4321_BOARD		0x046e
553*4882a593Smuzhiyun 
554*4882a593Smuzhiyun /* 4360 Boards */
555*4882a593Smuzhiyun #define BCM94360X52C            0X0117
556*4882a593Smuzhiyun #define BCM94360X52D            0X0137
557*4882a593Smuzhiyun #define BCM94360X29C            0X0112
558*4882a593Smuzhiyun #define BCM94360X29CP2          0X0134
559*4882a593Smuzhiyun #define BCM94360X29CP3          0X013B
560*4882a593Smuzhiyun #define BCM94360X51             0x0111
561*4882a593Smuzhiyun #define BCM94360X51P2           0x0129
562*4882a593Smuzhiyun #define BCM94360X51P3           0x0142
563*4882a593Smuzhiyun #define BCM94360X51A            0x0135
564*4882a593Smuzhiyun #define BCM94360X51B            0x0136
565*4882a593Smuzhiyun #define BCM94360CS              0x061B
566*4882a593Smuzhiyun #define BCM94360J28_D11AC2G     0x0c00
567*4882a593Smuzhiyun #define BCM94360J28_D11AC5G     0x0c01
568*4882a593Smuzhiyun #define BCM94360USBH5_D11AC5G   0x06aa
569*4882a593Smuzhiyun #define BCM94360MCM5            0x06d8
570*4882a593Smuzhiyun 
571*4882a593Smuzhiyun /* need to update si_fixup_vid_overrides() for additional platforms */
572*4882a593Smuzhiyun 
573*4882a593Smuzhiyun /* 43012 wlbga Board */
574*4882a593Smuzhiyun #define BCM943012WLREF_SSID	0x07d7
575*4882a593Smuzhiyun 
576*4882a593Smuzhiyun /* 43012 fcbga Board */
577*4882a593Smuzhiyun #define BCM943012FCREF_SSID	0x07d4
578*4882a593Smuzhiyun 
579*4882a593Smuzhiyun /* 43602 Boards, unclear yet what boards will be created. */
580*4882a593Smuzhiyun #define BCM943602RSVD1_SSID	0x06a5
581*4882a593Smuzhiyun #define BCM943602RSVD2_SSID	0x06a6
582*4882a593Smuzhiyun #define BCM943602X87            0X0133
583*4882a593Smuzhiyun #define BCM943602X87P2          0X0152
584*4882a593Smuzhiyun #define BCM943602X87P3          0X0153 /* need to update si_fixup_vid_overrides() */
585*4882a593Smuzhiyun #define BCM943602X238           0X0132
586*4882a593Smuzhiyun #define BCM943602X238D          0X014A
587*4882a593Smuzhiyun #define BCM943602X238DP2        0X0155 /* J117 */
588*4882a593Smuzhiyun #define BCM943602X238DP3        0X0156 /* J94 */
589*4882a593Smuzhiyun #define BCM943602X100           0x0761 /* Dev only */
590*4882a593Smuzhiyun #define BCM943602X100GS         0x0157 /* Woody */
591*4882a593Smuzhiyun #define BCM943602X100P2         0x015A /* Buzz, Zurg */
592*4882a593Smuzhiyun 
593*4882a593Smuzhiyun /* 4375B0 WLCSP SEMCO Board */
594*4882a593Smuzhiyun #define BCM94375B0_WLCSP_SSID	0x086b
595*4882a593Smuzhiyun 
596*4882a593Smuzhiyun /* # of GPIO pins */
597*4882a593Smuzhiyun #define GPIO_NUMPINS		32
598*4882a593Smuzhiyun 
599*4882a593Smuzhiyun /* chip RAM specifications */
600*4882a593Smuzhiyun #define RDL_RAM_SIZE_4360  0xA0000
601*4882a593Smuzhiyun #define RDL_RAM_BASE_4360  0x60000000
602*4882a593Smuzhiyun 
603*4882a593Smuzhiyun /* generic defs for nvram "muxenab" bits
604*4882a593Smuzhiyun * Note: these differ for 4335a0. refer bcmchipc.h for specific mux options.
605*4882a593Smuzhiyun */
606*4882a593Smuzhiyun #define MUXENAB_UART		0x00000001
607*4882a593Smuzhiyun #define MUXENAB_GPIO		0x00000002
608*4882a593Smuzhiyun #define MUXENAB_ERCX		0x00000004	/* External Radio BT coex */
609*4882a593Smuzhiyun #define MUXENAB_JTAG		0x00000008
610*4882a593Smuzhiyun #define MUXENAB_HOST_WAKE	0x00000010	/* configure GPIO for SDIO host_wake */
611*4882a593Smuzhiyun #define MUXENAB_I2S_EN		0x00000020
612*4882a593Smuzhiyun #define MUXENAB_I2S_MASTER	0x00000040
613*4882a593Smuzhiyun #define MUXENAB_I2S_FULL	0x00000080
614*4882a593Smuzhiyun #define MUXENAB_SFLASH		0x00000100
615*4882a593Smuzhiyun #define MUXENAB_RFSWCTRL0	0x00000200
616*4882a593Smuzhiyun #define MUXENAB_RFSWCTRL1	0x00000400
617*4882a593Smuzhiyun #define MUXENAB_RFSWCTRL2	0x00000800
618*4882a593Smuzhiyun #define MUXENAB_SECI		0x00001000
619*4882a593Smuzhiyun #define MUXENAB_BT_LEGACY	0x00002000
620*4882a593Smuzhiyun #define MUXENAB_HOST_WAKE1	0x00004000	/* configure alternative GPIO for SDIO host_wake */
621*4882a593Smuzhiyun 
622*4882a593Smuzhiyun /* Boot flags */
623*4882a593Smuzhiyun #define FLASH_KERNEL_NFLASH	0x00000001
624*4882a593Smuzhiyun #define FLASH_BOOT_NFLASH	0x00000002
625*4882a593Smuzhiyun 
626*4882a593Smuzhiyun #endif /* _BCMDEVS_H */
627