1184610Salfred/*	$OpenBSD: if_zydreg.h,v 1.19 2006/11/30 19:28:07 damien Exp $	*/
2184610Salfred/*	$NetBSD: if_zydreg.h,v 1.2 2007/06/16 11:18:45 kiyohara Exp $	*/
3184610Salfred/*	$FreeBSD: releng/10.3/sys/dev/usb/wlan/if_zydreg.h 269266 2014-07-29 21:59:24Z hselasky $	*/
4184610Salfred
5184610Salfred/*-
6184610Salfred * Copyright (c) 2006 by Damien Bergamini <damien.bergamini@free.fr>
7184610Salfred * Copyright (c) 2006 by Florian Stoehr <ich@florian-stoehr.de>
8184610Salfred *
9184610Salfred * Permission to use, copy, modify, and distribute this software for any
10184610Salfred * purpose with or without fee is hereby granted, provided that the above
11184610Salfred * copyright notice and this permission notice appear in all copies.
12184610Salfred *
13184610Salfred * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
14184610Salfred * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
15184610Salfred * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
16184610Salfred * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
17184610Salfred * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
18184610Salfred * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
19184610Salfred * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
20184610Salfred */
21184610Salfred
22184610Salfred/*
23184610Salfred * ZyDAS ZD1211/ZD1211B USB WLAN driver.
24184610Salfred */
25184610Salfred
26188417Sthompsa#define ZYD_CR_GPI_EN		0x9418
27188417Sthompsa#define ZYD_CR_RADIO_PD		0x942c
28188417Sthompsa#define ZYD_CR_RF2948_PD	0x942c
29188417Sthompsa#define ZYD_CR_EN_PS_MANUAL_AGC	0x943c
30188417Sthompsa#define ZYD_CR_CONFIG_PHILIPS	0x9440
31188417Sthompsa#define ZYD_CR_I2C_WRITE	0x9444
32188417Sthompsa#define ZYD_CR_SA2400_SER_RP	0x9448
33188417Sthompsa#define ZYD_CR_RADIO_PE		0x9458
34188417Sthompsa#define ZYD_CR_RST_BUS_MASTER	0x945c
35188417Sthompsa#define ZYD_CR_RFCFG		0x9464
36188417Sthompsa#define ZYD_CR_HSTSCHG		0x946c
37188417Sthompsa#define ZYD_CR_PHY_ON		0x9474
38188417Sthompsa#define ZYD_CR_RX_DELAY		0x9478
39188417Sthompsa#define ZYD_CR_RX_PE_DELAY	0x947c
40188417Sthompsa#define ZYD_CR_GPIO_1		0x9490
41188417Sthompsa#define ZYD_CR_GPIO_2		0x9494
42188417Sthompsa#define ZYD_CR_EnZYD_CRyBufMux	0x94a8
43188417Sthompsa#define ZYD_CR_PS_CTRL		0x9500
44188417Sthompsa#define ZYD_CR_ADDA_PWR_DWN	0x9504
45188417Sthompsa#define ZYD_CR_ADDA_MBIAS_WT	0x9508
46188417Sthompsa#define ZYD_CR_INTERRUPT	0x9510
47188417Sthompsa#define ZYD_CR_MAC_PS_STATE	0x950c
48188417Sthompsa#define ZYD_CR_ATIM_WND_PERIOD	0x951c
49188417Sthompsa#define ZYD_CR_BCN_INTERVAL	0x9520
50188417Sthompsa#define ZYD_CR_PRE_TBTT		0x9524
51184610Salfred
52184610Salfred/*
53184610Salfred * MAC registers.
54184610Salfred */
55188417Sthompsa#define ZYD_MAC_MACADRL		0x9610 /* MAC address (low) */
56188417Sthompsa#define ZYD_MAC_MACADRH		0x9614 /* MAC address (high) */
57188417Sthompsa#define ZYD_MAC_BSSADRL		0x9618 /* BSS address (low) */
58188417Sthompsa#define ZYD_MAC_BSSADRH		0x961c /* BSS address (high) */
59188417Sthompsa#define ZYD_MAC_BCNCFG		0x9620 /* BCN configuration */
60188417Sthompsa#define ZYD_MAC_GHTBL		0x9624 /* Group hash table (low) */
61188417Sthompsa#define ZYD_MAC_GHTBH		0x9628 /* Group hash table (high) */
62188417Sthompsa#define ZYD_MAC_RX_TIMEOUT	0x962c /* Rx timeout value */
63188417Sthompsa#define ZYD_MAC_BAS_RATE	0x9630 /* Basic rate setting */
64188417Sthompsa#define ZYD_MAC_MAN_RATE	0x9634 /* Mandatory rate setting */
65188417Sthompsa#define ZYD_MAC_RTSCTSRATE	0x9638 /* RTS CTS rate */
66188417Sthompsa#define ZYD_MAC_BACKOFF_PROTECT	0x963c /* Backoff protection */
67188417Sthompsa#define ZYD_MAC_RX_THRESHOLD	0x9640 /* Rx threshold */
68188417Sthompsa#define ZYD_MAC_TX_PE_CONTROL	0x9644 /* Tx_PE control */
69188417Sthompsa#define ZYD_MAC_AFTER_PNP	0x9648 /* After PnP */
70188417Sthompsa#define ZYD_MAC_RX_PE_DELAY	0x964c /* Rx_pe delay */
71188417Sthompsa#define ZYD_MAC_RX_ADDR2_L	0x9650 /* RX address2 (low)    */
72188417Sthompsa#define ZYD_MAC_RX_ADDR2_H	0x9654 /* RX address2 (high) */
73188417Sthompsa#define ZYD_MAC_SIFS_ACK_TIME	0x9658 /* Dynamic SIFS ack time */
74188417Sthompsa#define ZYD_MAC_PHY_DELAY	0x9660 /* PHY delay */
75188417Sthompsa#define ZYD_MAC_PHY_DELAY2	0x966c /* PHY delay */
76188417Sthompsa#define ZYD_MAC_BCNFIFO		0x9670 /* Beacon FIFO I/O port */
77188417Sthompsa#define ZYD_MAC_SNIFFER		0x9674 /* Sniffer on/off */
78188417Sthompsa#define ZYD_MAC_ENCRYPTION_TYPE 0x9678 /* Encryption type */
79188417Sthompsa#define ZYD_MAC_RETRY		0x967c /* Retry time */
80188417Sthompsa#define ZYD_MAC_MISC		0x9680 /* Misc */
81188417Sthompsa#define ZYD_MAC_STMACHINESTAT	0x9684 /* State machine status */
82188417Sthompsa#define ZYD_MAC_TX_UNDERRUN_CNT	0x9688 /* TX underrun counter */
83188417Sthompsa#define ZYD_MAC_RXFILTER	0x968c /* Send to host settings */
84188417Sthompsa#define ZYD_MAC_ACK_EXT		0x9690 /* Acknowledge extension */
85188417Sthompsa#define ZYD_MAC_BCNFIFOST	0x9694 /* BCN FIFO set and status */
86188417Sthompsa#define ZYD_MAC_DIFS_EIFS_SIFS	0x9698 /* DIFS, EIFS & SIFS settings */
87188417Sthompsa#define ZYD_MAC_RX_TIMEOUT_CNT	0x969c /* RX timeout count */
88188417Sthompsa#define ZYD_MAC_RX_TOTAL_FRAME	0x96a0 /* RX total frame count */
89188417Sthompsa#define ZYD_MAC_RX_CRC32_CNT	0x96a4 /* RX CRC32 frame count */
90188417Sthompsa#define ZYD_MAC_RX_CRC16_CNT	0x96a8 /* RX CRC16 frame count */
91188417Sthompsa#define ZYD_MAC_RX_UDEC		0x96ac /* RX unicast decr. error count */
92188417Sthompsa#define ZYD_MAC_RX_OVERRUN_CNT	0x96b0 /* RX FIFO overrun count */
93188417Sthompsa#define ZYD_MAC_RX_MDEC		0x96bc /* RX multicast decr. err. cnt. */
94188417Sthompsa#define ZYD_MAC_NAV_TCR		0x96c4 /* NAV timer count read */
95188417Sthompsa#define ZYD_MAC_BACKOFF_ST_RD	0x96c8 /* Backoff status read */
96188417Sthompsa#define ZYD_MAC_DM_RETRY_CNT_RD	0x96cc /* DM retry count read */
97188417Sthompsa#define ZYD_MAC_RX_ACR		0x96d0 /* RX arbitration count read    */
98188417Sthompsa#define ZYD_MAC_TX_CCR		0x96d4 /* Tx complete count read */
99188417Sthompsa#define ZYD_MAC_TCB_ADDR	0x96e8 /* Current PCI process TCP addr */
100188417Sthompsa#define ZYD_MAC_RCB_ADDR	0x96ec /* Next RCB address */
101188417Sthompsa#define ZYD_MAC_CONT_WIN_LIMIT	0x96f0 /* Contention window limit */
102188417Sthompsa#define ZYD_MAC_TX_PKT		0x96f4 /* Tx total packet count read */
103188417Sthompsa#define ZYD_MAC_DL_CTRL		0x96f8 /* Download control */
104188417Sthompsa#define ZYD_MAC_CAM_MODE	0x9700 /* CAM: Continuous Access Mode */
105188417Sthompsa#define ZYD_MACB_TXPWR_CTL1	0x9b00
106188417Sthompsa#define ZYD_MACB_TXPWR_CTL2	0x9b04
107188417Sthompsa#define ZYD_MACB_TXPWR_CTL3	0x9b08
108188417Sthompsa#define ZYD_MACB_TXPWR_CTL4	0x9b0c
109188417Sthompsa#define ZYD_MACB_AIFS_CTL1	0x9b10
110188417Sthompsa#define ZYD_MACB_AIFS_CTL2	0x9b14
111188417Sthompsa#define ZYD_MACB_TXOP		0x9b20
112188417Sthompsa#define ZYD_MACB_MAX_RETRY	0x9b28
113184610Salfred
114184610Salfred/*
115249584Sgabor * Miscellaneous registers.
116184610Salfred */
117188417Sthompsa#define ZYD_FIRMWARE_START_ADDR	0xee00
118188417Sthompsa#define ZYD_FIRMWARE_BASE_ADDR	0xee1d /* Firmware base address */
119184610Salfred
120184610Salfred/*
121184610Salfred * EEPROM registers.
122184610Salfred */
123188417Sthompsa#define ZYD_EEPROM_START_HEAD	0xf800 /* EEPROM start */
124188417Sthompsa#define ZYD_EEPROM_SUBID	0xf817
125188417Sthompsa#define ZYD_EEPROM_POD		0xf819
126188417Sthompsa#define ZYD_EEPROM_MAC_ADDR_P1	0xf81b /* Part 1 of the MAC address */
127188417Sthompsa#define ZYD_EEPROM_MAC_ADDR_P2	0xf81d /* Part 2 of the MAC address */
128188417Sthompsa#define ZYD_EEPROM_PWR_CAL	0xf81f /* Calibration */
129188417Sthompsa#define ZYD_EEPROM_PWR_INT	0xf827 /* Calibration */
130188417Sthompsa#define ZYD_EEPROM_ALLOWEDCHAN	0xf82f /* Allowed CH mask, 1 bit each */
131188417Sthompsa#define ZYD_EEPROM_DEVICE_VER	0xf837 /* Device version */
132188417Sthompsa#define ZYD_EEPROM_PHY_REG	0xf83c /* PHY registers */
133188417Sthompsa#define ZYD_EEPROM_36M_CAL	0xf83f /* Calibration */
134188417Sthompsa#define ZYD_EEPROM_11A_INT	0xf847 /* Interpolation */
135188417Sthompsa#define ZYD_EEPROM_48M_CAL	0xf84f /* Calibration */
136188417Sthompsa#define ZYD_EEPROM_48M_INT	0xf857 /* Interpolation */
137188417Sthompsa#define ZYD_EEPROM_54M_CAL	0xf85f /* Calibration */
138188417Sthompsa#define ZYD_EEPROM_54M_INT	0xf867 /* Interpolation */
139184610Salfred
140184610Salfred/*
141184610Salfred * Firmware registers offsets (relative to fwbase).
142184610Salfred */
143188417Sthompsa#define ZYD_FW_FIRMWARE_REV	0x0000 /* Firmware version */
144188417Sthompsa#define ZYD_FW_USB_SPEED	0x0001 /* USB speed (!=0 if highspeed) */
145188417Sthompsa#define ZYD_FW_FIX_TX_RATE	0x0002 /* Fixed TX rate */
146188417Sthompsa#define ZYD_FW_LINK_STATUS	0x0003
147188417Sthompsa#define ZYD_FW_SOFT_RESET	0x0004
148188417Sthompsa#define ZYD_FW_FLASH_CHK	0x0005
149184610Salfred
150184610Salfred/* possible flags for register ZYD_FW_LINK_STATUS */
151188417Sthompsa#define ZYD_LED1		(1 << 8)
152188417Sthompsa#define ZYD_LED2		(1 << 9)
153184610Salfred
154184610Salfred/*
155184610Salfred * RF IDs.
156184610Salfred */
157188417Sthompsa#define ZYD_RF_UW2451		0x2	/* not supported yet */
158188417Sthompsa#define ZYD_RF_UCHIP		0x3	/* not supported yet */
159188417Sthompsa#define ZYD_RF_AL2230		0x4
160188417Sthompsa#define ZYD_RF_AL7230B		0x5
161188417Sthompsa#define ZYD_RF_THETA		0x6	/* not supported yet */
162188417Sthompsa#define ZYD_RF_AL2210		0x7
163188417Sthompsa#define ZYD_RF_MAXIM_NEW	0x8
164188417Sthompsa#define ZYD_RF_GCT		0x9
165188417Sthompsa#define ZYD_RF_AL2230S		0xa	/* not supported yet */
166188417Sthompsa#define ZYD_RF_RALINK		0xb	/* not supported yet */
167188417Sthompsa#define ZYD_RF_INTERSIL		0xc	/* not supported yet */
168188417Sthompsa#define ZYD_RF_RFMD		0xd
169188417Sthompsa#define ZYD_RF_MAXIM_NEW2	0xe
170188417Sthompsa#define ZYD_RF_PHILIPS		0xf	/* not supported yet */
171184610Salfred
172184610Salfred/*
173184610Salfred * PHY registers (8 bits, not documented).
174184610Salfred */
175188417Sthompsa#define ZYD_CR0			0x9000
176188417Sthompsa#define ZYD_CR1			0x9004
177188417Sthompsa#define ZYD_CR2			0x9008
178188417Sthompsa#define ZYD_CR3			0x900c
179188417Sthompsa#define ZYD_CR5			0x9010
180188417Sthompsa#define ZYD_CR6			0x9014
181188417Sthompsa#define ZYD_CR7			0x9018
182188417Sthompsa#define ZYD_CR8			0x901c
183188417Sthompsa#define ZYD_CR4			0x9020
184188417Sthompsa#define ZYD_CR9			0x9024
185188417Sthompsa#define ZYD_CR10		0x9028
186188417Sthompsa#define ZYD_CR11		0x902c
187188417Sthompsa#define ZYD_CR12		0x9030
188188417Sthompsa#define ZYD_CR13		0x9034
189188417Sthompsa#define ZYD_CR14		0x9038
190188417Sthompsa#define ZYD_CR15		0x903c
191188417Sthompsa#define ZYD_CR16		0x9040
192188417Sthompsa#define ZYD_CR17		0x9044
193188417Sthompsa#define ZYD_CR18		0x9048
194188417Sthompsa#define ZYD_CR19		0x904c
195188417Sthompsa#define ZYD_CR20		0x9050
196188417Sthompsa#define ZYD_CR21		0x9054
197188417Sthompsa#define ZYD_CR22		0x9058
198188417Sthompsa#define ZYD_CR23		0x905c
199188417Sthompsa#define ZYD_CR24		0x9060
200188417Sthompsa#define ZYD_CR25		0x9064
201188417Sthompsa#define ZYD_CR26		0x9068
202188417Sthompsa#define ZYD_CR27		0x906c
203188417Sthompsa#define ZYD_CR28		0x9070
204188417Sthompsa#define ZYD_CR29		0x9074
205188417Sthompsa#define ZYD_CR30		0x9078
206188417Sthompsa#define ZYD_CR31		0x907c
207188417Sthompsa#define ZYD_CR32		0x9080
208188417Sthompsa#define ZYD_CR33		0x9084
209188417Sthompsa#define ZYD_CR34		0x9088
210188417Sthompsa#define ZYD_CR35		0x908c
211188417Sthompsa#define ZYD_CR36		0x9090
212188417Sthompsa#define ZYD_CR37		0x9094
213188417Sthompsa#define ZYD_CR38		0x9098
214188417Sthompsa#define ZYD_CR39		0x909c
215188417Sthompsa#define ZYD_CR40		0x90a0
216188417Sthompsa#define ZYD_CR41		0x90a4
217188417Sthompsa#define ZYD_CR42		0x90a8
218188417Sthompsa#define ZYD_CR43		0x90ac
219188417Sthompsa#define ZYD_CR44		0x90b0
220188417Sthompsa#define ZYD_CR45		0x90b4
221188417Sthompsa#define ZYD_CR46		0x90b8
222188417Sthompsa#define ZYD_CR47		0x90bc
223188417Sthompsa#define ZYD_CR48		0x90c0
224188417Sthompsa#define ZYD_CR49		0x90c4
225188417Sthompsa#define ZYD_CR50		0x90c8
226188417Sthompsa#define ZYD_CR51		0x90cc
227188417Sthompsa#define ZYD_CR52		0x90d0
228188417Sthompsa#define ZYD_CR53		0x90d4
229188417Sthompsa#define ZYD_CR54		0x90d8
230188417Sthompsa#define ZYD_CR55		0x90dc
231188417Sthompsa#define ZYD_CR56		0x90e0
232188417Sthompsa#define ZYD_CR57		0x90e4
233188417Sthompsa#define ZYD_CR58		0x90e8
234188417Sthompsa#define ZYD_CR59		0x90ec
235188417Sthompsa#define ZYD_CR60		0x90f0
236188417Sthompsa#define ZYD_CR61		0x90f4
237188417Sthompsa#define ZYD_CR62		0x90f8
238188417Sthompsa#define ZYD_CR63		0x90fc
239188417Sthompsa#define ZYD_CR64		0x9100
240188417Sthompsa#define ZYD_CR65		0x9104
241188417Sthompsa#define ZYD_CR66		0x9108
242188417Sthompsa#define ZYD_CR67		0x910c
243188417Sthompsa#define ZYD_CR68		0x9110
244188417Sthompsa#define ZYD_CR69		0x9114
245188417Sthompsa#define ZYD_CR70		0x9118
246188417Sthompsa#define ZYD_CR71		0x911c
247188417Sthompsa#define ZYD_CR72		0x9120
248188417Sthompsa#define ZYD_CR73		0x9124
249188417Sthompsa#define ZYD_CR74		0x9128
250188417Sthompsa#define ZYD_CR75		0x912c
251188417Sthompsa#define ZYD_CR76		0x9130
252188417Sthompsa#define ZYD_CR77		0x9134
253188417Sthompsa#define ZYD_CR78		0x9138
254188417Sthompsa#define ZYD_CR79		0x913c
255188417Sthompsa#define ZYD_CR80		0x9140
256188417Sthompsa#define ZYD_CR81		0x9144
257188417Sthompsa#define ZYD_CR82		0x9148
258188417Sthompsa#define ZYD_CR83		0x914c
259188417Sthompsa#define ZYD_CR84		0x9150
260188417Sthompsa#define ZYD_CR85		0x9154
261188417Sthompsa#define ZYD_CR86		0x9158
262188417Sthompsa#define ZYD_CR87		0x915c
263188417Sthompsa#define ZYD_CR88		0x9160
264188417Sthompsa#define ZYD_CR89		0x9164
265188417Sthompsa#define ZYD_CR90		0x9168
266188417Sthompsa#define ZYD_CR91		0x916c
267188417Sthompsa#define ZYD_CR92		0x9170
268188417Sthompsa#define ZYD_CR93		0x9174
269188417Sthompsa#define ZYD_CR94		0x9178
270188417Sthompsa#define ZYD_CR95		0x917c
271188417Sthompsa#define ZYD_CR96		0x9180
272188417Sthompsa#define ZYD_CR97		0x9184
273188417Sthompsa#define ZYD_CR98		0x9188
274188417Sthompsa#define ZYD_CR99		0x918c
275188417Sthompsa#define ZYD_CR100		0x9190
276188417Sthompsa#define ZYD_CR101		0x9194
277188417Sthompsa#define ZYD_CR102		0x9198
278188417Sthompsa#define ZYD_CR103		0x919c
279188417Sthompsa#define ZYD_CR104		0x91a0
280188417Sthompsa#define ZYD_CR105		0x91a4
281188417Sthompsa#define ZYD_CR106		0x91a8
282188417Sthompsa#define ZYD_CR107		0x91ac
283188417Sthompsa#define ZYD_CR108		0x91b0
284188417Sthompsa#define ZYD_CR109		0x91b4
285188417Sthompsa#define ZYD_CR110		0x91b8
286188417Sthompsa#define ZYD_CR111		0x91bc
287188417Sthompsa#define ZYD_CR112		0x91c0
288188417Sthompsa#define ZYD_CR113		0x91c4
289188417Sthompsa#define ZYD_CR114		0x91c8
290188417Sthompsa#define ZYD_CR115		0x91cc
291188417Sthompsa#define ZYD_CR116		0x91d0
292188417Sthompsa#define ZYD_CR117		0x91d4
293188417Sthompsa#define ZYD_CR118		0x91d8
294188417Sthompsa#define ZYD_CR119		0x91dc
295188417Sthompsa#define ZYD_CR120		0x91e0
296188417Sthompsa#define ZYD_CR121		0x91e4
297188417Sthompsa#define ZYD_CR122		0x91e8
298188417Sthompsa#define ZYD_CR123		0x91ec
299188417Sthompsa#define ZYD_CR124		0x91f0
300188417Sthompsa#define ZYD_CR125		0x91f4
301188417Sthompsa#define ZYD_CR126		0x91f8
302188417Sthompsa#define ZYD_CR127		0x91fc
303188417Sthompsa#define ZYD_CR128		0x9200
304188417Sthompsa#define ZYD_CR129		0x9204
305188417Sthompsa#define ZYD_CR130		0x9208
306188417Sthompsa#define ZYD_CR131		0x920c
307188417Sthompsa#define ZYD_CR132		0x9210
308188417Sthompsa#define ZYD_CR133		0x9214
309188417Sthompsa#define ZYD_CR134		0x9218
310188417Sthompsa#define ZYD_CR135		0x921c
311188417Sthompsa#define ZYD_CR136		0x9220
312188417Sthompsa#define ZYD_CR137		0x9224
313188417Sthompsa#define ZYD_CR138		0x9228
314188417Sthompsa#define ZYD_CR139		0x922c
315188417Sthompsa#define ZYD_CR140		0x9230
316188417Sthompsa#define ZYD_CR141		0x9234
317188417Sthompsa#define ZYD_CR142		0x9238
318188417Sthompsa#define ZYD_CR143		0x923c
319188417Sthompsa#define ZYD_CR144		0x9240
320188417Sthompsa#define ZYD_CR145		0x9244
321188417Sthompsa#define ZYD_CR146		0x9248
322188417Sthompsa#define ZYD_CR147		0x924c
323188417Sthompsa#define ZYD_CR148		0x9250
324188417Sthompsa#define ZYD_CR149		0x9254
325188417Sthompsa#define ZYD_CR150		0x9258
326188417Sthompsa#define ZYD_CR151		0x925c
327188417Sthompsa#define ZYD_CR152		0x9260
328188417Sthompsa#define ZYD_CR153		0x9264
329188417Sthompsa#define ZYD_CR154		0x9268
330188417Sthompsa#define ZYD_CR155		0x926c
331188417Sthompsa#define ZYD_CR156		0x9270
332188417Sthompsa#define ZYD_CR157		0x9274
333188417Sthompsa#define ZYD_CR158		0x9278
334188417Sthompsa#define ZYD_CR159		0x927c
335188417Sthompsa#define ZYD_CR160		0x9280
336188417Sthompsa#define ZYD_CR161		0x9284
337188417Sthompsa#define ZYD_CR162		0x9288
338188417Sthompsa#define ZYD_CR163		0x928c
339188417Sthompsa#define ZYD_CR164		0x9290
340188417Sthompsa#define ZYD_CR165		0x9294
341188417Sthompsa#define ZYD_CR166		0x9298
342188417Sthompsa#define ZYD_CR167		0x929c
343188417Sthompsa#define ZYD_CR168		0x92a0
344188417Sthompsa#define ZYD_CR169		0x92a4
345188417Sthompsa#define ZYD_CR170		0x92a8
346188417Sthompsa#define ZYD_CR171		0x92ac
347188417Sthompsa#define ZYD_CR172		0x92b0
348188417Sthompsa#define ZYD_CR173		0x92b4
349188417Sthompsa#define ZYD_CR174		0x92b8
350188417Sthompsa#define ZYD_CR175		0x92bc
351188417Sthompsa#define ZYD_CR176		0x92c0
352188417Sthompsa#define ZYD_CR177		0x92c4
353188417Sthompsa#define ZYD_CR178		0x92c8
354188417Sthompsa#define ZYD_CR179		0x92cc
355188417Sthompsa#define ZYD_CR180		0x92d0
356188417Sthompsa#define ZYD_CR181		0x92d4
357188417Sthompsa#define ZYD_CR182		0x92d8
358188417Sthompsa#define ZYD_CR183		0x92dc
359188417Sthompsa#define ZYD_CR184		0x92e0
360188417Sthompsa#define ZYD_CR185		0x92e4
361188417Sthompsa#define ZYD_CR186		0x92e8
362188417Sthompsa#define ZYD_CR187		0x92ec
363188417Sthompsa#define ZYD_CR188		0x92f0
364188417Sthompsa#define ZYD_CR189		0x92f4
365188417Sthompsa#define ZYD_CR190		0x92f8
366188417Sthompsa#define ZYD_CR191		0x92fc
367188417Sthompsa#define ZYD_CR192		0x9300
368188417Sthompsa#define ZYD_CR193		0x9304
369188417Sthompsa#define ZYD_CR194		0x9308
370188417Sthompsa#define ZYD_CR195		0x930c
371188417Sthompsa#define ZYD_CR196		0x9310
372188417Sthompsa#define ZYD_CR197		0x9314
373188417Sthompsa#define ZYD_CR198		0x9318
374188417Sthompsa#define ZYD_CR199		0x931c
375188417Sthompsa#define ZYD_CR200		0x9320
376188417Sthompsa#define ZYD_CR201		0x9324
377188417Sthompsa#define ZYD_CR202		0x9328
378188417Sthompsa#define ZYD_CR203		0x932c
379188417Sthompsa#define ZYD_CR204		0x9330
380188417Sthompsa#define ZYD_CR205		0x9334
381188417Sthompsa#define ZYD_CR206		0x9338
382188417Sthompsa#define ZYD_CR207		0x933c
383188417Sthompsa#define ZYD_CR208		0x9340
384188417Sthompsa#define ZYD_CR209		0x9344
385188417Sthompsa#define ZYD_CR210		0x9348
386188417Sthompsa#define ZYD_CR211		0x934c
387188417Sthompsa#define ZYD_CR212		0x9350
388188417Sthompsa#define ZYD_CR213		0x9354
389188417Sthompsa#define ZYD_CR214		0x9358
390188417Sthompsa#define ZYD_CR215		0x935c
391188417Sthompsa#define ZYD_CR216		0x9360
392188417Sthompsa#define ZYD_CR217		0x9364
393188417Sthompsa#define ZYD_CR218		0x9368
394188417Sthompsa#define ZYD_CR219		0x936c
395188417Sthompsa#define ZYD_CR220		0x9370
396188417Sthompsa#define ZYD_CR221		0x9374
397188417Sthompsa#define ZYD_CR222		0x9378
398188417Sthompsa#define ZYD_CR223		0x937c
399188417Sthompsa#define ZYD_CR224		0x9380
400188417Sthompsa#define ZYD_CR225		0x9384
401188417Sthompsa#define ZYD_CR226		0x9388
402188417Sthompsa#define ZYD_CR227		0x938c
403188417Sthompsa#define ZYD_CR228		0x9390
404188417Sthompsa#define ZYD_CR229		0x9394
405188417Sthompsa#define ZYD_CR230		0x9398
406188417Sthompsa#define ZYD_CR231		0x939c
407188417Sthompsa#define ZYD_CR232		0x93a0
408188417Sthompsa#define ZYD_CR233		0x93a4
409188417Sthompsa#define ZYD_CR234		0x93a8
410188417Sthompsa#define ZYD_CR235		0x93ac
411188417Sthompsa#define ZYD_CR236		0x93b0
412188417Sthompsa#define ZYD_CR240		0x93c0
413188417Sthompsa#define ZYD_CR241		0x93c4
414188417Sthompsa#define ZYD_CR242		0x93c8
415188417Sthompsa#define ZYD_CR243		0x93cc
416188417Sthompsa#define ZYD_CR244		0x93d0
417188417Sthompsa#define ZYD_CR245		0x93d4
418188417Sthompsa#define ZYD_CR251		0x93ec
419188417Sthompsa#define ZYD_CR252		0x93f0
420188417Sthompsa#define ZYD_CR253		0x93f4
421188417Sthompsa#define ZYD_CR254		0x93f8
422188417Sthompsa#define ZYD_CR255		0x93fc
423184610Salfred
424184610Salfred/* copied nearly verbatim from the Linux driver rewrite */
425184610Salfred#define	ZYD_DEF_PHY							\
426184610Salfred{									\
427184610Salfred	{ ZYD_CR0,   0x0a }, { ZYD_CR1,   0x06 }, { ZYD_CR2,   0x26 },	\
428184610Salfred	{ ZYD_CR3,   0x38 }, { ZYD_CR4,   0x80 }, { ZYD_CR9,   0xa0 },	\
429184610Salfred	{ ZYD_CR10,  0x81 }, { ZYD_CR11,  0x00 }, { ZYD_CR12,  0x7f },	\
430184610Salfred	{ ZYD_CR13,  0x8c }, { ZYD_CR14,  0x80 }, { ZYD_CR15,  0x3d },	\
431184610Salfred	{ ZYD_CR16,  0x20 }, { ZYD_CR17,  0x1e }, { ZYD_CR18,  0x0a },	\
432184610Salfred	{ ZYD_CR19,  0x48 }, { ZYD_CR20,  0x0c }, { ZYD_CR21,  0x0c },	\
433184610Salfred	{ ZYD_CR22,  0x23 }, { ZYD_CR23,  0x90 }, { ZYD_CR24,  0x14 },	\
434184610Salfred	{ ZYD_CR25,  0x40 }, { ZYD_CR26,  0x10 }, { ZYD_CR27,  0x19 },	\
435184610Salfred	{ ZYD_CR28,  0x7f }, { ZYD_CR29,  0x80 }, { ZYD_CR30,  0x4b },	\
436184610Salfred	{ ZYD_CR31,  0x60 }, { ZYD_CR32,  0x43 }, { ZYD_CR33,  0x08 },	\
437184610Salfred	{ ZYD_CR34,  0x06 }, { ZYD_CR35,  0x0a }, { ZYD_CR36,  0x00 },	\
438184610Salfred	{ ZYD_CR37,  0x00 }, { ZYD_CR38,  0x38 }, { ZYD_CR39,  0x0c },	\
439184610Salfred	{ ZYD_CR40,  0x84 }, { ZYD_CR41,  0x2a }, { ZYD_CR42,  0x80 },	\
440184610Salfred	{ ZYD_CR43,  0x10 }, { ZYD_CR44,  0x12 }, { ZYD_CR46,  0xff },	\
441186730Salfred	{ ZYD_CR47,  0x1e }, { ZYD_CR48,  0x26 }, { ZYD_CR49,  0x5b },	\
442184610Salfred	{ ZYD_CR64,  0xd0 }, { ZYD_CR65,  0x04 }, { ZYD_CR66,  0x58 },	\
443184610Salfred	{ ZYD_CR67,  0xc9 }, { ZYD_CR68,  0x88 }, { ZYD_CR69,  0x41 },	\
444184610Salfred	{ ZYD_CR70,  0x23 }, { ZYD_CR71,  0x10 }, { ZYD_CR72,  0xff },	\
445184610Salfred	{ ZYD_CR73,  0x32 }, { ZYD_CR74,  0x30 }, { ZYD_CR75,  0x65 },	\
446184610Salfred	{ ZYD_CR76,  0x41 }, { ZYD_CR77,  0x1b }, { ZYD_CR78,  0x30 },	\
447184610Salfred	{ ZYD_CR79,  0x68 }, { ZYD_CR80,  0x64 }, { ZYD_CR81,  0x64 },	\
448184610Salfred	{ ZYD_CR82,  0x00 }, { ZYD_CR83,  0x00 }, { ZYD_CR84,  0x00 },	\
449184610Salfred	{ ZYD_CR85,  0x02 }, { ZYD_CR86,  0x00 }, { ZYD_CR87,  0x00 },	\
450184610Salfred	{ ZYD_CR88,  0xff }, { ZYD_CR89,  0xfc }, { ZYD_CR90,  0x00 },	\
451184610Salfred	{ ZYD_CR91,  0x00 }, { ZYD_CR92,  0x00 }, { ZYD_CR93,  0x08 },	\
452184610Salfred	{ ZYD_CR94,  0x00 }, { ZYD_CR95,  0x00 }, { ZYD_CR96,  0xff },	\
453184610Salfred	{ ZYD_CR97,  0xe7 }, { ZYD_CR98,  0x00 }, { ZYD_CR99,  0x00 },	\
454184610Salfred	{ ZYD_CR100, 0x00 }, { ZYD_CR101, 0xae }, { ZYD_CR102, 0x02 },	\
455184610Salfred	{ ZYD_CR103, 0x00 }, { ZYD_CR104, 0x03 }, { ZYD_CR105, 0x65 },	\
456184610Salfred	{ ZYD_CR106, 0x04 }, { ZYD_CR107, 0x00 }, { ZYD_CR108, 0x0a },	\
457184610Salfred	{ ZYD_CR109, 0xaa }, { ZYD_CR110, 0xaa }, { ZYD_CR111, 0x25 },	\
458184610Salfred	{ ZYD_CR112, 0x25 }, { ZYD_CR113, 0x00 }, { ZYD_CR119, 0x1e },	\
459184610Salfred	{ ZYD_CR125, 0x90 }, { ZYD_CR126, 0x00 }, { ZYD_CR127, 0x00 },	\
460184610Salfred	{ ZYD_CR5,   0x00 }, { ZYD_CR6,   0x00 }, { ZYD_CR7,   0x00 },	\
461184610Salfred	{ ZYD_CR8,   0x00 }, { ZYD_CR9,   0x20 }, { ZYD_CR12,  0xf0 },	\
462184610Salfred	{ ZYD_CR20,  0x0e }, { ZYD_CR21,  0x0e }, { ZYD_CR27,  0x10 },	\
463186730Salfred	{ ZYD_CR44,  0x33 }, { ZYD_CR47,  0x1E }, { ZYD_CR83,  0x24 },	\
464184610Salfred	{ ZYD_CR84,  0x04 }, { ZYD_CR85,  0x00 }, { ZYD_CR86,  0x0C },	\
465184610Salfred	{ ZYD_CR87,  0x12 }, { ZYD_CR88,  0x0C }, { ZYD_CR89,  0x00 },	\
466184610Salfred	{ ZYD_CR90,  0x10 }, { ZYD_CR91,  0x08 }, { ZYD_CR93,  0x00 },	\
467184610Salfred	{ ZYD_CR94,  0x01 }, { ZYD_CR95,  0x00 }, { ZYD_CR96,  0x50 },	\
468184610Salfred	{ ZYD_CR97,  0x37 }, { ZYD_CR98,  0x35 }, { ZYD_CR101, 0x13 },	\
469184610Salfred	{ ZYD_CR102, 0x27 }, { ZYD_CR103, 0x27 }, { ZYD_CR104, 0x18 },	\
470184610Salfred	{ ZYD_CR105, 0x12 }, { ZYD_CR109, 0x27 }, { ZYD_CR110, 0x27 },	\
471184610Salfred	{ ZYD_CR111, 0x27 }, { ZYD_CR112, 0x27 }, { ZYD_CR113, 0x27 },	\
472184610Salfred	{ ZYD_CR114, 0x27 }, { ZYD_CR115, 0x26 }, { ZYD_CR116, 0x24 },	\
473184610Salfred	{ ZYD_CR117, 0xfc }, { ZYD_CR118, 0xfa }, { ZYD_CR120, 0x4f },	\
474186730Salfred	{ ZYD_CR125, 0xaa }, { ZYD_CR127, 0x03 }, { ZYD_CR128, 0x14 },	\
475186730Salfred	{ ZYD_CR129, 0x12 }, { ZYD_CR130, 0x10 }, { ZYD_CR131, 0x0C },	\
476186730Salfred	{ ZYD_CR136, 0xdf }, { ZYD_CR137, 0x40 }, { ZYD_CR138, 0xa0 },	\
477186730Salfred	{ ZYD_CR139, 0xb0 }, { ZYD_CR140, 0x99 }, { ZYD_CR141, 0x82 },	\
478186730Salfred	{ ZYD_CR142, 0x54 }, { ZYD_CR143, 0x1c }, { ZYD_CR144, 0x6c },	\
479186730Salfred	{ ZYD_CR147, 0x07 }, { ZYD_CR148, 0x4c }, { ZYD_CR149, 0x50 },	\
480186730Salfred	{ ZYD_CR150, 0x0e }, { ZYD_CR151, 0x18 }, { ZYD_CR160, 0xfe },	\
481186730Salfred	{ ZYD_CR161, 0xee }, { ZYD_CR162, 0xaa }, { ZYD_CR163, 0xfa },	\
482186730Salfred	{ ZYD_CR164, 0xfa }, { ZYD_CR165, 0xea }, { ZYD_CR166, 0xbe },	\
483186730Salfred	{ ZYD_CR167, 0xbe }, { ZYD_CR168, 0x6a }, { ZYD_CR169, 0xba },	\
484186730Salfred	{ ZYD_CR170, 0xba }, { ZYD_CR171, 0xba }, { ZYD_CR204, 0x7d },	\
485186730Salfred	{ ZYD_CR203, 0x30 }, { 0, 0}					\
486184610Salfred}
487184610Salfred
488188417Sthompsa#define ZYD_DEF_PHYB							\
489184610Salfred{									\
490184610Salfred	{ ZYD_CR0,   0x14 }, { ZYD_CR1,   0x06 }, { ZYD_CR2,   0x26 },	\
491184610Salfred	{ ZYD_CR3,   0x38 }, { ZYD_CR4,   0x80 }, { ZYD_CR9,   0xe0 },	\
492184610Salfred	{ ZYD_CR10,  0x81 }, { ZYD_CR11,  0x00 }, { ZYD_CR12,  0xf0 },	\
493184610Salfred	{ ZYD_CR13,  0x8c }, { ZYD_CR14,  0x80 }, { ZYD_CR15,  0x3d },	\
494184610Salfred	{ ZYD_CR16,  0x20 }, { ZYD_CR17,  0x1e }, { ZYD_CR18,  0x0a },	\
495184610Salfred	{ ZYD_CR19,  0x48 }, { ZYD_CR20,  0x10 }, { ZYD_CR21,  0x0e },	\
496184610Salfred	{ ZYD_CR22,  0x23 }, { ZYD_CR23,  0x90 }, { ZYD_CR24,  0x14 },	\
497184610Salfred	{ ZYD_CR25,  0x40 }, { ZYD_CR26,  0x10 }, { ZYD_CR27,  0x10 },	\
498184610Salfred	{ ZYD_CR28,  0x7f }, { ZYD_CR29,  0x80 }, { ZYD_CR30,  0x4b },	\
499184610Salfred	{ ZYD_CR31,  0x60 }, { ZYD_CR32,  0x43 }, { ZYD_CR33,  0x08 },	\
500184610Salfred	{ ZYD_CR34,  0x06 }, { ZYD_CR35,  0x0a }, { ZYD_CR36,  0x00 },	\
501184610Salfred	{ ZYD_CR37,  0x00 }, { ZYD_CR38,  0x38 }, { ZYD_CR39,  0x0c },	\
502184610Salfred	{ ZYD_CR40,  0x84 }, { ZYD_CR41,  0x2a }, { ZYD_CR42,  0x80 },	\
503184610Salfred	{ ZYD_CR43,  0x10 }, { ZYD_CR44,  0x33 }, { ZYD_CR46,  0xff },	\
504184610Salfred	{ ZYD_CR47,  0x1E }, { ZYD_CR48,  0x26 }, { ZYD_CR49,  0x5b },	\
505184610Salfred	{ ZYD_CR64,  0xd0 }, { ZYD_CR65,  0x04 }, { ZYD_CR66,  0x58 },	\
506184610Salfred	{ ZYD_CR67,  0xc9 }, { ZYD_CR68,  0x88 }, { ZYD_CR69,  0x41 },	\
507184610Salfred	{ ZYD_CR70,  0x23 }, { ZYD_CR71,  0x10 }, { ZYD_CR72,  0xff },	\
508184610Salfred	{ ZYD_CR73,  0x32 }, { ZYD_CR74,  0x30 }, { ZYD_CR75,  0x65 },	\
509184610Salfred	{ ZYD_CR76,  0x41 }, { ZYD_CR77,  0x1b }, { ZYD_CR78,  0x30 },	\
510184610Salfred	{ ZYD_CR79,  0xf0 }, { ZYD_CR80,  0x64 }, { ZYD_CR81,  0x64 },	\
511184610Salfred	{ ZYD_CR82,  0x00 }, { ZYD_CR83,  0x24 }, { ZYD_CR84,  0x04 },	\
512184610Salfred	{ ZYD_CR85,  0x00 }, { ZYD_CR86,  0x0c }, { ZYD_CR87,  0x12 },	\
513184610Salfred	{ ZYD_CR88,  0x0c }, { ZYD_CR89,  0x00 }, { ZYD_CR90,  0x58 },	\
514184610Salfred	{ ZYD_CR91,  0x04 }, { ZYD_CR92,  0x00 }, { ZYD_CR93,  0x00 },	\
515184610Salfred	{ ZYD_CR94,  0x01 }, { ZYD_CR95,  0x20 }, { ZYD_CR96,  0x50 },	\
516184610Salfred	{ ZYD_CR97,  0x37 }, { ZYD_CR98,  0x35 }, { ZYD_CR99,  0x00 },	\
517184610Salfred	{ ZYD_CR100, 0x01 }, { ZYD_CR101, 0x13 }, { ZYD_CR102, 0x27 },	\
518184610Salfred	{ ZYD_CR103, 0x27 }, { ZYD_CR104, 0x18 }, { ZYD_CR105, 0x12 },	\
519184610Salfred	{ ZYD_CR106, 0x04 }, { ZYD_CR107, 0x00 }, { ZYD_CR108, 0x0a },	\
520184610Salfred	{ ZYD_CR109, 0x27 }, { ZYD_CR110, 0x27 }, { ZYD_CR111, 0x27 },	\
521184610Salfred	{ ZYD_CR112, 0x27 }, { ZYD_CR113, 0x27 }, { ZYD_CR114, 0x27 },	\
522184610Salfred	{ ZYD_CR115, 0x26 }, { ZYD_CR116, 0x24 }, { ZYD_CR117, 0xfc },	\
523184610Salfred	{ ZYD_CR118, 0xfa }, { ZYD_CR119, 0x1e }, { ZYD_CR125, 0x90 },	\
524184610Salfred	{ ZYD_CR126, 0x00 }, { ZYD_CR127, 0x00 }, { ZYD_CR128, 0x14 },	\
525184610Salfred	{ ZYD_CR129, 0x12 }, { ZYD_CR130, 0x10 }, { ZYD_CR131, 0x0c },	\
526184610Salfred	{ ZYD_CR136, 0xdf }, { ZYD_CR137, 0xa0 }, { ZYD_CR138, 0xa8 },	\
527184610Salfred	{ ZYD_CR139, 0xb4 }, { ZYD_CR140, 0x98 }, { ZYD_CR141, 0x82 },	\
528184610Salfred	{ ZYD_CR142, 0x53 }, { ZYD_CR143, 0x1c }, { ZYD_CR144, 0x6c },	\
529184610Salfred	{ ZYD_CR147, 0x07 }, { ZYD_CR148, 0x40 }, { ZYD_CR149, 0x40 },	\
530184610Salfred	{ ZYD_CR150, 0x14 }, { ZYD_CR151, 0x18 }, { ZYD_CR159, 0x70 },	\
531184610Salfred	{ ZYD_CR160, 0xfe }, { ZYD_CR161, 0xee }, { ZYD_CR162, 0xaa },	\
532184610Salfred	{ ZYD_CR163, 0xfa }, { ZYD_CR164, 0xfa }, { ZYD_CR165, 0xea },	\
533184610Salfred	{ ZYD_CR166, 0xbe }, { ZYD_CR167, 0xbe }, { ZYD_CR168, 0x6a },	\
534184610Salfred	{ ZYD_CR169, 0xba }, { ZYD_CR170, 0xba }, { ZYD_CR171, 0xba },	\
535184610Salfred	{ ZYD_CR204, 0x7d }, { ZYD_CR203, 0x30 },			\
536184610Salfred	{ 0, 0 }							\
537184610Salfred}
538184610Salfred
539188417Sthompsa#define ZYD_RFMD_PHY							\
540184610Salfred{									\
541184610Salfred	{ ZYD_CR2,   0x1e }, { ZYD_CR9,   0x20 }, { ZYD_CR10,  0x89 },	\
542184610Salfred	{ ZYD_CR11,  0x00 }, { ZYD_CR15,  0xd0 }, { ZYD_CR17,  0x68 },	\
543184610Salfred	{ ZYD_CR19,  0x4a }, { ZYD_CR20,  0x0c }, { ZYD_CR21,  0x0e },	\
544184610Salfred	{ ZYD_CR23,  0x48 }, { ZYD_CR24,  0x14 }, { ZYD_CR26,  0x90 },	\
545184610Salfred	{ ZYD_CR27,  0x30 }, { ZYD_CR29,  0x20 }, { ZYD_CR31,  0xb2 },	\
546184610Salfred	{ ZYD_CR32,  0x43 }, { ZYD_CR33,  0x28 }, { ZYD_CR38,  0x30 },	\
547184610Salfred	{ ZYD_CR34,  0x0f }, { ZYD_CR35,  0xf0 }, { ZYD_CR41,  0x2a },	\
548184610Salfred	{ ZYD_CR46,  0x7f }, { ZYD_CR47,  0x1e }, { ZYD_CR51,  0xc5 },	\
549184610Salfred	{ ZYD_CR52,  0xc5 }, { ZYD_CR53,  0xc5 }, { ZYD_CR79,  0x58 },	\
550184610Salfred	{ ZYD_CR80,  0x30 }, { ZYD_CR81,  0x30 }, { ZYD_CR82,  0x00 },	\
551184610Salfred	{ ZYD_CR83,  0x24 }, { ZYD_CR84,  0x04 }, { ZYD_CR85,  0x00 },	\
552184610Salfred	{ ZYD_CR86,  0x10 }, { ZYD_CR87,  0x2a }, { ZYD_CR88,  0x10 },	\
553184610Salfred	{ ZYD_CR89,  0x24 }, { ZYD_CR90,  0x18 }, { ZYD_CR91,  0x00 },	\
554184610Salfred	{ ZYD_CR92,  0x0a }, { ZYD_CR93,  0x00 }, { ZYD_CR94,  0x01 },	\
555184610Salfred	{ ZYD_CR95,  0x00 }, { ZYD_CR96,  0x40 }, { ZYD_CR97,  0x37 },	\
556184610Salfred	{ ZYD_CR98,  0x05 }, { ZYD_CR99,  0x28 }, { ZYD_CR100, 0x00 },	\
557184610Salfred	{ ZYD_CR101, 0x13 }, { ZYD_CR102, 0x27 }, { ZYD_CR103, 0x27 },	\
558184610Salfred	{ ZYD_CR104, 0x18 }, { ZYD_CR105, 0x12 }, { ZYD_CR106, 0x1a },	\
559184610Salfred	{ ZYD_CR107, 0x24 }, { ZYD_CR108, 0x0a }, { ZYD_CR109, 0x13 },	\
560184610Salfred	{ ZYD_CR110, 0x2f }, { ZYD_CR111, 0x27 }, { ZYD_CR112, 0x27 },	\
561184610Salfred	{ ZYD_CR113, 0x27 }, { ZYD_CR114, 0x27 }, { ZYD_CR115, 0x40 },	\
562184610Salfred	{ ZYD_CR116, 0x40 }, { ZYD_CR117, 0xf0 }, { ZYD_CR118, 0xf0 },	\
563184610Salfred	{ ZYD_CR119, 0x16 }, { ZYD_CR122, 0x00 }, { ZYD_CR127, 0x03 },	\
564184610Salfred	{ ZYD_CR131, 0x08 }, { ZYD_CR138, 0x28 }, { ZYD_CR148, 0x44 },	\
565184610Salfred	{ ZYD_CR150, 0x10 }, { ZYD_CR169, 0xbb }, { ZYD_CR170, 0xbb }	\
566184610Salfred}
567184610Salfred
568188417Sthompsa#define ZYD_RFMD_RF							\
569184610Salfred{									\
570184610Salfred	0x000007, 0x07dd43, 0x080959, 0x0e6666, 0x116a57, 0x17dd43,	\
571184610Salfred	0x1819f9, 0x1e6666, 0x214554, 0x25e7fa, 0x27fffa, 0x294128,	\
572184610Salfred	0x2c0000, 0x300000, 0x340000, 0x381e0f, 0x6c180f		\
573184610Salfred}
574184610Salfred
575188417Sthompsa#define ZYD_RFMD_CHANTABLE	\
576184610Salfred{				\
577184610Salfred	{ 0x181979, 0x1e6666 },	\
578184610Salfred	{ 0x181989, 0x1e6666 },	\
579184610Salfred	{ 0x181999, 0x1e6666 },	\
580184610Salfred	{ 0x1819a9, 0x1e6666 },	\
581184610Salfred	{ 0x1819b9, 0x1e6666 },	\
582184610Salfred	{ 0x1819c9, 0x1e6666 },	\
583184610Salfred	{ 0x1819d9, 0x1e6666 },	\
584184610Salfred	{ 0x1819e9, 0x1e6666 },	\
585184610Salfred	{ 0x1819f9, 0x1e6666 },	\
586184610Salfred	{ 0x181a09, 0x1e6666 },	\
587184610Salfred	{ 0x181a19, 0x1e6666 },	\
588184610Salfred	{ 0x181a29, 0x1e6666 },	\
589184610Salfred	{ 0x181a39, 0x1e6666 },	\
590184610Salfred	{ 0x181a60, 0x1c0000 }	\
591184610Salfred}
592184610Salfred
593188417Sthompsa#define ZYD_AL2230_PHY							\
594184610Salfred{									\
595184610Salfred	{ ZYD_CR15,  0x20 }, { ZYD_CR23,  0x40 }, { ZYD_CR24,  0x20 },	\
596184610Salfred	{ ZYD_CR26,  0x11 }, { ZYD_CR28,  0x3e }, { ZYD_CR29,  0x00 },	\
597184610Salfred	{ ZYD_CR44,  0x33 }, { ZYD_CR106, 0x2a }, { ZYD_CR107, 0x1a },	\
598184610Salfred	{ ZYD_CR109, 0x09 }, { ZYD_CR110, 0x27 }, { ZYD_CR111, 0x2b },	\
599184610Salfred	{ ZYD_CR112, 0x2b }, { ZYD_CR119, 0x0a }, { ZYD_CR10,  0x89 },	\
600184610Salfred	{ ZYD_CR17,  0x28 }, { ZYD_CR26,  0x93 }, { ZYD_CR34,  0x30 },	\
601184610Salfred	{ ZYD_CR35,  0x3e }, { ZYD_CR41,  0x24 }, { ZYD_CR44,  0x32 },	\
602184610Salfred	{ ZYD_CR46,  0x96 }, { ZYD_CR47,  0x1e }, { ZYD_CR79,  0x58 },	\
603184610Salfred	{ ZYD_CR80,  0x30 }, { ZYD_CR81,  0x30 }, { ZYD_CR87,  0x0a },	\
604184610Salfred	{ ZYD_CR89,  0x04 }, { ZYD_CR92,  0x0a }, { ZYD_CR99,  0x28 },	\
605184610Salfred	{ ZYD_CR100, 0x00 }, { ZYD_CR101, 0x13 }, { ZYD_CR102, 0x27 },	\
606184610Salfred	{ ZYD_CR106, 0x24 }, { ZYD_CR107, 0x2a }, { ZYD_CR109, 0x09 },	\
607184610Salfred	{ ZYD_CR110, 0x13 }, { ZYD_CR111, 0x1f }, { ZYD_CR112, 0x1f },	\
608184610Salfred	{ ZYD_CR113, 0x27 }, { ZYD_CR114, 0x27 }, { ZYD_CR115, 0x24 },	\
609184610Salfred	{ ZYD_CR116, 0x24 }, { ZYD_CR117, 0xf4 }, { ZYD_CR118, 0xfc },	\
610184610Salfred	{ ZYD_CR119, 0x10 }, { ZYD_CR120, 0x4f }, { ZYD_CR121, 0x77 },	\
611184610Salfred	{ ZYD_CR122, 0xe0 }, { ZYD_CR137, 0x88 }, { ZYD_CR252, 0xff },	\
612184610Salfred	{ ZYD_CR253, 0xff }, { ZYD_CR251, 0x2f }, { ZYD_CR251, 0x3f },	\
613184610Salfred	{ ZYD_CR138, 0x28 }, { ZYD_CR203, 0x06 } 			\
614184610Salfred}
615184610Salfred
616188417Sthompsa#define ZYD_AL2230_PHY_B						\
617184610Salfred{									\
618186730Salfred	{ ZYD_CR10,  0x89 }, { ZYD_CR15,  0x20 }, { ZYD_CR17,  0x2B },	\
619184610Salfred	{ ZYD_CR23,  0x40 }, { ZYD_CR24,  0x20 }, { ZYD_CR26,  0x93 },	\
620184610Salfred	{ ZYD_CR28,  0x3e }, { ZYD_CR29,  0x00 }, { ZYD_CR33,  0x28 },	\
621184610Salfred	{ ZYD_CR34,  0x30 }, { ZYD_CR35,  0x3e }, { ZYD_CR41,  0x24 },	\
622184610Salfred	{ ZYD_CR44,  0x32 }, { ZYD_CR46,  0x99 }, { ZYD_CR47,  0x1e },	\
623186730Salfred	{ ZYD_CR48,  0x06 }, { ZYD_CR49,  0xf9 }, { ZYD_CR51,  0x01 },	\
624184610Salfred	{ ZYD_CR52,  0x80 }, { ZYD_CR53,  0x7e }, { ZYD_CR65,  0x00 },	\
625184610Salfred	{ ZYD_CR66,  0x00 }, { ZYD_CR67,  0x00 }, { ZYD_CR68,  0x00 },	\
626184610Salfred	{ ZYD_CR69,  0x28 }, { ZYD_CR79,  0x58 }, { ZYD_CR80,  0x30 },	\
627184610Salfred	{ ZYD_CR81,  0x30 }, { ZYD_CR87,  0x0a }, { ZYD_CR89,  0x04 },	\
628184610Salfred	{ ZYD_CR91,  0x00 }, { ZYD_CR92,  0x0a }, { ZYD_CR98,  0x8d },	\
629186730Salfred	{ ZYD_CR99,  0x00 }, { ZYD_CR101, 0x13 }, { ZYD_CR102, 0x27 },	\
630186730Salfred	{ ZYD_CR106, 0x24 }, { ZYD_CR107, 0x2a }, { ZYD_CR109, 0x13 },	\
631186730Salfred	{ ZYD_CR110, 0x1f }, { ZYD_CR111, 0x1f }, { ZYD_CR112, 0x1f },	\
632186730Salfred	{ ZYD_CR113, 0x27 }, { ZYD_CR114, 0x27 }, { ZYD_CR115, 0x26 },	\
633184610Salfred	{ ZYD_CR116, 0x24 }, { ZYD_CR117, 0xfa }, { ZYD_CR118, 0xfa },	\
634184610Salfred	{ ZYD_CR119, 0x10 }, { ZYD_CR120, 0x4f }, { ZYD_CR121, 0x6c },	\
635184610Salfred	{ ZYD_CR122, 0xfc }, { ZYD_CR123, 0x57 }, { ZYD_CR125, 0xad },	\
636184610Salfred	{ ZYD_CR126, 0x6c }, { ZYD_CR127, 0x03 }, { ZYD_CR137, 0x50 },	\
637184610Salfred	{ ZYD_CR138, 0xa8 }, { ZYD_CR144, 0xac }, { ZYD_CR150, 0x0d },	\
638186730Salfred	{ ZYD_CR252, 0x34 }, { ZYD_CR253, 0x34 }			\
639184610Salfred}
640184610Salfred
641188417Sthompsa#define ZYD_AL2230_PHY_PART1						\
642184610Salfred{									\
643186730Salfred	{ ZYD_CR240, 0x57 }, { ZYD_CR9,   0xe0 }			\
644186730Salfred}
645186730Salfred
646188417Sthompsa#define ZYD_AL2230_PHY_PART2						\
647186730Salfred{									\
648186730Salfred	{ ZYD_CR251, 0x2f }, { ZYD_CR251, 0x7f },			\
649186730Salfred}
650186730Salfred
651188417Sthompsa#define ZYD_AL2230_PHY_PART3						\
652186730Salfred{									\
653186730Salfred	{ ZYD_CR128, 0x14 }, { ZYD_CR129, 0x12 }, { ZYD_CR130, 0x10 },	\
654186730Salfred}
655186730Salfred
656186730Salfred#define	ZYD_AL2230S_PHY_INIT						\
657186730Salfred{									\
658186730Salfred	{ ZYD_CR47,  0x1e }, { ZYD_CR106, 0x22 }, { ZYD_CR107, 0x2a },	\
659186730Salfred	{ ZYD_CR109, 0x13 }, { ZYD_CR118, 0xf8 }, { ZYD_CR119, 0x12 },	\
660186730Salfred	{ ZYD_CR122, 0xe0 }, { ZYD_CR128, 0x10 }, { ZYD_CR129, 0x0e },	\
661186730Salfred	{ ZYD_CR130, 0x10 }						\
662186730Salfred}
663186730Salfred
664186730Salfred#define	ZYD_AL2230_PHY_FINI_PART1					\
665186730Salfred{									\
666186730Salfred	{ ZYD_CR80,  0x30 }, { ZYD_CR81,  0x30 }, { ZYD_CR79,  0x58 },	\
667186730Salfred	{ ZYD_CR12,  0xf0 }, { ZYD_CR77,  0x1b }, { ZYD_CR78,  0x58 },	\
668186730Salfred	{ ZYD_CR203, 0x06 }, { ZYD_CR240, 0x80 },			\
669186730Salfred}
670186730Salfred
671188417Sthompsa#define ZYD_AL2230_RF_PART1						\
672186730Salfred{									\
673186730Salfred	0x03f790, 0x033331, 0x00000d, 0x0b3331, 0x03b812, 0x00fff3	\
674186730Salfred}
675186730Salfred
676188417Sthompsa#define ZYD_AL2230_RF_PART2						\
677186730Salfred{									\
678184610Salfred	0x000da4, 0x0f4dc5, 0x0805b6, 0x011687, 0x000688, 0x0403b9,	\
679186730Salfred	0x00dbba, 0x00099b, 0x0bdffc, 0x00000d, 0x00500f		\
680184610Salfred}
681184610Salfred
682188417Sthompsa#define ZYD_AL2230_RF_PART3						\
683186730Salfred{									\
684186730Salfred	0x00d00f, 0x004c0f, 0x00540f, 0x00700f, 0x00500f		\
685186730Salfred}
686186730Salfred
687188417Sthompsa#define ZYD_AL2230_RF_B							\
688184610Salfred{									\
689184610Salfred	0x03f790, 0x033331, 0x00000d, 0x0b3331, 0x03b812, 0x00fff3,	\
690184610Salfred	0x0005a4, 0x0f4dc5, 0x0805b6, 0x0146c7, 0x000688, 0x0403b9,	\
691184610Salfred	0x00dbba, 0x00099b, 0x0bdffc, 0x00000d, 0x00580f		\
692184610Salfred}
693184610Salfred
694188417Sthompsa#define ZYD_AL2230_RF_B_PART1						\
695186730Salfred{									\
696186730Salfred	0x8cccd0, 0x481dc0, 0xcfff00, 0x25a000				\
697186730Salfred}
698186730Salfred
699188417Sthompsa#define ZYD_AL2230_RF_B_PART2						\
700186730Salfred{									\
701186730Salfred	0x25a000, 0xa3b2f0, 0x6da010, 0xe36280, 0x116000, 0x9dc020,	\
702186730Salfred	0x5ddb00, 0xd99000, 0x3ffbd0, 0xb00000, 0xf01a00		\
703186730Salfred}
704186730Salfred
705188417Sthompsa#define ZYD_AL2230_RF_B_PART3						\
706186730Salfred{									\
707186730Salfred	0xf01b00, 0xf01e00, 0xf01a00					\
708186730Salfred}
709186730Salfred
710188417Sthompsa#define ZYD_AL2230_CHANTABLE			\
711184610Salfred{						\
712184610Salfred	{ 0x03f790, 0x033331, 0x00000d },	\
713184610Salfred	{ 0x03f790, 0x0b3331, 0x00000d },	\
714184610Salfred	{ 0x03e790, 0x033331, 0x00000d },	\
715184610Salfred	{ 0x03e790, 0x0b3331, 0x00000d },	\
716184610Salfred	{ 0x03f7a0, 0x033331, 0x00000d },	\
717184610Salfred	{ 0x03f7a0, 0x0b3331, 0x00000d },	\
718184610Salfred	{ 0x03e7a0, 0x033331, 0x00000d },	\
719184610Salfred	{ 0x03e7a0, 0x0b3331, 0x00000d },	\
720184610Salfred	{ 0x03f7b0, 0x033331, 0x00000d },	\
721184610Salfred	{ 0x03f7b0, 0x0b3331, 0x00000d },	\
722184610Salfred	{ 0x03e7b0, 0x033331, 0x00000d },	\
723184610Salfred	{ 0x03e7b0, 0x0b3331, 0x00000d },	\
724184610Salfred	{ 0x03f7c0, 0x033331, 0x00000d },	\
725184610Salfred	{ 0x03e7c0, 0x066661, 0x00000d }	\
726184610Salfred}
727184610Salfred
728188417Sthompsa#define ZYD_AL2230_CHANTABLE_B			\
729186730Salfred{						\
730186730Salfred	{ 0x09efc0, 0x8cccc0, 0xb00000 },	\
731186730Salfred	{ 0x09efc0, 0x8cccd0, 0xb00000 },	\
732186730Salfred	{ 0x09e7c0, 0x8cccc0, 0xb00000 },	\
733186730Salfred	{ 0x09e7c0, 0x8cccd0, 0xb00000 },	\
734186730Salfred	{ 0x05efc0, 0x8cccc0, 0xb00000 },	\
735186730Salfred	{ 0x05efc0, 0x8cccd0, 0xb00000 },	\
736186730Salfred	{ 0x05e7c0, 0x8cccc0, 0xb00000 },	\
737186730Salfred	{ 0x05e7c0, 0x8cccd0, 0xb00000 },	\
738186730Salfred	{ 0x0defc0, 0x8cccc0, 0xb00000 },	\
739186730Salfred	{ 0x0defc0, 0x8cccd0, 0xb00000 },	\
740186730Salfred	{ 0x0de7c0, 0x8cccc0, 0xb00000 },	\
741186730Salfred	{ 0x0de7c0, 0x8cccd0, 0xb00000 },	\
742186730Salfred	{ 0x03efc0, 0x8cccc0, 0xb00000 },	\
743186730Salfred	{ 0x03e7c0, 0x866660, 0xb00000 }	\
744186730Salfred}
745184610Salfred
746188417Sthompsa#define ZYD_AL7230B_PHY_1							\
747184610Salfred{									\
748184610Salfred	{ ZYD_CR240, 0x57 }, { ZYD_CR15,  0x20 }, { ZYD_CR23,  0x40 },	\
749184610Salfred	{ ZYD_CR24,  0x20 }, { ZYD_CR26,  0x11 }, { ZYD_CR28,  0x3e },	\
750184610Salfred	{ ZYD_CR29,  0x00 }, { ZYD_CR44,  0x33 }, { ZYD_CR106, 0x22 },	\
751184610Salfred	{ ZYD_CR107, 0x1a }, { ZYD_CR109, 0x09 }, { ZYD_CR110, 0x27 },	\
752184610Salfred	{ ZYD_CR111, 0x2b }, { ZYD_CR112, 0x2b }, { ZYD_CR119, 0x0a },	\
753184610Salfred	{ ZYD_CR122, 0xfc }, { ZYD_CR10,  0x89 }, { ZYD_CR17,  0x28 },	\
754184610Salfred	{ ZYD_CR26,  0x93 }, { ZYD_CR34,  0x30 }, { ZYD_CR35,  0x3e },	\
755184610Salfred	{ ZYD_CR41,  0x24 }, { ZYD_CR44,  0x32 }, { ZYD_CR46,  0x96 },	\
756184610Salfred	{ ZYD_CR47,  0x1e }, { ZYD_CR79,  0x58 }, { ZYD_CR80,  0x30 },	\
757184610Salfred	{ ZYD_CR81,  0x30 }, { ZYD_CR87,  0x0a }, { ZYD_CR89,  0x04 },	\
758184610Salfred	{ ZYD_CR92,  0x0a }, { ZYD_CR99,  0x28 }, { ZYD_CR100, 0x02 },	\
759184610Salfred	{ ZYD_CR101, 0x13 }, { ZYD_CR102, 0x27 }, { ZYD_CR106, 0x22 },	\
760184610Salfred	{ ZYD_CR107, 0x3f }, { ZYD_CR109, 0x09 }, { ZYD_CR110, 0x1f },	\
761184610Salfred	{ ZYD_CR111, 0x1f }, { ZYD_CR112, 0x1f }, { ZYD_CR113, 0x27 },	\
762184610Salfred	{ ZYD_CR114, 0x27 }, { ZYD_CR115, 0x24 }, { ZYD_CR116, 0x3f },	\
763184610Salfred	{ ZYD_CR117, 0xfa }, { ZYD_CR118, 0xfc }, { ZYD_CR119, 0x10 },	\
764184610Salfred	{ ZYD_CR120, 0x4f }, { ZYD_CR121, 0x77 }, { ZYD_CR137, 0x88 },	\
765184610Salfred	{ ZYD_CR138, 0xa8 }, { ZYD_CR252, 0x34 }, { ZYD_CR253, 0x34 },	\
766184610Salfred	{ ZYD_CR251, 0x2f }						\
767184610Salfred}
768184610Salfred
769188417Sthompsa#define ZYD_AL7230B_PHY_2						\
770184610Salfred{									\
771184610Salfred	{ ZYD_CR251, 0x3f }, { ZYD_CR128, 0x14 }, { ZYD_CR129, 0x12 },	\
772184610Salfred	{ ZYD_CR130, 0x10 }, { ZYD_CR38,  0x38 }, { ZYD_CR136, 0xdf }	\
773184610Salfred}
774184610Salfred
775188417Sthompsa#define ZYD_AL7230B_PHY_3						\
776184610Salfred{									\
777184610Salfred	{ ZYD_CR203, 0x06 }, { ZYD_CR240, 0x80 }			\
778184610Salfred}
779184610Salfred
780188417Sthompsa#define ZYD_AL7230B_RF_1						\
781184610Salfred{									\
782184610Salfred	0x09ec04, 0x8cccc8, 0x4ff821, 0xc5fbfc, 0x21ebfe, 0xafd401,	\
783184610Salfred	0x6cf56a, 0xe04073, 0x193d76, 0x9dd844, 0x500007, 0xd8c010,	\
784184610Salfred	0x3c9000, 0xbfffff, 0x700000, 0xf15d58				\
785184610Salfred}
786184610Salfred
787188417Sthompsa#define ZYD_AL7230B_RF_2						\
788184610Salfred{									\
789184610Salfred	0xf15d59, 0xf15d5c, 0xf15d58					\
790184610Salfred}
791184610Salfred
792188417Sthompsa#define ZYD_AL7230B_RF_SETCHANNEL					\
793184610Salfred{									\
794184610Salfred	0x4ff821, 0xc5fbfc, 0x21ebfe, 0xafd401, 0x6cf56a, 0xe04073,	\
795184610Salfred	0x193d76, 0x9dd844, 0x500007, 0xd8c010, 0x3c9000, 0xf15d58	\
796184610Salfred}
797184610Salfred
798188417Sthompsa#define ZYD_AL7230B_CHANTABLE	\
799184610Salfred{				\
800184610Salfred	{ 0x09ec00, 0x8cccc8 },	\
801184610Salfred	{ 0x09ec00, 0x8cccd8 },	\
802184610Salfred	{ 0x09ec00, 0x8cccc0 },	\
803184610Salfred	{ 0x09ec00, 0x8cccd0 },	\
804184610Salfred	{ 0x05ec00, 0x8cccc8 },	\
805184610Salfred	{ 0x05ec00, 0x8cccd8 },	\
806184610Salfred	{ 0x05ec00, 0x8cccc0 },	\
807184610Salfred	{ 0x05ec00, 0x8cccd0 },	\
808184610Salfred	{ 0x0dec00, 0x8cccc8 },	\
809184610Salfred	{ 0x0dec00, 0x8cccd8 },	\
810184610Salfred	{ 0x0dec00, 0x8cccc0 },	\
811184610Salfred	{ 0x0dec00, 0x8cccd0 },	\
812184610Salfred	{ 0x03ec00, 0x8cccc8 },	\
813184610Salfred	{ 0x03ec00, 0x866660 }	\
814184610Salfred}
815184610Salfred
816188417Sthompsa#define ZYD_AL2210_PHY							\
817184610Salfred{									\
818184610Salfred	{ ZYD_CR9,   0xe0 }, { ZYD_CR10, 0x91 }, { ZYD_CR12,  0x90 },	\
819184610Salfred	{ ZYD_CR15,  0xd0 }, { ZYD_CR16, 0x40 }, { ZYD_CR17,  0x58 },	\
820184610Salfred	{ ZYD_CR18,  0x04 }, { ZYD_CR23, 0x66 }, { ZYD_CR24,  0x14 },	\
821184610Salfred	{ ZYD_CR26,  0x90 }, { ZYD_CR31, 0x80 }, { ZYD_CR34,  0x06 },	\
822184610Salfred	{ ZYD_CR35,  0x3e }, { ZYD_CR38, 0x38 }, { ZYD_CR46,  0x90 },	\
823184610Salfred	{ ZYD_CR47,  0x1e }, { ZYD_CR64, 0x64 }, { ZYD_CR79,  0xb5 },	\
824184610Salfred	{ ZYD_CR80,  0x38 }, { ZYD_CR81, 0x30 }, { ZYD_CR113, 0xc0 },	\
825184610Salfred	{ ZYD_CR127, 0x03 }						\
826184610Salfred}
827184610Salfred
828188417Sthompsa#define ZYD_AL2210_RF							\
829184610Salfred{									\
830184610Salfred	0x2396c0, 0x00fcb1, 0x358132, 0x0108b3, 0xc77804, 0x456415,	\
831184610Salfred	0xff2226, 0x806667, 0x7860f8, 0xbb01c9, 0x00000a, 0x00000b	\
832184610Salfred}
833184610Salfred
834188417Sthompsa#define ZYD_AL2210_CHANTABLE						\
835184610Salfred{									\
836184610Salfred	0x0196c0, 0x019710, 0x019760, 0x0197b0,	0x019800, 0x019850,	\
837184610Salfred	0x0198a0, 0x0198f0, 0x019940, 0x019990, 0x0199e0, 0x019a30,	\
838184610Salfred	0x019a80, 0x019b40 						\
839184610Salfred}
840184610Salfred
841188417Sthompsa#define ZYD_GCT_PHY							\
842184610Salfred{									\
843193420Sweongyo	{ ZYD_CR10,  0x89 }, { ZYD_CR15,  0x20 }, { ZYD_CR17,  0x28 },	\
844193420Sweongyo	{ ZYD_CR23,  0x38 }, { ZYD_CR24,  0x20 }, { ZYD_CR26,  0x93 },	\
845193420Sweongyo	{ ZYD_CR27,  0x15 }, { ZYD_CR28,  0x3e }, { ZYD_CR29,  0x00 },	\
846193420Sweongyo	{ ZYD_CR33,  0x28 }, { ZYD_CR34,  0x30 }, { ZYD_CR35,  0x43 },	\
847193420Sweongyo	{ ZYD_CR41,  0x24 }, { ZYD_CR44,  0x32 }, { ZYD_CR46,  0x92 },	\
848193420Sweongyo	{ ZYD_CR47,  0x1e }, { ZYD_CR48,  0x04 }, { ZYD_CR49,  0xfa },	\
849193420Sweongyo	{ ZYD_CR79,  0x58 }, { ZYD_CR80,  0x30 }, { ZYD_CR81,  0x30 },	\
850193420Sweongyo	{ ZYD_CR87,  0x0a }, { ZYD_CR89,  0x04 }, { ZYD_CR91,  0x00 },	\
851193420Sweongyo	{ ZYD_CR92,  0x0a }, { ZYD_CR98,  0x8d }, { ZYD_CR99,  0x28 },	\
852193420Sweongyo	{ ZYD_CR100, 0x02 }, { ZYD_CR101, 0x09 }, { ZYD_CR102, 0x27 },	\
853193420Sweongyo	{ ZYD_CR106, 0x1c }, { ZYD_CR107, 0x1c }, { ZYD_CR109, 0x13 },	\
854193420Sweongyo	{ ZYD_CR110, 0x1f }, { ZYD_CR111, 0x13 }, { ZYD_CR112, 0x1f },	\
855193420Sweongyo	{ ZYD_CR113, 0x27 }, { ZYD_CR114, 0x23 }, { ZYD_CR115, 0x24 },	\
856193420Sweongyo	{ ZYD_CR116, 0x24 }, { ZYD_CR117, 0xfa }, { ZYD_CR118, 0xf0 },	\
857193420Sweongyo	{ ZYD_CR119, 0x1a }, { ZYD_CR120, 0x4f }, { ZYD_CR121, 0x1f },	\
858193420Sweongyo	{ ZYD_CR122, 0xf0 }, { ZYD_CR123, 0x57 }, { ZYD_CR125, 0xad },	\
859193420Sweongyo	{ ZYD_CR126, 0x6c }, { ZYD_CR127, 0x03 }, { ZYD_CR128, 0x14 },	\
860193420Sweongyo	{ ZYD_CR129, 0x12 }, { ZYD_CR130, 0x10 }, { ZYD_CR137, 0x50 },	\
861193420Sweongyo	{ ZYD_CR138, 0xa8 }, { ZYD_CR144, 0xac }, { ZYD_CR146, 0x20 },	\
862193420Sweongyo	{ ZYD_CR252, 0xff }, { ZYD_CR253, 0xff }			\
863184610Salfred}
864184610Salfred
865188417Sthompsa#define ZYD_GCT_RF							\
866184610Salfred{									\
867193420Sweongyo	0x40002b, 0x519e4f, 0x6f81ad, 0x73fffe, 0x25f9c, 0x100047,	\
868193420Sweongyo	0x200999, 0x307602, 0x346063,					\
869184610Salfred}
870184610Salfred
871193420Sweongyo#define	ZYD_GCT_VCO							\
872184610Salfred{									\
873193420Sweongyo	{ 0x664d, 0x604d, 0x6675, 0x6475, 0x6655, 0x6455, 0x6665 },	\
874193420Sweongyo	{ 0x666d, 0x606d, 0x664d, 0x644d, 0x6675, 0x6475, 0x6655 },	\
875193420Sweongyo	{ 0x665d, 0x605d, 0x666d, 0x646d, 0x664d, 0x644d, 0x6675 },	\
876193420Sweongyo	{ 0x667d, 0x607d, 0x665d, 0x645d, 0x666d, 0x646d, 0x664d },	\
877193420Sweongyo	{ 0x6643, 0x6043, 0x667d, 0x647d, 0x665d, 0x645d, 0x666d },	\
878193420Sweongyo	{ 0x6663, 0x6063, 0x6643, 0x6443, 0x667d, 0x647d, 0x665d },	\
879193420Sweongyo	{ 0x6653, 0x6053, 0x6663, 0x6463, 0x6643, 0x6443, 0x667d },	\
880193420Sweongyo	{ 0x6673, 0x6073, 0x6653, 0x6453, 0x6663, 0x6463, 0x6643 },	\
881193420Sweongyo	{ 0x664b, 0x604b, 0x6673, 0x6473, 0x6653, 0x6453, 0x6663 },	\
882193420Sweongyo	{ 0x666b, 0x606b, 0x664b, 0x644b, 0x6673, 0x6473, 0x6653 },	\
883193420Sweongyo	{ 0x665b, 0x605b, 0x666b, 0x646b, 0x664b, 0x644b, 0x6673 }	\
884184610Salfred}
885184610Salfred
886193420Sweongyo#define	ZYD_GCT_TXGAIN							\
887184610Salfred{									\
888193420Sweongyo	0x0e313, 0x0fb13, 0x0e093, 0x0f893, 0x0ea93, 0x1f093, 0x1f493,	\
889193420Sweongyo	0x1f693, 0x1f393, 0x1f35b, 0x1e6db, 0x1ff3f, 0x1ffff, 0x361d7,	\
890193420Sweongyo	0x37fbf, 0x3ff8b, 0x3ff33, 0x3fb3f, 0x3ffff			\
891184610Salfred}
892184610Salfred
893193420Sweongyo#define	ZYD_GCT_CHANNEL_ACAL						\
894184610Salfred{									\
895193420Sweongyo	0x106847, 0x106847, 0x106867, 0x106867, 0x106867, 0x106867,	\
896193420Sweongyo	0x106857, 0x106857, 0x106857, 0x106857, 0x106877, 0x106877,	\
897193420Sweongyo	0x106877, 0x10684f						\
898184610Salfred}
899184610Salfred
900193420Sweongyo#define	ZYD_GCT_CHANNEL_STD						\
901193420Sweongyo{									\
902193420Sweongyo	0x100047, 0x100047, 0x100067, 0x100067, 0x100067, 0x100067,	\
903193420Sweongyo	0x100057, 0x100057, 0x100057, 0x100057, 0x100077, 0x100077,	\
904193420Sweongyo	0x100077, 0x10004f						\
905184610Salfred}
906184610Salfred
907193420Sweongyo#define	ZYD_GCT_CHANNEL_DIV						\
908193420Sweongyo{									\
909193420Sweongyo	0x200999, 0x20099b, 0x200998, 0x20099a, 0x200999, 0x20099b,	\
910193420Sweongyo	0x200998, 0x20099a, 0x200999, 0x20099b, 0x200998, 0x20099a,	\
911193420Sweongyo	0x200999, 0x200ccc						\
912193420Sweongyo}
913193420Sweongyo
914188417Sthompsa#define ZYD_MAXIM2_PHY							\
915184610Salfred{									\
916184610Salfred	{ ZYD_CR23,  0x40 }, { ZYD_CR15,  0x20 }, { ZYD_CR28,  0x3e },	\
917184610Salfred	{ ZYD_CR29,  0x00 }, { ZYD_CR26,  0x11 }, { ZYD_CR44,  0x33 },	\
918184610Salfred	{ ZYD_CR106, 0x2a }, { ZYD_CR107, 0x1a }, { ZYD_CR109, 0x2b },	\
919184610Salfred	{ ZYD_CR110, 0x2b }, { ZYD_CR111, 0x2b }, { ZYD_CR112, 0x2b },	\
920184610Salfred	{ ZYD_CR10,  0x89 }, { ZYD_CR17,  0x20 }, { ZYD_CR26,  0x93 },	\
921184610Salfred	{ ZYD_CR34,  0x30 }, { ZYD_CR35,  0x40 }, { ZYD_CR41,  0x24 },	\
922184610Salfred	{ ZYD_CR44,  0x32 }, { ZYD_CR46,  0x90 }, { ZYD_CR89,  0x18 },	\
923184610Salfred	{ ZYD_CR92,  0x0a }, { ZYD_CR101, 0x13 }, { ZYD_CR102, 0x27 },	\
924184610Salfred	{ ZYD_CR106, 0x20 }, { ZYD_CR107, 0x24 }, { ZYD_CR109, 0x09 },	\
925184610Salfred	{ ZYD_CR110, 0x13 }, { ZYD_CR111, 0x13 }, { ZYD_CR112, 0x13 },	\
926184610Salfred	{ ZYD_CR113, 0x27 }, { ZYD_CR114, 0x27 }, { ZYD_CR115, 0x24 },	\
927184610Salfred	{ ZYD_CR116, 0x24 }, { ZYD_CR117, 0xf4 }, { ZYD_CR118, 0xfa },	\
928184610Salfred	{ ZYD_CR120, 0x4f }, { ZYD_CR121, 0x77 }, { ZYD_CR122, 0xfe },	\
929184610Salfred	{ ZYD_CR10,  0x89 }, { ZYD_CR17,  0x20 }, { ZYD_CR26,  0x93 },	\
930184610Salfred	{ ZYD_CR34,  0x30 }, { ZYD_CR35,  0x40 }, { ZYD_CR41,  0x24 },	\
931184610Salfred	{ ZYD_CR44,  0x32 }, { ZYD_CR46,  0x90 }, { ZYD_CR79,  0x58 },	\
932184610Salfred	{ ZYD_CR80,  0x30 }, { ZYD_CR81,  0x30 }, { ZYD_CR89,  0x18 },	\
933184610Salfred	{ ZYD_CR92,  0x0a }, { ZYD_CR101, 0x13 }, { ZYD_CR102, 0x27 },	\
934184610Salfred	{ ZYD_CR106, 0x20 }, { ZYD_CR107, 0x24 }, { ZYD_CR109, 0x09 },	\
935184610Salfred	{ ZYD_CR110, 0x13 }, { ZYD_CR111, 0x13 }, { ZYD_CR112, 0x13 },	\
936184610Salfred	{ ZYD_CR113, 0x27 }, { ZYD_CR114, 0x27 }, { ZYD_CR115, 0x24 },	\
937184610Salfred	{ ZYD_CR116, 0x24 }, { ZYD_CR117, 0xf4 }, { ZYD_CR118, 0x00 },	\
938184610Salfred	{ ZYD_CR120, 0x4f }, { ZYD_CR121, 0x06 }, { ZYD_CR122, 0xfe }	\
939184610Salfred}
940184610Salfred
941188417Sthompsa#define ZYD_MAXIM2_RF							\
942184610Salfred{									\
943184610Salfred	0x33334, 0x10a03, 0x00400, 0x00ca1, 0x10072, 0x18645, 0x04006,	\
944184610Salfred	0x000a7, 0x08258, 0x03fc9, 0x0040a, 0x0000b, 0x0026c		\
945184610Salfred}
946184610Salfred
947188417Sthompsa#define ZYD_MAXIM2_CHANTABLE_F						\
948184610Salfred{									\
949184610Salfred	0x33334, 0x08884, 0x1ddd4, 0x33334, 0x08884, 0x1ddd4, 0x33334,	\
950184610Salfred	0x08884, 0x1ddd4, 0x33334, 0x08884, 0x1ddd4, 0x33334, 0x26664	\
951184610Salfred}
952184610Salfred
953188417Sthompsa#define ZYD_MAXIM2_CHANTABLE	\
954184610Salfred{				\
955184610Salfred	{ 0x33334, 0x10a03 },	\
956184610Salfred	{ 0x08884, 0x20a13 },	\
957184610Salfred	{ 0x1ddd4, 0x30a13 },	\
958184610Salfred	{ 0x33334, 0x10a13 },	\
959184610Salfred	{ 0x08884, 0x20a23 },	\
960184610Salfred	{ 0x1ddd4, 0x30a23 },	\
961184610Salfred	{ 0x33334, 0x10a23 },	\
962184610Salfred	{ 0x08884, 0x20a33 },	\
963184610Salfred	{ 0x1ddd4, 0x30a33 },	\
964184610Salfred	{ 0x33334, 0x10a33 },	\
965184610Salfred	{ 0x08884, 0x20a43 },	\
966184610Salfred	{ 0x1ddd4, 0x30a43 },	\
967184610Salfred	{ 0x33334, 0x10a43 },	\
968184610Salfred	{ 0x26664, 0x20a53 }	\
969184610Salfred}
970184610Salfred
971193803Sweongyo#define	ZYD_TX_RATEDIV							\
972193803Sweongyo{									\
973269266Shselasky	0x1, 0x2, 0xb, 0xb, 0x1, 0x1, 0x1, 0x1, 0x30, 0x18, 0xc, 0x6,	\
974193803Sweongyo	0x36, 0x24, 0x12, 0x9						\
975193803Sweongyo}
976193803Sweongyo
977184610Salfred/*
978184610Salfred * Control pipe requests.
979184610Salfred */
980188417Sthompsa#define ZYD_DOWNLOADREQ		0x30
981188417Sthompsa#define ZYD_DOWNLOADSTS		0x31
982188417Sthompsa#define	ZYD_READFWDATAREQ	0x32
983184610Salfred
984184610Salfred/* possible values for register ZYD_CR_INTERRUPT */
985188417Sthompsa#define ZYD_HWINT_MASK		0x004f0000
986184610Salfred
987184610Salfred/* possible values for register ZYD_MAC_MISC */
988188417Sthompsa#define ZYD_UNLOCK_PHY_REGS	0x80
989184610Salfred
990184610Salfred/* possible values for register ZYD_MAC_ENCRYPTION_TYPE */
991188417Sthompsa#define ZYD_ENC_SNIFFER		8
992184610Salfred
993184610Salfred/* flags for register ZYD_MAC_RXFILTER */
994188417Sthompsa#define ZYD_FILTER_ASS_REQ	(1 << 0)
995188417Sthompsa#define ZYD_FILTER_ASS_RSP	(1 << 1)
996188417Sthompsa#define ZYD_FILTER_REASS_REQ	(1 << 2)
997188417Sthompsa#define ZYD_FILTER_REASS_RSP	(1 << 3)
998188417Sthompsa#define ZYD_FILTER_PRB_REQ	(1 << 4)
999188417Sthompsa#define ZYD_FILTER_PRB_RSP	(1 << 5)
1000188417Sthompsa#define ZYD_FILTER_BCN		(1 << 8)
1001188417Sthompsa#define ZYD_FILTER_ATIM		(1 << 9)
1002188417Sthompsa#define ZYD_FILTER_DEASS	(1 << 10)
1003188417Sthompsa#define ZYD_FILTER_AUTH		(1 << 11)
1004188417Sthompsa#define ZYD_FILTER_DEAUTH	(1 << 12)
1005188417Sthompsa#define ZYD_FILTER_PS_POLL	(1 << 26)
1006188417Sthompsa#define ZYD_FILTER_RTS		(1 << 27)
1007188417Sthompsa#define ZYD_FILTER_CTS		(1 << 28)
1008188417Sthompsa#define ZYD_FILTER_ACK		(1 << 29)
1009188417Sthompsa#define ZYD_FILTER_CFE		(1 << 30)
1010261455Seadler#define ZYD_FILTER_CFE_A	(1U << 31)
1011184610Salfred
1012184610Salfred/* helpers for register ZYD_MAC_RXFILTER */
1013188417Sthompsa#define ZYD_FILTER_MONITOR	0xffffffff
1014188417Sthompsa#define ZYD_FILTER_BSS							\
1015188417Sthompsa	(ZYD_FILTER_ASS_REQ | ZYD_FILTER_ASS_RSP |			\
1016188417Sthompsa	 ZYD_FILTER_REASS_REQ | ZYD_FILTER_REASS_RSP |			\
1017188417Sthompsa	 ZYD_FILTER_PRB_REQ | ZYD_FILTER_PRB_RSP |			\
1018188417Sthompsa	 (0x3 << 6) |							\
1019188417Sthompsa	 ZYD_FILTER_BCN | ZYD_FILTER_ATIM | ZYD_FILTER_DEASS |		\
1020188417Sthompsa	 ZYD_FILTER_AUTH | ZYD_FILTER_DEAUTH |				\
1021188417Sthompsa	 (0x7 << 13) |							\
1022188417Sthompsa	 ZYD_FILTER_PS_POLL | ZYD_FILTER_ACK)
1023188417Sthompsa#define ZYD_FILTER_HOSTAP						\
1024184610Salfred	(ZYD_FILTER_ASS_REQ | ZYD_FILTER_REASS_REQ |			\
1025184610Salfred	 ZYD_FILTER_PRB_REQ | ZYD_FILTER_DEASS | ZYD_FILTER_AUTH |	\
1026184610Salfred	 ZYD_FILTER_DEAUTH | ZYD_FILTER_PS_POLL)
1027184610Salfred
1028184610Salfredstruct zyd_tx_desc {
1029188417Sthompsa	uint8_t			phy;
1030188417Sthompsa#define ZYD_TX_PHY_SIGNAL(x)	((x) & 0xf)
1031188417Sthompsa#define ZYD_TX_PHY_OFDM		(1 << 4)
1032188417Sthompsa#define ZYD_TX_PHY_SHPREAMBLE	(1 << 5)	/* CCK */
1033188417Sthompsa#define ZYD_TX_PHY_5GHZ		(1 << 5)	/* OFDM */
1034188417Sthompsa	uint16_t		len;
1035188417Sthompsa	uint8_t			flags;
1036188417Sthompsa#define ZYD_TX_FLAG_BACKOFF	(1 << 0)
1037188417Sthompsa#define ZYD_TX_FLAG_MULTICAST	(1 << 1)
1038188417Sthompsa#define ZYD_TX_FLAG_TYPE(x)	(((x) & 0x3) << 2)
1039188417Sthompsa#define ZYD_TX_TYPE_DATA	0
1040188417Sthompsa#define ZYD_TX_TYPE_PS_POLL	1
1041188417Sthompsa#define ZYD_TX_TYPE_MGMT	2
1042188417Sthompsa#define ZYD_TX_TYPE_CTL		3
1043188417Sthompsa#define ZYD_TX_FLAG_WAKEUP	(1 << 4)
1044188417Sthompsa#define ZYD_TX_FLAG_RTS		(1 << 5)
1045188417Sthompsa#define ZYD_TX_FLAG_ENCRYPT	(1 << 6)
1046188417Sthompsa#define ZYD_TX_FLAG_CTS_TO_SELF	(1 << 7)
1047188417Sthompsa	uint16_t		pktlen;
1048188417Sthompsa	uint16_t		plcp_length;
1049188417Sthompsa	uint8_t			plcp_service;
1050188417Sthompsa#define ZYD_PLCP_LENGEXT	0x80
1051188417Sthompsa	uint16_t		nextlen;
1052184610Salfred} __packed;
1053184610Salfred
1054184610Salfredstruct zyd_plcphdr {
1055188417Sthompsa	uint8_t			signal;
1056188417Sthompsa	uint8_t			reserved[2];
1057188417Sthompsa	uint16_t		service;	/* unaligned! */
1058184610Salfred} __packed;
1059184610Salfred
1060184610Salfredstruct zyd_rx_stat {
1061188417Sthompsa	uint8_t			signal_cck;
1062188417Sthompsa	uint8_t			rssi;
1063188417Sthompsa	uint8_t			signal_ofdm;
1064188417Sthompsa	uint8_t			cipher;
1065188417Sthompsa#define ZYD_RX_CIPHER_WEP64	1
1066188417Sthompsa#define ZYD_RX_CIPHER_TKIP	2
1067188417Sthompsa#define ZYD_RX_CIPHER_AES	4
1068188417Sthompsa#define ZYD_RX_CIPHER_WEP128	5
1069188417Sthompsa#define ZYD_RX_CIPHER_WEP256	6
1070188417Sthompsa#define ZYD_RX_CIPHER_WEP	\
1071184610Salfred	(ZYD_RX_CIPHER_WEP64 | ZYD_RX_CIPHER_WEP128 | ZYD_RX_CIPHER_WEP256)
1072188417Sthompsa	uint8_t			flags;
1073188417Sthompsa#define ZYD_RX_OFDM		(1 << 0)
1074188417Sthompsa#define ZYD_RX_TIMEOUT		(1 << 1)
1075188417Sthompsa#define ZYD_RX_OVERRUN		(1 << 2)
1076188417Sthompsa#define ZYD_RX_DECRYPTERR	(1 << 3)
1077188417Sthompsa#define ZYD_RX_BADCRC32		(1 << 4)
1078188417Sthompsa#define ZYD_RX_NOT2ME		(1 << 5)
1079188417Sthompsa#define ZYD_RX_BADCRC16		(1 << 6)
1080188417Sthompsa#define ZYD_RX_ERROR		(1 << 7)
1081184610Salfred} __packed;
1082184610Salfred
1083184610Salfred/* this structure may be unaligned */
1084184610Salfredstruct zyd_rx_desc {
1085188417Sthompsa#define ZYD_MAX_RXFRAMECNT	3
1086188417Sthompsa	uWord			len[ZYD_MAX_RXFRAMECNT];
1087188417Sthompsa	uWord			tag;
1088188417Sthompsa#define ZYD_TAG_MULTIFRAME	0x697e
1089184610Salfred} __packed;
1090184610Salfred
1091184610Salfred/* I2C bus alike */
1092188417Sthompsastruct zyd_rfwrite_cmd {
1093188417Sthompsa	uint16_t		code;
1094188417Sthompsa	uint16_t		width;
1095188417Sthompsa	uint16_t		bit[32];
1096188417Sthompsa#define ZYD_RF_IF_LE		(1 << 1)
1097188417Sthompsa#define ZYD_RF_CLK		(1 << 2)
1098188417Sthompsa#define ZYD_RF_DATA		(1 << 3)
1099184610Salfred} __packed;
1100184610Salfred
1101184610Salfredstruct zyd_cmd {
1102188417Sthompsa	uint16_t		code;
1103188417Sthompsa#define ZYD_CMD_IOWR		0x0021	/* write HMAC or PHY register */
1104188417Sthompsa#define ZYD_CMD_IORD		0x0022	/* read HMAC or PHY register */
1105188417Sthompsa#define ZYD_CMD_RFCFG		0x0023	/* write RF register */
1106188417Sthompsa#define ZYD_NOTIF_IORD		0x9001	/* response for ZYD_CMD_IORD */
1107188417Sthompsa#define ZYD_NOTIF_MACINTR	0x9001	/* interrupt notification */
1108188417Sthompsa#define ZYD_NOTIF_RETRYSTATUS	0xa001	/* Tx retry notification */
1109188417Sthompsa	uint8_t			data[64];
1110184610Salfred} __packed;
1111184610Salfred
1112184610Salfred/* structure for command ZYD_CMD_IOWR */
1113184610Salfredstruct zyd_pair {
1114188417Sthompsa	uint16_t		reg;
1115184610Salfred/* helpers macros to read/write 32-bit registers */
1116188417Sthompsa#define ZYD_REG32_LO(reg)	(reg)
1117188417Sthompsa#define ZYD_REG32_HI(reg)	\
1118184610Salfred	((reg) + ((((reg) & 0xf000) == 0x9000) ? 2 : 1))
1119188417Sthompsa	uint16_t		val;
1120184610Salfred} __packed;
1121184610Salfred
1122184610Salfred/* structure for notification ZYD_NOTIF_RETRYSTATUS */
1123184610Salfredstruct zyd_notif_retry {
1124188417Sthompsa	uint16_t		rate;
1125188417Sthompsa	uint8_t			macaddr[IEEE80211_ADDR_LEN];
1126188417Sthompsa	uint16_t		count;
1127184610Salfred} __packed;
1128184610Salfred
1129188419Sthompsa#define ZYD_CONFIG_INDEX	0
1130188417Sthompsa#define ZYD_IFACE_INDEX		0
1131184610Salfred
1132188417Sthompsa#define ZYD_INTR_TIMEOUT	1000
1133188417Sthompsa#define ZYD_TX_TIMEOUT		10000
1134184610Salfred
1135188417Sthompsa#define ZYD_MAX_TXBUFSZ	\
1136184610Salfred	(sizeof(struct zyd_tx_desc) + MCLBYTES)
1137188417Sthompsa#define ZYD_MIN_FRAGSZ							\
1138184610Salfred	(sizeof(struct zyd_plcphdr) + IEEE80211_MIN_LEN + 		\
1139184610Salfred	 sizeof(struct zyd_rx_stat))
1140188417Sthompsa#define ZYD_MIN_RXBUFSZ	ZYD_MIN_FRAGSZ
1141188417Sthompsa#define ZYX_MAX_RXBUFSZ							\
1142184610Salfred	((sizeof (struct zyd_plcphdr) + IEEE80211_MAX_LEN +		\
1143184610Salfred	  sizeof (struct zyd_rx_stat)) * ZYD_MAX_RXFRAMECNT + 		\
1144184610Salfred	 sizeof (struct zyd_rx_desc))
1145188417Sthompsa#define ZYD_TX_DESC_SIZE	(sizeof (struct zyd_tx_desc))
1146184610Salfred
1147188417Sthompsa#define ZYD_RX_LIST_CNT		1
1148188417Sthompsa#define ZYD_TX_LIST_CNT		5
1149188417Sthompsa#define ZYD_CMD_FLAG_READ	(1 << 0)
1150188417Sthompsa#define ZYD_CMD_FLAG_SENT	(1 << 1)
1151184610Salfred
1152184610Salfred/* quickly determine if a given rate is CCK or OFDM */
1153188417Sthompsa#define ZYD_RATE_IS_OFDM(rate)	((rate) >= 12 && (rate) != 22)
1154184610Salfred
1155184610Salfredstruct zyd_phy_pair {
1156188417Sthompsa	uint16_t		reg;
1157188417Sthompsa	uint8_t			val;
1158184610Salfred};
1159184610Salfred
1160184610Salfredstruct zyd_mac_pair {
1161188417Sthompsa	uint16_t		reg;
1162188417Sthompsa	uint32_t		val;
1163184610Salfred};
1164184610Salfred
1165188417Sthompsastruct zyd_tx_data {
1166188417Sthompsa	STAILQ_ENTRY(zyd_tx_data)	next;
1167188417Sthompsa	struct zyd_softc		*sc;
1168188417Sthompsa	struct zyd_tx_desc		desc;
1169188417Sthompsa	struct mbuf			*m;
1170188417Sthompsa	struct ieee80211_node		*ni;
1171188417Sthompsa	int				rate;
1172188417Sthompsa};
1173188417Sthompsatypedef STAILQ_HEAD(, zyd_tx_data) zyd_txdhead;
1174188417Sthompsa
1175188417Sthompsastruct zyd_rx_data {
1176188417Sthompsa	struct mbuf			*m;
1177188417Sthompsa	int				rssi;
1178188417Sthompsa};
1179188417Sthompsa
1180184610Salfredstruct zyd_rx_radiotap_header {
1181184610Salfred	struct ieee80211_radiotap_header wr_ihdr;
1182188417Sthompsa	uint8_t			wr_flags;
1183188417Sthompsa	uint8_t			wr_rate;
1184188417Sthompsa	uint16_t		wr_chan_freq;
1185188417Sthompsa	uint16_t		wr_chan_flags;
1186188417Sthompsa	int8_t			wr_antsignal;
1187188417Sthompsa	int8_t			wr_antnoise;
1188253757Shselasky} __packed __aligned(8);
1189184610Salfred
1190188417Sthompsa#define ZYD_RX_RADIOTAP_PRESENT						\
1191184610Salfred	((1 << IEEE80211_RADIOTAP_FLAGS) |				\
1192184610Salfred	 (1 << IEEE80211_RADIOTAP_RATE) |				\
1193184610Salfred	 (1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL) |			\
1194184610Salfred	 (1 << IEEE80211_RADIOTAP_DBM_ANTNOISE) |			\
1195184610Salfred	 (1 << IEEE80211_RADIOTAP_CHANNEL))
1196184610Salfred
1197184610Salfredstruct zyd_tx_radiotap_header {
1198184610Salfred	struct ieee80211_radiotap_header wt_ihdr;
1199188417Sthompsa	uint8_t			wt_flags;
1200188417Sthompsa	uint8_t			wt_rate;
1201188417Sthompsa	uint16_t		wt_chan_freq;
1202188417Sthompsa	uint16_t		wt_chan_flags;
1203253757Shselasky} __packed __aligned(8);
1204184610Salfred
1205188417Sthompsa#define ZYD_TX_RADIOTAP_PRESENT						\
1206184610Salfred	((1 << IEEE80211_RADIOTAP_FLAGS) |				\
1207184610Salfred	 (1 << IEEE80211_RADIOTAP_RATE) |				\
1208184610Salfred	 (1 << IEEE80211_RADIOTAP_CHANNEL))
1209184610Salfred
1210188417Sthompsastruct zyd_softc;	/* forward declaration */
1211184610Salfred
1212184610Salfredstruct zyd_rf {
1213184610Salfred	/* RF methods */
1214188417Sthompsa	int			(*init)(struct zyd_rf *);
1215188417Sthompsa	int			(*switch_radio)(struct zyd_rf *, int);
1216188417Sthompsa	int			(*set_channel)(struct zyd_rf *, uint8_t);
1217188417Sthompsa	int			(*bandedge6)(struct zyd_rf *,
1218188417Sthompsa				    struct ieee80211_channel *);
1219188417Sthompsa	/* RF attributes */
1220188417Sthompsa	struct zyd_softc	*rf_sc;	/* back-pointer */
1221188417Sthompsa	int			width;
1222193420Sweongyo	int			idx;	/* for GIT RF */
1223193420Sweongyo	int			update_pwr;
1224184610Salfred};
1225184610Salfred
1226188417Sthompsastruct zyd_rq {
1227188417Sthompsa	struct zyd_cmd		*cmd;
1228188417Sthompsa	const uint16_t		*idata;
1229188417Sthompsa	struct zyd_pair		*odata;
1230188417Sthompsa	int			ilen;
1231188417Sthompsa	int			olen;
1232188417Sthompsa	int			flags;
1233188417Sthompsa	STAILQ_ENTRY(zyd_rq)	rq;
1234184610Salfred};
1235184610Salfred
1236184610Salfredstruct zyd_vap {
1237188417Sthompsa	struct ieee80211vap	vap;
1238188417Sthompsa	int			(*newstate)(struct ieee80211vap *,
1239188417Sthompsa				    enum ieee80211_state, int);
1240184610Salfred};
1241188417Sthompsa#define	ZYD_VAP(vap)	((struct zyd_vap *)(vap))
1242184610Salfred
1243188417Sthompsaenum {
1244188417Sthompsa	ZYD_BULK_WR,
1245188417Sthompsa	ZYD_BULK_RD,
1246188417Sthompsa	ZYD_INTR_WR,
1247188417Sthompsa	ZYD_INTR_RD,
1248188417Sthompsa	ZYD_N_TRANSFER = 4,
1249184610Salfred};
1250184610Salfred
1251188417Sthompsastruct zyd_softc {
1252188417Sthompsa	struct ifnet		*sc_ifp;
1253188417Sthompsa	device_t		sc_dev;
1254192984Sthompsa	struct usb_device	*sc_udev;
1255184610Salfred
1256192984Sthompsa	struct usb_xfer	*sc_xfer[ZYD_N_TRANSFER];
1257184610Salfred
1258188417Sthompsa	int			sc_flags;
1259188419Sthompsa#define	ZYD_FLAG_FWLOADED		(1 << 0)
1260188419Sthompsa#define	ZYD_FLAG_INITONCE		(1 << 1)
1261188419Sthompsa#define	ZYD_FLAG_INITDONE		(1 << 2)
1262246614Shselasky#define	ZYD_FLAG_DETACHED		(1 << 3)
1263184610Salfred
1264188417Sthompsa	struct zyd_rf		sc_rf;
1265184610Salfred
1266188417Sthompsa	STAILQ_HEAD(, zyd_rq)	sc_rtx;
1267188417Sthompsa	STAILQ_HEAD(, zyd_rq)	sc_rqh;
1268184610Salfred
1269188417Sthompsa	uint8_t			sc_bssid[IEEE80211_ADDR_LEN];
1270188417Sthompsa	uint16_t		sc_fwbase;
1271188417Sthompsa	uint8_t			sc_regdomain;
1272188417Sthompsa	uint8_t			sc_macrev;
1273188417Sthompsa	uint16_t		sc_fwrev;
1274188417Sthompsa	uint8_t			sc_rfrev;
1275188417Sthompsa	uint8_t			sc_parev;
1276188417Sthompsa	uint8_t			sc_al2230s;
1277188417Sthompsa	uint8_t			sc_bandedge6;
1278188417Sthompsa	uint8_t			sc_newphy;
1279188417Sthompsa	uint8_t			sc_cckgain;
1280188417Sthompsa	uint8_t			sc_fix_cr157;
1281188417Sthompsa	uint8_t			sc_ledtype;
1282188417Sthompsa	uint8_t			sc_txled;
1283184610Salfred
1284188417Sthompsa	uint32_t		sc_atim_wnd;
1285188417Sthompsa	uint32_t		sc_pre_tbtt;
1286188417Sthompsa	uint32_t		sc_bcn_int;
1287187259Sthompsa
1288188417Sthompsa	uint8_t			sc_pwrcal[14];
1289188417Sthompsa	uint8_t			sc_pwrint[14];
1290188417Sthompsa	uint8_t			sc_ofdm36_cal[14];
1291188417Sthompsa	uint8_t			sc_ofdm48_cal[14];
1292188417Sthompsa	uint8_t			sc_ofdm54_cal[14];
1293184610Salfred
1294188417Sthompsa	struct mtx		sc_mtx;
1295188419Sthompsa	struct zyd_tx_data	tx_data[ZYD_TX_LIST_CNT];
1296188417Sthompsa	zyd_txdhead		tx_q;
1297188417Sthompsa	zyd_txdhead		tx_free;
1298188417Sthompsa	int			tx_nfree;
1299188417Sthompsa	struct zyd_rx_desc	sc_rx_desc;
1300188417Sthompsa	struct zyd_rx_data	sc_rx_data[ZYD_MAX_RXFRAMECNT];
1301188417Sthompsa	int			sc_rx_count;
1302184610Salfred
1303188417Sthompsa	struct zyd_cmd		sc_ibuf;
1304184610Salfred
1305188417Sthompsa	struct zyd_rx_radiotap_header	sc_rxtap;
1306188417Sthompsa	int			sc_rxtap_len;
1307188417Sthompsa	struct zyd_tx_radiotap_header	sc_txtap;
1308188417Sthompsa	int			sc_txtap_len;
1309188417Sthompsa};
1310186730Salfred
1311188417Sthompsa#define	ZYD_LOCK(sc)		mtx_lock(&(sc)->sc_mtx)
1312188417Sthompsa#define	ZYD_UNLOCK(sc)		mtx_unlock(&(sc)->sc_mtx)
1313188417Sthompsa#define	ZYD_LOCK_ASSERT(sc, t)	mtx_assert(&(sc)->sc_mtx, t)
1314184610Salfred
1315