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