1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
|
/* $OpenBSD: bcwreg.h,v 1.2 2006/11/17 20:49:27 mglocker Exp $ */
/*
* Copyright (c) 2006 Jon Simola <jsimola@gmail.com>
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
*/
/* Broadcom BCM43xx */
/* PCI registers defined in the PCI 2.2 spec. */
#define BCW_PCI_BAR0 0x10
/* Saved Interrupt mask */
#define BCW_SAVEDINTRMASK 0xb007a864
/* Sonics SB register access */
#define BCW_ADDR_SPACE0 0x80
#define BCW_ADDR_SPACE1 0x84
#define BCW_REG0_WIN 0x80
#define BCW_REG1_WIN 0x84
#define BCW_SPROM_CONTROL 0x88
#define BCW_ADDR1_BURST_CONTROL 0x8C
#define BCW_PCII 0x90
#define BCW_PCICR 0x94
#define BCW_BI 0x98
#define BCW_PCICI 0xB0
#define BCW_PCICO 0xB4
#define BCW_PCICOE 0xB8
#define BCW_GPIOI 0xB0 /* GPIO IN */
#define BCW_GPIOO 0xB4 /* GPIO OUT */
#define BCW_GPIOE 0xB8 /* GPIO ENABLE */
/* Some bitmasks */
#define BCW_XTALPOWERUP 0x40
#define BCW_PLLPOWERDOWN 0x80
/* Core select address macro */
#define BCW_CORE_SELECT(x) (0x18000000 + (x * 0x1000))
/* Some Core Types */
#define BCW_CORE_COMMON 0x800
#define BCW_CORE_PCI 0x804
#define BCW_CORE_ENET 0x806
#define BCW_CORE_80211 0x812
#define BCW_CORE_PCIE 0x820
#define BCW_CORE_MIMOPHY 0x821
#define BCW_CORE_COMMON_CHIPID 0x0
/* Core Info Registers */
#define BCW_CIR_SBID_HI 0xffc
#define BCW_CIR_SBID_LO 0xff8
#define BCW_SBTMSTATELOW 0x0f98
#define BCW_SBTMSTATEHI 0x0f9C
#define BCW_SONICS_WIN 0x18002000
/* Sonics PCI control */
#define BCW_SPCI_TR2 0x0108 /* Sonics to PCI translation
* 2 */
/* bit defines */
#define SBTOPCI_PREF 0x4 /* prefetch enable */
#define SBTOPCI_BURST 0x8 /* burst enable */
#define BCW_SBINTVEC 0x0f94
/* interrupt bits */
#define SBIV_ENET0 0x02 /* enable for enet 0 */
#define SBIV_ENET1 0x40 /* enable for enet 1 */
/* Host Interface Registers */
#define BCW_DEVCTL 0x0000 /* device control */
/* device control bits */
#define BCW_DC_IP 0x00000400 /* internal phy present */
#define BCW_DC_ER 0x00008000 /* ephy reset */
/* Interrupt Control */
#define BCW_INT_STS 0x0020
#define BCW_INT_MASK 0x0024
/* bits for both status, and mask */
#define I_TO 0x00000080 /* general timeout */
#define I_PC 0x00000400 /* descriptor error */
#define I_PD 0x00000800 /* data error */
#define I_DE 0x00001000 /* desc. protocol error */
#define I_RU 0x00002000 /* rx desc. underflow */
#define I_RO 0x00004000 /* rx fifo overflow */
#define I_XU 0x00008000 /* tx fifo underflow */
#define I_RI 0x00010000 /* receive interrupt */
#define I_XI 0x01000000 /* transmit interrupt */
/* Ethernet MAC Control */
#define BCW_MACCTL 0x00A8 /* ethernet mac control */
/* mac control bits */
#define BCW_EMC_CRC32_ENAB 0x00000001 /* crc32 generation */
#define BCW_EMC_PDOWN 0x00000004 /* PHY powerdown */
#define BCW_EMC_EDET 0x00000008 /* PHY energy detect */
#define BCW_EMC_LED 0x000000e0 /* PHY LED control */
/* DMA Interrupt control */
#define BCW_DMAI_CTL 0x0100
/* DMA registers */
#define BCW_DMA_TXCTL 0x0200 /* transmit control */
/* transmit control bits */
#define XC_XE 0x1 /* transmit enable */
#define XC_LE 0x4 /* loopback enable */
#define BCW_DMA_TXADDR 0x0204 /* tx ring base address */
#define BCW_DMA_DPTR 0x0208 /* last tx descriptor */
#define BCW_DMA_TXSTATUS 0x020C /* active desc, etc */
#define BCW_DMA_RXCTL 0x0210 /* enable, etc */
#define BCW_DMA_RXADDR 0x0214 /* rx ring base address */
#define BCW_DMA_RXDPTR 0x0218 /* last descriptor */
#define BCW_DMA_RXSTATUS 0x021C /* active desc, etc */
/* receive status bits */
#define RS_CD_MASK 0x0fff /* current descriptor pointer */
#define RS_DMA_IDLE 0x2000 /* DMA is idle */
#define RS_ERROR 0xf0000 /* had an error */
/* Ethernet MAC control registers */
#define BCW_RX_CTL 0x0400 /* receive config */
/* config bits */
#define ERC_DB 0x00000001 /* disable broadcast */
#define ERC_AM 0x00000002 /* rx all multicast */
#define ERC_PE 0x00000008 /* promiscuous enable */
#define BCW_RX_MAX 0x0404 /* max packet length */
#define BCW_TX_MAX 0x0408
#define BCW_MI_CTL 0x0410
#define BCW_MI_COMM 0x0414
#define BCW_MI_STS 0x041C
/* mii status bits */
#define BCW_MIINTR 0x00000001 /* mii mdio interrupt */
#define BCW_FILT_LOW 0x0420 /* mac low 4 bytes */
#define BCW_FILT_HI 0x0424 /* mac hi 2 bytes */
#define BCW_FILT_CTL 0x0428 /* packet filter ctrl */
#define BCW_ENET_CTL 0x042C
/* bits for mac control */
#define EC_EE 0x00000001 /* emac enable */
#define EC_ED 0x00000002 /* disable emac */
#define EC_ES 0x00000004 /* soft reset emac */
#define EC_EP 0x00000008 /* external phy */
#define BCW_TX_CTL 0x0430
/* bits for transmit control */
#define EXC_FD 0x00000001 /* full duplex */
#define BCW_TX_WATER 0x0434 /* tx watermark */
/* statistics counters */
#define BCW_RX_PKTS 0x058C
/* SiliconBackplane registers */
#define BCW_SBIMSTATE 0x0f90
#define BCW_SBTMSTATELOW 0x0f98
#define BCW_SBTMSTATEHI 0x0f9C
#define SBTML_RESET 0x1 /* reset */
#define SBTML_REJ 0x6 /* reject */
#define SBTML_CLK 0x10000 /* clock enable */
#define SBTML_FGC 0x20000 /* force gated clocks on */
#define SBTML_80211FLAG 0x40000 /* core specific flag */
#define SBTML_80211PHY 0x20000000 /* Attach PHY */
#define SBTMH_BUSY 0x4
#define SBIM_MAGIC_ERRORBITS 0x60000
/*
* MMIO Registers by offset, followed by indented bitmasks
*/
#define BCW_SPROM_CONTROL 0x88 /* SPROM Control register */
#define BCW_SBF 0x120 /* MIMO - Status Bit Field */
#define BCW_SBF_MAC_ENABLED 0x00000001 /* Set when mac enabled */
#define BCW_SBF_CORE_READY 0x00000004 /* set after core reset/enabled */
#define BCW_SBF_REGISTER_BYTESWAP 0x00010000 /* xfer regs are byteswapped in hw */
#define BCW_SBF_ADHOC 0x00020000 /* Operating mode is not adhoc */
#define BCW_SBF_AP 0x00040000 /* Device is in AP mode */
#define BCW_SBF_RADIOREG_LOCK 0x00080000 /* Radio Registers locked for use */
#define BCW_SBF_MONITOR 0x00400000 /* Pass HW handled control frames
* to driver, needs PROMISC also */
#define BCW_SBF_PROMISC 0x01000000 /* Device is in promiscuous mode */
#define BCW_SBF_PS1 0x02000000 /* Power saving bit 1 - unknown */
#define BCW_SBF_PS2 0x04000000 /* bit 2 - Device is awake */
#define BCW_SBF_SSID_BCAST 0x08000000 /* set = SSID bcast is disabled
* unset = SSID bcast enabled */
#define BCW_SBF_TIME_UPDATE 0x10000000 /* Related to TSF updates */
#define BCW_GIR 0x128 /* MIMO - Generic Interrupt Reason */
#define BCW_SHM_CONTROL 0x160 /* Control */
#define BCW_SHM_DATA 0x164 /* Data - 32bit */
#define BCW_SHM_DATALOW 0x164 /* Data Low - 16bit */
#define BCW_SHM_DATAHIGH 0x166 /* Data High - 16 bit */
#define BCW_SHM_CONTROL_SHARED 0x0001 /* Select SHM Routing shared memory */
#define BCW_SHM_CONTROL_80211 0x0002 /* Select 80211 settings */
#define BCW_SHM_CONTROL_PCM 0x0003 /* Select PCM data */
#define BCW_SHM_CONTROL_HWMAC 0x0004 /* Security Hardware MAC Address list */
#define BCW_SHM_CONTROL_MCODE 0x0300 /* Microcode */
#define BCW_SHM_CONTROL_INIMCODE 0x0301 /* Initial Value Microcode? */
/* SHM Addresses */
#define BCW_SHM_MICROCODEFLAGSLOW 0x005e /* Flags for Microcode ops */
#define BCW_SHM_MICROCODEFLAGSHIGH 0x0060 /* Flags for Microcode ops */
/* http://bcm-specs.sipsolutions.net/MicrocodeFlagsBitfield */
#define BCW_SHM_MICROCODEFLAGS
/* 0x200 DMA Register space */
/* 0x300 PIO Register space */
#define BCW_RADIO_CONTROL 0x3f6 /* Control - 16bit */
#define BCW_RADIO_DATA 0x3fa /* Data - 16bit */
#define BCW_RADIO_DATALOW 0x3fa /* Data Low - 16bit */
#define BCW_RADIO_DATAHIGH 0x3f8 /* Data High - 16 bit */
#define BCW_RADIO_ID 0x01 /* Radio ID offset */
#define BCW_PHY_CONTROL 0x3fc /* Control - 16bit */
#define BCW_PHY_DATA 0x3fe /* Data - 16bit */
/* SPROM registers are 16 bit and based at MMIO offset 0x1000 */
#define BCW_MMIO_BASE 0x1000
#define BCW_SPROM_IL0MACADDR 0x1048 /* 802.11b/g MAC */
#define BCW_SPROM_ET0MACADDR 0x104e /* ethernet MAC */
#define BCW_SPROM_ET1MACADDR 0x1054 /* 802.11a MAC */
#define BCW_SPROM_PA0B0 0x105e
#define BCW_SPROM_PA0B1 0x1060
#define BCW_SPROM_PA0B2 0x1062
#define BCW_SPROM_PAMAXPOWER 0x1066 /* 7-0 for A, 15-8 for B/G */
#define BCW_SPROM_PA1B0 0x106a
#define BCW_SPROM_PA1B1 0x106c
#define BCW_SPROM_PA1B2 0x106e
#define BCW_SPROM_IDLETSSI 0x1070 /* As below */
#define BCW_SPROM_ANTGAIN 0x1074 /* bits 7-0 for an A PHY
bits 15-8 for B/G PHYs */
#define BCW_PHY_TYPEA 0x0 /* 802.11a PHY */
#define BCW_PHY_TYPEB 0x1 /* 802.11b PHY */
#define BCW_PHY_TYPEG 0x2 /* 802.11g PHY */
#define BCW_PHY_TYPEN 0x4 /* 802.11n PHY */
#define BCW_READ8(regs, ofs) \
((*(regs)->r_read8)(regs, ofs))
#define BCW_READ16(regs, ofs) \
((*(regs)->r_read16)(regs, ofs))
#define BCW_READ32(regs, ofs) \
((*(regs)->r_read32)(regs, ofs))
#define BCW_WRITE8(regs, ofs, val) \
((*(regs)->r_write8)(regs, ofs, val))
#define BCW_WRITE16(regs, ofs, val) \
((*(regs)->r_write16)(regs, ofs, val))
#define BCW_WRITE32(regs, ofs, val) \
((*(regs)->r_write32)(regs, ofs, val))
#define BCW_ISSET(regs, reg, mask) \
(BCW_READ32((regs), (reg)) & (mask))
#define BCW_CLR(regs, reg, mask) \
BCW_WRITE32((regs), (reg), BCW_READ32((regs), (reg)) & ~(mask))
|