linux/drivers/net/wireless/broadcom/brcm80211/include/chipcommon.h
<<
>>
Prefs
   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