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