2 * Copyright (c) 2010 Broadcom Corporation
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.
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.
20 #include "defs.h" /* for PAD macro */
22 #define CHIPCREGOFFS(field) offsetof(struct chipcregs, field)
27 u32 corecontrol
; /* corerev >= 1 */
31 u32 otpstatus
; /* 0x10, corerev >= 10 */
34 u32 otplayout
; /* corerev >= 23 */
36 /* Interrupt control */
37 u32 intstatus
; /* 0x20 */
40 /* Chip specific regs */
41 u32 chipcontrol
; /* 0x28, rev >= 11 */
42 u32 chipstatus
; /* 0x2c, rev >= 11 */
45 u32 jtagcmd
; /* 0x30, rev >= 10 */
50 /* serial flash interface registers */
51 u32 flashcontrol
; /* 0x40 */
56 /* Silicon backplane configuration broadcast control */
57 u32 broadcastaddress
; /* 0x50 */
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 */
70 /* GPIO events corerev >= 11 */
75 u32 watchdog
; /* 0x80 */
77 /* GPIO events corerev >= 11 */
78 u32 gpioeventintpolarity
;
80 /* GPIO based LED powersave registers corerev >= 16 */
81 u32 gpiotimerval
; /* 0x88 */
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 */
94 /* pll delay registers (corerev >= 4) */
95 u32 pll_on_delay
; /* 0xb0 */
97 u32 slow_clk_ctl
; /* 5 < corerev < 10 */
100 /* Instaclock registers (corerev >= 10) */
101 u32 system_clk_ctl
; /* 0xc0 */
105 /* Indirect backplane access (corerev >= 22) */
106 u32 bp_addrlow
; /* 0xd0 */
113 /* More clock dividers (corerev >= 32) */
117 /* In AI chips, pointer to erom */
118 u32 eromptr
; /* 0xfc */
120 /* ExtBus control registers (corerev >= 3) */
121 u32 pcmcia_config
; /* 0x100 */
133 u32 SECI_config
; /* 0x130 SECI configuration */
136 /* Enhanced Coexistence Interface (ECI) registers (corerev >= 21) */
137 u32 eci_output
; /* 0x140 */
142 u32 eci_inputintpolaritylo
;
143 u32 eci_inputintpolaritymi
;
144 u32 eci_inputintpolarityhi
;
156 /* SROM interface (corerev >= 32) */
157 u32 sromcontrol
; /* 0x190 */
162 /* Clock control and hardware workarounds (corerev >= 20) */
163 u32 clk_ctl_st
; /* 0x1e0 */
168 u8 uart0data
; /* 0x300 */
176 u8 PAD
[248]; /* corerev >= 1 */
178 u8 uart1data
; /* 0x400 */
188 /* PMU registers (corerev >= 20) */
189 u32 pmucontrol
; /* 0x600 */
203 u32 gpiosel
; /* 0x638, rev >= 1 */
204 u32 gpioenable
; /* 0x63c, rev >= 1 */
205 u32 res_req_timer_sel
;
208 u32 pmucapabilities_ext
; /* 0x64c, pmurev >=15 */
209 u32 chipcontrol_addr
; /* 0x650 */
210 u32 chipcontrol_data
; /* 0x654 */
215 u32 pmustrapopt
; /* 0x668, corerev >= 28 */
216 u32 pmu_xtalfreq
; /* 0x66C, pmurev >= 10 */
217 u32 retention_ctl
; /* 0x670, pmurev >= 15 */
219 u32 retention_grpidx
; /* 0x680 */
220 u32 retention_grpctl
; /* 0x684 */
226 #define CID_ID_MASK 0x0000ffff /* Chip Id mask */
227 #define CID_REV_MASK 0x000f0000 /* Chip Revision mask */
228 #define CID_REV_SHIFT 16 /* Chip Revision shift */
229 #define CID_PKG_MASK 0x00f00000 /* Package Option mask */
230 #define CID_PKG_SHIFT 20 /* Package Option shift */
231 #define CID_CC_MASK 0x0f000000 /* CoreCount (corerev >= 4) */
232 #define CID_CC_SHIFT 24
233 #define CID_TYPE_MASK 0xf0000000 /* Chip Type */
234 #define CID_TYPE_SHIFT 28
237 #define CC_CAP_UARTS_MASK 0x00000003 /* Number of UARTs */
238 #define CC_CAP_MIPSEB 0x00000004 /* MIPS is in big-endian mode */
239 #define CC_CAP_UCLKSEL 0x00000018 /* UARTs clock select */
240 /* UARTs are driven by internal divided clock */
241 #define CC_CAP_UINTCLK 0x00000008
242 #define CC_CAP_UARTGPIO 0x00000020 /* UARTs own GPIOs 15:12 */
243 #define CC_CAP_EXTBUS_MASK 0x000000c0 /* External bus mask */
244 #define CC_CAP_EXTBUS_NONE 0x00000000 /* No ExtBus present */
245 #define CC_CAP_EXTBUS_FULL 0x00000040 /* ExtBus: PCMCIA, IDE & Prog */
246 #define CC_CAP_EXTBUS_PROG 0x00000080 /* ExtBus: ProgIf only */
247 #define CC_CAP_FLASH_MASK 0x00000700 /* Type of flash */
248 #define CC_CAP_PLL_MASK 0x00038000 /* Type of PLL */
249 #define CC_CAP_PWR_CTL 0x00040000 /* Power control */
250 #define CC_CAP_OTPSIZE 0x00380000 /* OTP Size (0 = none) */
251 #define CC_CAP_OTPSIZE_SHIFT 19 /* OTP Size shift */
252 #define CC_CAP_OTPSIZE_BASE 5 /* OTP Size base */
253 #define CC_CAP_JTAGP 0x00400000 /* JTAG Master Present */
254 #define CC_CAP_ROM 0x00800000 /* Internal boot rom active */
255 #define CC_CAP_BKPLN64 0x08000000 /* 64-bit backplane */
256 #define CC_CAP_PMU 0x10000000 /* PMU Present, rev >= 20 */
257 #define CC_CAP_SROM 0x40000000 /* Srom Present, rev >= 32 */
258 /* Nand flash present, rev >= 35 */
259 #define CC_CAP_NFLASH 0x80000000
261 #define CC_CAP2_SECI 0x00000001 /* SECI Present, rev >= 36 */
262 /* GSIO (spi/i2c) present, rev >= 37 */
263 #define CC_CAP2_GSIO 0x00000002
265 /* pmucapabilities */
266 #define PCAP_REV_MASK 0x000000ff
267 #define PCAP_RC_MASK 0x00001f00
268 #define PCAP_RC_SHIFT 8
269 #define PCAP_TC_MASK 0x0001e000
270 #define PCAP_TC_SHIFT 13
271 #define PCAP_PC_MASK 0x001e0000
272 #define PCAP_PC_SHIFT 17
273 #define PCAP_VC_MASK 0x01e00000
274 #define PCAP_VC_SHIFT 21
275 #define PCAP_CC_MASK 0x1e000000
276 #define PCAP_CC_SHIFT 25
277 #define PCAP5_PC_MASK 0x003e0000 /* PMU corerev >= 5 */
278 #define PCAP5_PC_SHIFT 17
279 #define PCAP5_VC_MASK 0x07c00000
280 #define PCAP5_VC_SHIFT 22
281 #define PCAP5_CC_MASK 0xf8000000
282 #define PCAP5_CC_SHIFT 27
283 /* pmucapabilites_ext PMU rev >= 15 */
284 #define PCAPEXT_SR_SUPPORTED_MASK (1 << 1)
285 /* retention_ctl PMU rev >= 15 */
286 #define PMU_RCTL_MACPHY_DISABLE_MASK (1 << 26)
287 #define PMU_RCTL_LOGIC_DISABLE_MASK (1 << 27)
291 * Maximum delay for the PMU state transition in us.
292 * This is an upper bound intended for spinwaits etc.
294 #define PMU_MAX_TRANSITION_DLY 15000
296 #endif /* _SBCHIPC_H */