249 lines
9.1 KiB
C
249 lines
9.1 KiB
C
|
/*
|
||
|
* SiliconBackplane GCI core hardware definitions
|
||
|
*
|
||
|
* Copyright (C) 1999-2017, Broadcom Corporation
|
||
|
*
|
||
|
* Unless you and Broadcom execute a separate written software license
|
||
|
* agreement governing use of this software, this software is licensed to you
|
||
|
* under the terms of the GNU General Public License version 2 (the "GPL"),
|
||
|
* available at http://www.broadcom.com/licenses/GPLv2.php, with the
|
||
|
* following added to such license:
|
||
|
*
|
||
|
* As a special exception, the copyright holders of this software give you
|
||
|
* permission to link this software with independent modules, and to copy and
|
||
|
* distribute the resulting executable under terms of your choice, provided that
|
||
|
* you also meet, for each linked independent module, the terms and conditions of
|
||
|
* the license of that module. An independent module is a module which is not
|
||
|
* derived from this software. The special exception does not apply to any
|
||
|
* modifications of the software.
|
||
|
*
|
||
|
* Notwithstanding the above, under no circumstances may you combine this
|
||
|
* software in any way with any other Broadcom software provided under a license
|
||
|
* other than the GPL, without Broadcom's express prior written consent.
|
||
|
*
|
||
|
*
|
||
|
* <<Broadcom-WL-IPTag/Open:>>
|
||
|
*
|
||
|
* $Id: sbgci.h 612498 2016-01-14 05:09:09Z $
|
||
|
*/
|
||
|
|
||
|
#ifndef _SBGCI_H
|
||
|
#define _SBGCI_H
|
||
|
|
||
|
#if !defined(_LANGUAGE_ASSEMBLY) && !defined(__ASSEMBLY__)
|
||
|
|
||
|
/* cpp contortions to concatenate w/arg prescan */
|
||
|
#ifndef PAD
|
||
|
#define _PADLINE(line) pad ## line
|
||
|
#define _XSTR(line) _PADLINE(line)
|
||
|
#define PAD _XSTR(__LINE__)
|
||
|
#endif /* PAD */
|
||
|
|
||
|
#define GCI_OFFSETOF(sih, reg) \
|
||
|
(AOB_ENAB(sih) ? OFFSETOF(gciregs_t, reg) : OFFSETOF(chipcregs_t, reg))
|
||
|
#define GCI_CORE_IDX(sih) (AOB_ENAB(sih) ? si_findcoreidx(sih, GCI_CORE_ID, 0) : SI_CC_IDX)
|
||
|
|
||
|
typedef volatile struct {
|
||
|
uint32 gci_corecaps0; /* 0x000 */
|
||
|
uint32 gci_corecaps1; /* 0x004 */
|
||
|
uint32 gci_corecaps2; /* 0x008 */
|
||
|
uint32 gci_corectrl; /* 0x00c */
|
||
|
uint32 gci_corestat; /* 0x010 */
|
||
|
uint32 gci_intstat; /* 0x014 */
|
||
|
uint32 gci_intmask; /* 0x018 */
|
||
|
uint32 gci_wakemask; /* 0x01c */
|
||
|
uint32 gci_levelintstat; /* 0x020 */
|
||
|
uint32 gci_eventintstat; /* 0x024 */
|
||
|
uint32 gci_wakelevelintstat; /* 0x028 */
|
||
|
uint32 gci_wakeeventintstat; /* 0x02c */
|
||
|
uint32 semaphoreintstatus; /* 0x030 */
|
||
|
uint32 semaphoreintmask; /* 0x034 */
|
||
|
uint32 semaphorerequest; /* 0x038 */
|
||
|
uint32 semaphorereserve; /* 0x03c */
|
||
|
uint32 gci_indirect_addr; /* 0x040 */
|
||
|
uint32 gci_gpioctl; /* 0x044 */
|
||
|
uint32 gci_gpiostatus; /* 0x048 */
|
||
|
uint32 gci_gpiomask; /* 0x04c */
|
||
|
uint32 eventsummary; /* 0x050 */
|
||
|
uint32 gci_miscctl; /* 0x054 */
|
||
|
uint32 gci_gpiointmask; /* 0x058 */
|
||
|
uint32 gci_gpiowakemask; /* 0x05c */
|
||
|
uint32 gci_input[32]; /* 0x060 */
|
||
|
uint32 gci_event[32]; /* 0x0e0 */
|
||
|
uint32 gci_output[4]; /* 0x160 */
|
||
|
uint32 gci_control_0; /* 0x170 */
|
||
|
uint32 gci_control_1; /* 0x174 */
|
||
|
uint32 gci_intpolreg; /* 0x178 */
|
||
|
uint32 gci_levelintmask; /* 0x17c */
|
||
|
uint32 gci_eventintmask; /* 0x180 */
|
||
|
uint32 wakelevelintmask; /* 0x184 */
|
||
|
uint32 wakeeventintmask; /* 0x188 */
|
||
|
uint32 hwmask; /* 0x18c */
|
||
|
uint32 PAD;
|
||
|
uint32 gci_inbandeventintmask; /* 0x194 */
|
||
|
uint32 PAD;
|
||
|
uint32 gci_inbandeventstatus; /* 0x19c */
|
||
|
uint32 gci_seciauxtx; /* 0x1a0 */
|
||
|
uint32 gci_seciauxrx; /* 0x1a4 */
|
||
|
uint32 gci_secitx_datatag; /* 0x1a8 */
|
||
|
uint32 gci_secirx_datatag; /* 0x1ac */
|
||
|
uint32 gci_secitx_datamask; /* 0x1b0 */
|
||
|
uint32 gci_seciusef0tx_reg; /* 0x1b4 */
|
||
|
uint32 gci_secif0tx_offset; /* 0x1b8 */
|
||
|
uint32 gci_secif0rx_offset; /* 0x1bc */
|
||
|
uint32 gci_secif1tx_offset; /* 0x1c0 */
|
||
|
uint32 gci_rxfifo_common_ctrl; /* 0x1c4 */
|
||
|
uint32 gci_rxfifoctrl; /* 0x1c8 */
|
||
|
uint32 gci_hw_sema_status; /* 0x1cc */
|
||
|
uint32 gci_seciuartescval; /* 0x1d0 */
|
||
|
uint32 gic_seciuartautobaudctr; /* 0x1d4 */
|
||
|
uint32 gci_secififolevel; /* 0x1d8 */
|
||
|
uint32 gci_seciuartdata; /* 0x1dc */
|
||
|
uint32 gci_secibauddiv; /* 0x1e0 */
|
||
|
uint32 gci_secifcr; /* 0x1e4 */
|
||
|
uint32 gci_secilcr; /* 0x1e8 */
|
||
|
uint32 gci_secimcr; /* 0x1ec */
|
||
|
uint32 gci_secilsr; /* 0x1f0 */
|
||
|
uint32 gci_secimsr; /* 0x1f4 */
|
||
|
uint32 gci_baudadj; /* 0x1f8 */
|
||
|
uint32 gci_inbandintmask; /* 0x1fc */
|
||
|
uint32 gci_chipctrl; /* 0x200 */
|
||
|
uint32 gci_chipsts; /* 0x204 */
|
||
|
uint32 gci_gpioout; /* 0x208 */
|
||
|
uint32 gci_gpioout_read; /* 0x20C */
|
||
|
uint32 gci_mpwaketx; /* 0x210 */
|
||
|
uint32 gci_mpwakedetect; /* 0x214 */
|
||
|
uint32 gci_seciin_ctrl; /* 0x218 */
|
||
|
uint32 gci_seciout_ctrl; /* 0x21C */
|
||
|
uint32 gci_seciin_auxfifo_en; /* 0x220 */
|
||
|
uint32 gci_seciout_txen_txbr; /* 0x224 */
|
||
|
uint32 gci_seciin_rxbrstatus; /* 0x228 */
|
||
|
uint32 gci_seciin_rxerrstatus; /* 0x22C */
|
||
|
uint32 gci_seciin_fcstatus; /* 0x230 */
|
||
|
uint32 gci_seciout_txstatus; /* 0x234 */
|
||
|
uint32 gci_seciout_txbrstatus; /* 0x238 */
|
||
|
uint32 wlan_mem_info; /* 0x23C */
|
||
|
uint32 wlan_bankxinfo; /* 0x240 */
|
||
|
uint32 bt_smem_select; /* 0x244 */
|
||
|
uint32 bt_smem_stby; /* 0x248 */
|
||
|
uint32 bt_smem_status; /* 0x24C */
|
||
|
uint32 wlan_bankxactivepda; /* 0x250 */
|
||
|
uint32 wlan_bankxsleeppda; /* 0x254 */
|
||
|
uint32 wlan_bankxkill; /* 0x258 */
|
||
|
uint32 PAD[41];
|
||
|
uint32 gci_chipid; /* 0x300 */
|
||
|
uint32 PAD[3];
|
||
|
uint32 otpstatus; /* 0x310 */
|
||
|
uint32 otpcontrol; /* 0x314 */
|
||
|
uint32 otpprog; /* 0x318 */
|
||
|
uint32 otplayout; /* 0x31c */
|
||
|
uint32 otplayoutextension; /* 0x320 */
|
||
|
uint32 otpcontrol1; /* 0x324 */
|
||
|
uint32 otpprogdata; /* 0x328 */
|
||
|
uint32 PAD[52];
|
||
|
uint32 otpECCstatus; /* 0x3FC */
|
||
|
uint32 PAD[512];
|
||
|
uint32 lhl_core_capab_adr; /* 0xC00 */
|
||
|
uint32 lhl_main_ctl_adr; /* 0xC04 */
|
||
|
uint32 lhl_pmu_ctl_adr; /* 0xC08 */
|
||
|
uint32 lhl_extlpo_ctl_adr; /* 0xC0C */
|
||
|
uint32 lpo_ctl_adr; /* 0xC10 */
|
||
|
uint32 lhl_lpo2_ctl_adr; /* 0xC14 */
|
||
|
uint32 lhl_osc32k_ctl_adr; /* 0xC18 */
|
||
|
uint32 lhl_clk_status_adr; /* 0xC1C */
|
||
|
uint32 lhl_clk_det_ctl_adr; /* 0xC20 */
|
||
|
uint32 lhl_clk_sel_adr; /* 0xC24 */
|
||
|
uint32 hidoff_cnt_adr[2]; /* 0xC28-0xC2C */
|
||
|
uint32 lhl_autoclk_ctl_adr; /* 0xC30 */
|
||
|
uint32 PAD; /* reserved */
|
||
|
uint32 lhl_hibtim_adr; /* 0xC38 */
|
||
|
uint32 lhl_wl_ilp_val_adr; /* 0xC3C */
|
||
|
uint32 lhl_wl_armtim0_intrp_adr; /* 0xC40 */
|
||
|
uint32 lhl_wl_armtim0_st_adr; /* 0xC44 */
|
||
|
uint32 lhl_wl_armtim0_adr; /* 0xC48 */
|
||
|
uint32 PAD[9]; /* 0xC4C-0xC6C */
|
||
|
uint32 lhl_wl_mactim0_intrp_adr; /* 0xC70 */
|
||
|
uint32 lhl_wl_mactim0_st_adr; /* 0xC74 */
|
||
|
uint32 lhl_wl_mactim_int0_adr; /* 0xC78 */
|
||
|
uint32 lhl_wl_mactim_frac0_adr; /* 0xC7C */
|
||
|
uint32 lhl_wl_mactim1_intrp_adr; /* 0xC80 */
|
||
|
uint32 lhl_wl_mactim1_st_adr; /* 0xC84 */
|
||
|
uint32 lhl_wl_mactim_int1_adr; /* 0xC88 */
|
||
|
uint32 lhl_wl_mactim_frac1_adr; /* 0xC8C */
|
||
|
uint32 PAD[8]; /* 0xC90-0xCAC */
|
||
|
uint32 gpio_int_en_port_adr[4]; /* 0xCB0-0xCBC */
|
||
|
uint32 gpio_int_st_port_adr[4]; /* 0xCC0-0xCCC */
|
||
|
uint32 gpio_ctrl_iocfg_p_adr[64]; /* 0xCD0-0xDCC */
|
||
|
uint32 gpio_gctrl_iocfg_p0_p39_adr; /* 0xDD0 */
|
||
|
uint32 gpio_gdsctrl_iocfg_p0_p25_p30_p39_adr; /* 0xDD4 */
|
||
|
uint32 gpio_gdsctrl_iocfg_p26_p29_adr; /* 0xDD8 */
|
||
|
uint32 PAD[8]; /* 0xDDC-0xDF8 */
|
||
|
uint32 lhl_gpio_din0_adr; /* 0xDFC */
|
||
|
uint32 lhl_gpio_din1_adr; /* 0xE00 */
|
||
|
uint32 lhl_wkup_status_adr; /* 0xE04 */
|
||
|
uint32 lhl_ctl_adr; /* 0xE08 */
|
||
|
uint32 lhl_adc_ctl_adr; /* 0xE0C */
|
||
|
uint32 lhl_qdxyz_in_dly_adr; /* 0xE10 */
|
||
|
uint32 lhl_optctl_adr; /* 0xE14 */
|
||
|
uint32 lhl_optct2_adr; /* 0xE18 */
|
||
|
uint32 lhl_scanp_cntr_init_val_adr; /* 0xE1C */
|
||
|
uint32 lhl_opt_togg_val_adr[6]; /* 0xE20-0xE34 */
|
||
|
uint32 lhl_optx_smp_val_adr; /* 0xE38 */
|
||
|
uint32 lhl_opty_smp_val_adr; /* 0xE3C */
|
||
|
uint32 lhl_optz_smp_val_adr; /* 0xE40 */
|
||
|
uint32 lhl_hidoff_keepstate_adr[3]; /* 0xE44-0xE4C */
|
||
|
uint32 lhl_bt_slmboot_ctl0_adr[4]; /* 0xE50-0xE5C */
|
||
|
uint32 lhl_wl_fw_ctl; /* 0xE60 */
|
||
|
uint32 lhl_wl_hw_ctl_adr[2]; /* 0xE64-0xE68 */
|
||
|
uint32 lhl_bt_hw_ctl_adr; /* 0xE6C */
|
||
|
uint32 lhl_top_pwrseq_en_adr; /* 0xE70 */
|
||
|
uint32 lhl_top_pwrdn_ctl_adr; /* 0xE74 */
|
||
|
uint32 lhl_top_pwrup_ctl_adr; /* 0xE78 */
|
||
|
uint32 lhl_top_pwrseq_ctl_adr; /* 0xE7C */
|
||
|
uint32 lhl_top_pwrdn2_ctl_adr; /* 0xE80 */
|
||
|
uint32 lhl_top_pwrup2_ctl_adr; /* 0xE84 */
|
||
|
uint32 wpt_regon_intrp_cfg_adr; /* 0xE88 */
|
||
|
uint32 bt_regon_intrp_cfg_adr; /* 0xE8C */
|
||
|
uint32 wl_regon_intrp_cfg_adr; /* 0xE90 */
|
||
|
uint32 regon_intrp_st_adr; /* 0xE94 */
|
||
|
uint32 regon_intrp_en_adr; /* 0xE98 */
|
||
|
} gciregs_t;
|
||
|
|
||
|
#define GCI_CAP0_REV_MASK 0x000000ff
|
||
|
|
||
|
/* GCI Capabilities registers */
|
||
|
#define GCI_CORE_CAP_0_COREREV_MASK 0xFF
|
||
|
#define GCI_CORE_CAP_0_COREREV_SHIFT 0
|
||
|
|
||
|
#define GCI_INDIRECT_ADDRESS_REG_REGINDEX_MASK 0x3F
|
||
|
#define GCI_INDIRECT_ADDRESS_REG_REGINDEX_SHIFT 0
|
||
|
#define GCI_INDIRECT_ADDRESS_REG_GPIOINDEX_MASK 0xF
|
||
|
#define GCI_INDIRECT_ADDRESS_REG_GPIOINDEX_SHIFT 16
|
||
|
|
||
|
#define WLAN_BANKX_SLEEPPDA_REG_SLEEPPDA_MASK 0xFFFF
|
||
|
|
||
|
#define WLAN_BANKX_PKILL_REG_SLEEPPDA_MASK 0x1
|
||
|
|
||
|
/* WLAN BankXInfo Register */
|
||
|
#define WLAN_BANKXINFO_BANK_SIZE_MASK 0x00FFF000
|
||
|
#define WLAN_BANKXINFO_BANK_SIZE_SHIFT 12
|
||
|
|
||
|
/* WLAN Mem Info Register */
|
||
|
#define WLAN_MEM_INFO_REG_NUMSOCRAMBANKS_MASK 0x000000FF
|
||
|
#define WLAN_MEM_INFO_REG_NUMSOCRAMBANKS_SHIFT 0
|
||
|
|
||
|
#define WLAN_MEM_INFO_REG_NUMD11MACBM_MASK 0x0000FF00
|
||
|
#define WLAN_MEM_INFO_REG_NUMD11MACBM_SHIFT 8
|
||
|
|
||
|
#define WLAN_MEM_INFO_REG_NUMD11MACUCM_MASK 0x00FF0000
|
||
|
#define WLAN_MEM_INFO_REG_NUMD11MACUCM_SHIFT 16
|
||
|
|
||
|
#define WLAN_MEM_INFO_REG_NUMD11MACSHM_MASK 0xFF000000
|
||
|
#define WLAN_MEM_INFO_REG_NUMD11MACSHM_SHIFT 24
|
||
|
|
||
|
|
||
|
#endif /* !_LANGUAGE_ASSEMBLY && !__ASSEMBLY__ */
|
||
|
|
||
|
|
||
|
#endif /* _SBGCI_H */
|