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