mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2024-12-22 18:22:25 +02:00
796a9d1091
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@15242 3c298f89-4303-0410-b956-a3cf2f4a3e73
391 lines
13 KiB
C
391 lines
13 KiB
C
/*
|
|
* Broadcom device-specific manifest constants.
|
|
*
|
|
* Copyright 2005, Broadcom Corporation
|
|
* All Rights Reserved.
|
|
*
|
|
* THIS SOFTWARE IS OFFERED "AS IS", AND BROADCOM GRANTS NO WARRANTIES OF ANY
|
|
* KIND, EXPRESS OR IMPLIED, BY STATUTE, COMMUNICATION OR OTHERWISE. BROADCOM
|
|
* SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS
|
|
* FOR A SPECIFIC PURPOSE OR NONINFRINGEMENT CONCERNING THIS SOFTWARE.
|
|
*/
|
|
|
|
#ifndef _BCMDEVS_H
|
|
#define _BCMDEVS_H
|
|
|
|
|
|
/* Known PCI vendor Id's */
|
|
#define VENDOR_EPIGRAM 0xfeda
|
|
#define VENDOR_BROADCOM 0x14e4
|
|
#define VENDOR_3COM 0x10b7
|
|
#define VENDOR_NETGEAR 0x1385
|
|
#define VENDOR_DIAMOND 0x1092
|
|
#define VENDOR_DELL 0x1028
|
|
#define VENDOR_HP 0x0e11
|
|
#define VENDOR_APPLE 0x106b
|
|
|
|
/* PCI Device Id's */
|
|
#define BCM4210_DEVICE_ID 0x1072 /* never used */
|
|
#define BCM4211_DEVICE_ID 0x4211
|
|
#define BCM4230_DEVICE_ID 0x1086 /* never used */
|
|
#define BCM4231_DEVICE_ID 0x4231
|
|
|
|
#define BCM4410_DEVICE_ID 0x4410 /* bcm44xx family pci iline */
|
|
#define BCM4430_DEVICE_ID 0x4430 /* bcm44xx family cardbus iline */
|
|
#define BCM4412_DEVICE_ID 0x4412 /* bcm44xx family pci enet */
|
|
#define BCM4432_DEVICE_ID 0x4432 /* bcm44xx family cardbus enet */
|
|
|
|
#define BCM3352_DEVICE_ID 0x3352 /* bcm3352 device id */
|
|
#define BCM3360_DEVICE_ID 0x3360 /* bcm3360 device id */
|
|
|
|
#define EPI41210_DEVICE_ID 0xa0fa /* bcm4210 */
|
|
#define EPI41230_DEVICE_ID 0xa10e /* bcm4230 */
|
|
|
|
#define BCM47XX_ILINE_ID 0x4711 /* 47xx iline20 */
|
|
#define BCM47XX_V90_ID 0x4712 /* 47xx v90 codec */
|
|
#define BCM47XX_ENET_ID 0x4713 /* 47xx enet */
|
|
#define BCM47XX_EXT_ID 0x4714 /* 47xx external i/f */
|
|
#define BCM47XX_USB_ID 0x4715 /* 47xx usb */
|
|
#define BCM47XX_USBH_ID 0x4716 /* 47xx usb host */
|
|
#define BCM47XX_USBD_ID 0x4717 /* 47xx usb device */
|
|
#define BCM47XX_IPSEC_ID 0x4718 /* 47xx ipsec */
|
|
#define BCM47XX_ROBO_ID 0x4719 /* 47xx/53xx roboswitch core */
|
|
#define BCM47XX_USB20H_ID 0x471a /* 47xx usb 2.0 host */
|
|
#define BCM47XX_USB20D_ID 0x471b /* 47xx usb 2.0 device */
|
|
|
|
#define BCM4710_DEVICE_ID 0x4710 /* 4710 primary function 0 */
|
|
|
|
#define BCM4610_DEVICE_ID 0x4610 /* 4610 primary function 0 */
|
|
#define BCM4610_ILINE_ID 0x4611 /* 4610 iline100 */
|
|
#define BCM4610_V90_ID 0x4612 /* 4610 v90 codec */
|
|
#define BCM4610_ENET_ID 0x4613 /* 4610 enet */
|
|
#define BCM4610_EXT_ID 0x4614 /* 4610 external i/f */
|
|
#define BCM4610_USB_ID 0x4615 /* 4610 usb */
|
|
|
|
#define BCM4402_DEVICE_ID 0x4402 /* 4402 primary function 0 */
|
|
#define BCM4402_ENET_ID 0x4402 /* 4402 enet */
|
|
#define BCM4402_V90_ID 0x4403 /* 4402 v90 codec */
|
|
#define BCM4401_ENET_ID 0x170c /* 4401b0 production enet cards */
|
|
|
|
#define BCM4301_DEVICE_ID 0x4301 /* 4301 primary function 0 */
|
|
#define BCM4301_D11B_ID 0x4301 /* 4301 802.11b */
|
|
|
|
#define BCM4307_DEVICE_ID 0x4307 /* 4307 primary function 0 */
|
|
#define BCM4307_V90_ID 0x4305 /* 4307 v90 codec */
|
|
#define BCM4307_ENET_ID 0x4306 /* 4307 enet */
|
|
#define BCM4307_D11B_ID 0x4307 /* 4307 802.11b */
|
|
|
|
#define BCM4306_DEVICE_ID 0x4306 /* 4306 chipcommon chipid */
|
|
#define BCM4306_D11G_ID 0x4320 /* 4306 802.11g */
|
|
#define BCM4306_D11G_ID2 0x4325
|
|
#define BCM4306_D11A_ID 0x4321 /* 4306 802.11a */
|
|
#define BCM4306_UART_ID 0x4322 /* 4306 uart */
|
|
#define BCM4306_V90_ID 0x4323 /* 4306 v90 codec */
|
|
#define BCM4306_D11DUAL_ID 0x4324 /* 4306 dual A+B */
|
|
|
|
#define BCM4309_PKG_ID 1 /* 4309 package id */
|
|
|
|
#define BCM4303_D11B_ID 0x4303 /* 4303 802.11b */
|
|
#define BCM4303_PKG_ID 2 /* 4303 package id */
|
|
|
|
#define BCM4310_DEVICE_ID 0x4310 /* 4310 chipcommon chipid */
|
|
#define BCM4310_D11B_ID 0x4311 /* 4310 802.11b */
|
|
#define BCM4310_UART_ID 0x4312 /* 4310 uart */
|
|
#define BCM4310_ENET_ID 0x4313 /* 4310 enet */
|
|
#define BCM4310_USB_ID 0x4315 /* 4310 usb */
|
|
|
|
#define BCMGPRS_UART_ID 0x4333 /* Uart id used by 4306/gprs card */
|
|
#define BCMGPRS2_UART_ID 0x4344 /* Uart id used by 4306/gprs card */
|
|
|
|
|
|
#define BCM4704_DEVICE_ID 0x4704 /* 4704 chipcommon chipid */
|
|
#define BCM4704_ENET_ID 0x4706 /* 4704 enet (Use 47XX_ENET_ID instead!) */
|
|
|
|
#define BCM4317_DEVICE_ID 0x4317 /* 4317 chip common chipid */
|
|
|
|
#define BCM4318_DEVICE_ID 0x4318 /* 4318 chip common chipid */
|
|
#define BCM4318_D11G_ID 0x4318 /* 4318 801.11b/g id */
|
|
#define BCM4318_D11DUAL_ID 0x4319 /* 4318 801.11a/b/g id */
|
|
#define BCM4318_JTAGM_ID 0x4331 /* 4318 jtagm device id */
|
|
|
|
#define FPGA_JTAGM_ID 0x4330 /* ??? */
|
|
|
|
/* Address map */
|
|
#define BCM4710_SDRAM 0x00000000 /* Physical SDRAM */
|
|
#define BCM4710_PCI_MEM 0x08000000 /* Host Mode PCI memory access space (64 MB) */
|
|
#define BCM4710_PCI_CFG 0x0c000000 /* Host Mode PCI configuration space (64 MB) */
|
|
#define BCM4710_PCI_DMA 0x40000000 /* Client Mode PCI memory access space (1 GB) */
|
|
#define BCM4710_SDRAM_SWAPPED 0x10000000 /* Byteswapped Physical SDRAM */
|
|
#define BCM4710_ENUM 0x18000000 /* Beginning of core enumeration space */
|
|
|
|
/* Core register space */
|
|
#define BCM4710_REG_SDRAM 0x18000000 /* SDRAM core registers */
|
|
#define BCM4710_REG_ILINE20 0x18001000 /* InsideLine20 core registers */
|
|
#define BCM4710_REG_EMAC0 0x18002000 /* Ethernet MAC 0 core registers */
|
|
#define BCM4710_REG_CODEC 0x18003000 /* Codec core registers */
|
|
#define BCM4710_REG_USB 0x18004000 /* USB core registers */
|
|
#define BCM4710_REG_PCI 0x18005000 /* PCI core registers */
|
|
#define BCM4710_REG_MIPS 0x18006000 /* MIPS core registers */
|
|
#define BCM4710_REG_EXTIF 0x18007000 /* External Interface core registers */
|
|
#define BCM4710_REG_EMAC1 0x18008000 /* Ethernet MAC 1 core registers */
|
|
|
|
#define BCM4710_EXTIF 0x1f000000 /* External Interface base address */
|
|
#define BCM4710_PCMCIA_MEM 0x1f000000 /* External Interface PCMCIA memory access */
|
|
#define BCM4710_PCMCIA_IO 0x1f100000 /* PCMCIA I/O access */
|
|
#define BCM4710_PCMCIA_CONF 0x1f200000 /* PCMCIA configuration */
|
|
#define BCM4710_PROG 0x1f800000 /* Programable interface */
|
|
#define BCM4710_FLASH 0x1fc00000 /* Flash */
|
|
|
|
#define BCM4710_EJTAG 0xff200000 /* MIPS EJTAG space (2M) */
|
|
|
|
#define BCM4710_UART (BCM4710_REG_EXTIF + 0x00000300)
|
|
|
|
#define BCM4710_EUART (BCM4710_EXTIF + 0x00800000)
|
|
#define BCM4710_LED (BCM4710_EXTIF + 0x00900000)
|
|
|
|
#define BCM4712_DEVICE_ID 0x4712 /* 4712 chipcommon chipid */
|
|
#define BCM4712_MIPS_ID 0x4720 /* 4712 base devid */
|
|
#define BCM4712LARGE_PKG_ID 0 /* 340pin 4712 package id */
|
|
#define BCM4712SMALL_PKG_ID 1 /* 200pin 4712 package id */
|
|
#define BCM4712MID_PKG_ID 2 /* 225pin 4712 package id */
|
|
|
|
#define SDIOH_FPGA_ID 0x4380 /* sdio host fpga */
|
|
|
|
#define BCM5365_DEVICE_ID 0x5365 /* 5365 chipcommon chipid */
|
|
#define BCM5350_DEVICE_ID 0x5350 /* bcm5350 chipcommon chipid */
|
|
#define BCM5352_DEVICE_ID 0x5352 /* bcm5352 chipcommon chipid */
|
|
|
|
#define BCM4320_DEVICE_ID 0x4320 /* bcm4320 chipcommon chipid */
|
|
|
|
/* PCMCIA vendor Id's */
|
|
|
|
#define VENDOR_BROADCOM_PCMCIA 0x02d0
|
|
|
|
/* SDIO vendor Id's */
|
|
#define VENDOR_BROADCOM_SDIO 0x00BF
|
|
|
|
|
|
/* boardflags */
|
|
#define BFL_BTCOEXIST 0x0001 /* This board implements Bluetooth coexistance */
|
|
#define BFL_PACTRL 0x0002 /* This board has gpio 9 controlling the PA */
|
|
#define BFL_AIRLINEMODE 0x0004 /* This board implements gpio13 radio disable indication */
|
|
#define BFL_ENETROBO 0x0010 /* This board has robo switch or core */
|
|
#define BFL_CCKHIPWR 0x0040 /* Can do high-power CCK transmission */
|
|
#define BFL_ENETADM 0x0080 /* This board has ADMtek switch */
|
|
#define BFL_ENETVLAN 0x0100 /* This board has vlan capability */
|
|
#define BFL_AFTERBURNER 0x0200 /* This board supports Afterburner mode */
|
|
#define BFL_NOPCI 0x0400 /* This board leaves PCI floating */
|
|
#define BFL_FEM 0x0800 /* This board supports the Front End Module */
|
|
#define BFL_EXTLNA 0x1000 /* This board has an external LNA */
|
|
#define BFL_HGPA 0x2000 /* This board has a high gain PA */
|
|
#define BFL_BTCMOD 0x4000 /* This board' BTCOEXIST is in the alternate gpios */
|
|
#define BFL_ALTIQ 0x8000 /* Alternate I/Q settings */
|
|
|
|
/* board specific GPIO assignment, gpio 0-3 are also customer-configurable led */
|
|
#define BOARD_GPIO_HWRAD_B 0x010 /* bit 4 is HWRAD input on 4301 */
|
|
#define BOARD_GPIO_BTCMOD_IN 0x010 /* bit 4 is the alternate BT Coexistance Input */
|
|
#define BOARD_GPIO_BTCMOD_OUT 0x020 /* bit 5 is the alternate BT Coexistance Out */
|
|
#define BOARD_GPIO_BTC_IN 0x080 /* bit 7 is BT Coexistance Input */
|
|
#define BOARD_GPIO_BTC_OUT 0x100 /* bit 8 is BT Coexistance Out */
|
|
#define BOARD_GPIO_PACTRL 0x200 /* bit 9 controls the PA on new 4306 boards */
|
|
#define PCI_CFG_GPIO_SCS 0x10 /* PCI config space bit 4 for 4306c0 slow clock source */
|
|
#define PCI_CFG_GPIO_HWRAD 0x20 /* PCI config space GPIO 13 for hw radio disable */
|
|
#define PCI_CFG_GPIO_XTAL 0x40 /* PCI config space GPIO 14 for Xtal powerup */
|
|
#define PCI_CFG_GPIO_PLL 0x80 /* PCI config space GPIO 15 for PLL powerdown */
|
|
|
|
/* Bus types */
|
|
#define SB_BUS 0 /* Silicon Backplane */
|
|
#define PCI_BUS 1 /* PCI target */
|
|
#define PCMCIA_BUS 2 /* PCMCIA target */
|
|
#define SDIO_BUS 3 /* SDIO target */
|
|
#define JTAG_BUS 4 /* JTAG */
|
|
|
|
/* Allows optimization for single-bus support */
|
|
#ifdef BCMBUSTYPE
|
|
#define BUSTYPE(bus) (BCMBUSTYPE)
|
|
#else
|
|
#define BUSTYPE(bus) (bus)
|
|
#endif
|
|
|
|
/* power control defines */
|
|
#define PLL_DELAY 150 /* us pll on delay */
|
|
#define FREF_DELAY 200 /* us fref change delay */
|
|
#define MIN_SLOW_CLK 32 /* us Slow clock period */
|
|
#define XTAL_ON_DELAY 1000 /* us crystal power-on delay */
|
|
|
|
/* Reference Board Types */
|
|
|
|
#define BU4710_BOARD 0x0400
|
|
#define VSIM4710_BOARD 0x0401
|
|
#define QT4710_BOARD 0x0402
|
|
|
|
#define BU4610_BOARD 0x0403
|
|
#define VSIM4610_BOARD 0x0404
|
|
|
|
#define BU4307_BOARD 0x0405
|
|
#define BCM94301CB_BOARD 0x0406
|
|
#define BCM94301PC_BOARD 0x0406 /* Pcmcia 5v card */
|
|
#define BCM94301MP_BOARD 0x0407
|
|
#define BCM94307MP_BOARD 0x0408
|
|
#define BCMAP4307_BOARD 0x0409
|
|
|
|
#define BU4309_BOARD 0x040a
|
|
#define BCM94309CB_BOARD 0x040b
|
|
#define BCM94309MP_BOARD 0x040c
|
|
#define BCM4309AP_BOARD 0x040d
|
|
|
|
#define BCM94302MP_BOARD 0x040e
|
|
|
|
#define VSIM4310_BOARD 0x040f
|
|
#define BU4711_BOARD 0x0410
|
|
#define BCM94310U_BOARD 0x0411
|
|
#define BCM94310AP_BOARD 0x0412
|
|
#define BCM94310MP_BOARD 0x0414
|
|
|
|
#define BU4306_BOARD 0x0416
|
|
#define BCM94306CB_BOARD 0x0417
|
|
#define BCM94306MP_BOARD 0x0418
|
|
|
|
#define BCM94710D_BOARD 0x041a
|
|
#define BCM94710R1_BOARD 0x041b
|
|
#define BCM94710R4_BOARD 0x041c
|
|
#define BCM94710AP_BOARD 0x041d
|
|
|
|
|
|
#define BU2050_BOARD 0x041f
|
|
|
|
|
|
#define BCM94309G_BOARD 0x0421
|
|
|
|
#define BCM94301PC3_BOARD 0x0422 /* Pcmcia 3.3v card */
|
|
|
|
#define BU4704_BOARD 0x0423
|
|
#define BU4702_BOARD 0x0424
|
|
|
|
#define BCM94306PC_BOARD 0x0425 /* pcmcia 3.3v 4306 card */
|
|
|
|
#define BU4317_BOARD 0x0426
|
|
|
|
|
|
#define BCM94702MN_BOARD 0x0428
|
|
|
|
/* BCM4702 1U CompactPCI Board */
|
|
#define BCM94702CPCI_BOARD 0x0429
|
|
|
|
/* BCM4702 with BCM95380 VLAN Router */
|
|
#define BCM95380RR_BOARD 0x042a
|
|
|
|
/* cb4306 with SiGe PA */
|
|
#define BCM94306CBSG_BOARD 0x042b
|
|
|
|
/* mp4301 with 2050 radio */
|
|
#define BCM94301MPL_BOARD 0x042c
|
|
|
|
/* cb4306 with SiGe PA */
|
|
#define PCSG94306_BOARD 0x042d
|
|
|
|
/* bu4704 with sdram */
|
|
#define BU4704SD_BOARD 0x042e
|
|
|
|
/* Dual 11a/11g Router */
|
|
#define BCM94704AGR_BOARD 0x042f
|
|
|
|
/* 11a-only minipci */
|
|
#define BCM94308MP_BOARD 0x0430
|
|
|
|
|
|
|
|
/* BCM94317 boards */
|
|
#define BCM94317CB_BOARD 0x0440
|
|
#define BCM94317MP_BOARD 0x0441
|
|
#define BCM94317PCMCIA_BOARD 0x0442
|
|
#define BCM94317SDIO_BOARD 0x0443
|
|
|
|
#define BU4712_BOARD 0x0444
|
|
#define BU4712SD_BOARD 0x045d
|
|
#define BU4712L_BOARD 0x045f
|
|
|
|
/* BCM4712 boards */
|
|
#define BCM94712AP_BOARD 0x0445
|
|
#define BCM94712P_BOARD 0x0446
|
|
|
|
/* BCM4318 boards */
|
|
#define BU4318_BOARD 0x0447
|
|
#define CB4318_BOARD 0x0448
|
|
#define MPG4318_BOARD 0x0449
|
|
#define MP4318_BOARD 0x044a
|
|
#define SD4318_BOARD 0x044b
|
|
|
|
/* BCM63XX boards */
|
|
#define BCM96338_BOARD 0x6338
|
|
#define BCM96345_BOARD 0x6345
|
|
#define BCM96348_BOARD 0x6348
|
|
|
|
/* Another mp4306 with SiGe */
|
|
#define BCM94306P_BOARD 0x044c
|
|
|
|
/* CF-like 4317 modules */
|
|
#define BCM94317CF_BOARD 0x044d
|
|
|
|
/* mp4303 */
|
|
#define BCM94303MP_BOARD 0x044e
|
|
|
|
/* mpsgh4306 */
|
|
#define BCM94306MPSGH_BOARD 0x044f
|
|
|
|
/* BRCM 4306 w/ Front End Modules */
|
|
#define BCM94306MPM 0x0450
|
|
#define BCM94306MPL 0x0453
|
|
|
|
/* 4712agr */
|
|
#define BCM94712AGR_BOARD 0x0451
|
|
|
|
/* The real CF 4317 board */
|
|
#define CFI4317_BOARD 0x0452
|
|
|
|
/* pcmcia 4303 */
|
|
#define PC4303_BOARD 0x0454
|
|
|
|
/* 5350K */
|
|
#define BCM95350K_BOARD 0x0455
|
|
|
|
/* 5350R */
|
|
#define BCM95350R_BOARD 0x0456
|
|
|
|
/* 4306mplna */
|
|
#define BCM94306MPLNA_BOARD 0x0457
|
|
|
|
/* 4320 boards */
|
|
#define BU4320_BOARD 0x0458
|
|
#define BU4320S_BOARD 0x0459
|
|
#define BCM94320PH_BOARD 0x045a
|
|
|
|
/* 4306mph */
|
|
#define BCM94306MPH_BOARD 0x045b
|
|
|
|
/* 4306pciv */
|
|
#define BCM94306PCIV_BOARD 0x045c
|
|
|
|
#define BU4712SD_BOARD 0x045d
|
|
|
|
#define BCM94320PFLSH_BOARD 0x045e
|
|
|
|
#define BU4712L_BOARD 0x045f
|
|
#define BCM94712LGR_BOARD 0x0460
|
|
#define BCM94320R_BOARD 0x0461
|
|
|
|
#define BU5352_BOARD 0x0462
|
|
|
|
#define BCM94318MPGH_BOARD 0x0463
|
|
|
|
|
|
#define BCM95352GR_BOARD 0x0467
|
|
|
|
/* bcm95351agr */
|
|
#define BCM95351AGR_BOARD 0x0470
|
|
|
|
/* # of GPIO pins */
|
|
#define GPIO_NUMPINS 16
|
|
|
|
#endif /* _BCMDEVS_H */
|