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 24struct 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 */ 304