diff options
Diffstat (limited to 'target/linux/brcm47xx-2.6/files/include')
10 files changed, 1773 insertions, 0 deletions
| diff --git a/target/linux/brcm47xx-2.6/files/include/asm-generic/gpio.h b/target/linux/brcm47xx-2.6/files/include/asm-generic/gpio.h new file mode 100644 index 000000000..2d0aab1d8 --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/asm-generic/gpio.h @@ -0,0 +1,25 @@ +#ifndef _ASM_GENERIC_GPIO_H +#define _ASM_GENERIC_GPIO_H + +/* platforms that don't directly support access to GPIOs through I2C, SPI, + * or other blocking infrastructure can use these wrappers. + */ + +static inline int gpio_cansleep(unsigned gpio) +{ +	return 0; +} + +static inline int gpio_get_value_cansleep(unsigned gpio) +{ +	might_sleep(); +	return gpio_get_value(gpio); +} + +static inline void gpio_set_value_cansleep(unsigned gpio, int value) +{ +	might_sleep(); +	gpio_set_value(gpio, value); +} + +#endif /* _ASM_GENERIC_GPIO_H */ diff --git a/target/linux/brcm47xx-2.6/files/include/asm-mips/cfe.h b/target/linux/brcm47xx-2.6/files/include/asm-mips/cfe.h new file mode 100644 index 000000000..47c3f5613 --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/asm-mips/cfe.h @@ -0,0 +1,189 @@ +/* + * Broadcom Common Firmware Environment (CFE) support + * + * Copyright 2000, 2001, 2002 + * Broadcom Corporation. All rights reserved. + * + * Copyright (C) 2006 Michael Buesch + * + * Original Authors:  Mitch Lichtenberg, Chris Demetriou + * + * This software is furnished under license and may be used and copied only + * in accordance with the following terms and conditions.  Subject to these + * conditions, you may download, copy, install, use, modify and distribute + * modified or unmodified copies of this software in source and/or binary + * form. No title or ownership is transferred hereby. + * + * 1) Any source code used, modified or distributed must reproduce and + *    retain this copyright notice and list of conditions as they appear in + *    the source file. + * + * 2) No right is granted to use any trade name, trademark, or logo of + *    Broadcom Corporation.  The "Broadcom Corporation" name may not be + *    used to endorse or promote products derived from this software + *    without the prior written permission of Broadcom Corporation. + * + * 3) THIS SOFTWARE IS PROVIDED "AS-IS" AND ANY EXPRESS OR IMPLIED + *    WARRANTIES, INCLUDING BUT NOT LIMITED TO, ANY IMPLIED WARRANTIES OF + *    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR + *    NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL BROADCOM BE LIABLE + *    FOR ANY DAMAGES WHATSOEVER, AND IN PARTICULAR, BROADCOM SHALL NOT BE + *    LIABLE FOR DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + *    CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + *    SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR + *    BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + *    WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE + *    OR OTHERWISE), EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#ifndef LINUX_CFE_API_H_ +#define LINUX_CFE_API_H_ + +#include <linux/types.h> + + +#define CFE_MI_RESERVED		0		/* memory is reserved, do not use */ +#define CFE_MI_AVAILABLE	1		/* memory is available */ + +#define CFE_FLG_WARMSTART	0x00000001 +#define CFE_FLG_FULL_ARENA	0x00000001 +#define CFE_FLG_ENV_PERMANENT	0x00000001 + +#define CFE_CPU_CMD_START	1 +#define CFE_CPU_CMD_STOP	0 + +#define CFE_STDHANDLE_CONSOLE	0 + +#define CFE_DEV_NETWORK 	1 +#define CFE_DEV_DISK		2 +#define CFE_DEV_FLASH		3 +#define CFE_DEV_SERIAL		4 +#define CFE_DEV_CPU		5 +#define CFE_DEV_NVRAM		6 +#define CFE_DEV_CLOCK           7 +#define CFE_DEV_OTHER		8 +#define CFE_DEV_MASK		0x0F + +#define CFE_CACHE_FLUSH_D	1 +#define CFE_CACHE_INVAL_I	2 +#define CFE_CACHE_INVAL_D	4 +#define CFE_CACHE_INVAL_L2	8 + +#define CFE_FWI_64BIT		0x00000001 +#define CFE_FWI_32BIT		0x00000002 +#define CFE_FWI_RELOC		0x00000004 +#define CFE_FWI_UNCACHED	0x00000008 +#define CFE_FWI_MULTICPU	0x00000010 +#define CFE_FWI_FUNCSIM		0x00000020 +#define CFE_FWI_RTLSIM		0x00000040 + +struct cfe_fwinfo { +	s64 version;		/* major, minor, eco version */ +	s64 totalmem;		/* total installed mem */ +	s64 flags;		/* various flags */ +	s64 boardid;		/* board ID */ +	s64 bootarea_va;	/* VA of boot area */ +	s64 bootarea_pa;	/* PA of boot area */ +	s64 bootarea_size;	/* size of boot area */ +}; + + +/* The public CFE API */ + +int cfe_present(void);	/* Check if we booted from CFE. Returns bool */ + +int cfe_getticks(s64 *ticks); +int cfe_close(int handle); +int cfe_cpu_start(int cpu, void (*fn)(void), long sp, long gp, long a1); +int cfe_cpu_stop(int cpu); +int cfe_enumenv(int idx, char *name, int namelen, char *val, int vallen); +int cfe_enumdev(int idx, char *name, int namelen); +int cfe_enummem(int idx, int flags, u64 *start, u64 *length, +		u64 *type); +int cfe_exit(int warm, int status); +int cfe_flushcache(int flags); +int cfe_getdevinfo(char *name); +int cfe_getenv(char *name, char *dest, int destlen); +int cfe_getfwinfo(struct cfe_fwinfo *info); +int cfe_getstdhandle(int handletype); +int cfe_inpstat(int handle); +int cfe_ioctl(int handle, unsigned int ioctlnum, unsigned char *buffer, +	      int length, int *retlen, u64 offset); +int cfe_open(char *name); +int cfe_read(int handle, unsigned char *buffer, int length); +int cfe_readblk(int handle, s64 offset, unsigned char *buffer, int length); +int cfe_setenv(char *name, char *val); +int cfe_write(int handle, unsigned char *buffer, int length); +int cfe_writeblk(int handle, s64 offset, unsigned char *buffer, +		 int length); + + +/* High level API */ + +/* Print some information to CFE's console (most likely serial line) */ +int cfe_printk(const char *fmt, ...) __attribute__((format(printf, 1, 2))); +int cfe_vprintk(const char *fmt, va_list args); + + + +/* Error codes returned by the low API functions */ + +#define CFE_ISERR(errcode)	(errcode < 0) + +#define CFE_OK			 0 +#define CFE_ERR                 -1	/* generic error */ +#define CFE_ERR_INV_COMMAND	-2 +#define CFE_ERR_EOF		-3 +#define CFE_ERR_IOERR		-4 +#define CFE_ERR_NOMEM		-5 +#define CFE_ERR_DEVNOTFOUND	-6 +#define CFE_ERR_DEVOPEN		-7 +#define CFE_ERR_INV_PARAM	-8 +#define CFE_ERR_ENVNOTFOUND	-9 +#define CFE_ERR_ENVREADONLY	-10 + +#define CFE_ERR_NOTELF		-11 +#define CFE_ERR_NOT32BIT 	-12 +#define CFE_ERR_WRONGENDIAN 	-13 +#define CFE_ERR_BADELFVERS 	-14 +#define CFE_ERR_NOTMIPS 	-15 +#define CFE_ERR_BADELFFMT 	-16 +#define CFE_ERR_BADADDR 	-17 + +#define CFE_ERR_FILENOTFOUND	-18 +#define CFE_ERR_UNSUPPORTED	-19 + +#define CFE_ERR_HOSTUNKNOWN	-20 + +#define CFE_ERR_TIMEOUT		-21 + +#define CFE_ERR_PROTOCOLERR	-22 + +#define CFE_ERR_NETDOWN		-23 +#define CFE_ERR_NONAMESERVER	-24 + +#define CFE_ERR_NOHANDLES	-25 +#define CFE_ERR_ALREADYBOUND	-26 + +#define CFE_ERR_CANNOTSET	-27 +#define CFE_ERR_NOMORE		-28 +#define CFE_ERR_BADFILESYS	-29 +#define CFE_ERR_FSNOTAVAIL	-30 + +#define CFE_ERR_INVBOOTBLOCK	-31 +#define CFE_ERR_WRONGDEVTYPE	-32 +#define CFE_ERR_BBCHECKSUM	-33 +#define CFE_ERR_BOOTPROGCHKSUM	-34 + +#define CFE_ERR_LDRNOTAVAIL	-35 + +#define CFE_ERR_NOTREADY	-36 + +#define CFE_ERR_GETMEM          -37 +#define CFE_ERR_SETMEM          -38 + +#define CFE_ERR_NOTCONN		-39 +#define CFE_ERR_ADDRINUSE	-40 + + +#endif /* LINUX_CFE_API_H_ */ diff --git a/target/linux/brcm47xx-2.6/files/include/asm-mips/mach-bcm947xx/gpio.h b/target/linux/brcm47xx-2.6/files/include/asm-mips/mach-bcm947xx/gpio.h new file mode 100644 index 000000000..2999a255f --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/asm-mips/mach-bcm947xx/gpio.h @@ -0,0 +1,88 @@ +#ifndef __BCM947XX_GPIO_H +#define __BCM947XX_GPIO_H + +#include <linux/ssb/ssb.h> +#include <linux/ssb/ssb_driver_chipcommon.h> +#include <linux/ssb/ssb_driver_extif.h> + +extern struct ssb_bus ssb; + +static inline int gpio_request(unsigned gpio, const char *label) +{ +	return 0; +} + +static inline void gpio_free(unsigned gpio) +{ +} + +static inline int gpio_direction_input(unsigned gpio) +{ +	if (ssb.chipco->dev) +		ssb_chipco_gpioouten(&ssb.chipco, 1 << gpio, 0); +	else if (ssb.extif->dev) +		ssb_extif_gpioouten(&ssb.extif, 1 << gpio, 0); +	else +		return -EINVAL; +	return 0; +} + +static inline int gpio_direction_output(unsigned gpio) +{ +	if (ssb.chipco->dev) +		ssb_chipco_gpioouten(&ssb.chipco, 1 << gpio, 1 << gpio); +	else if (ssb.extif->dev) +		ssb_extif_gpioouten(&ssb.extif, 1 << gpio, 1 << gpio); +	else +		return -EINVAL; + +	return 0; +} + + +static inline int gpio_to_irq(unsigned gpio) +{ +	struct ssb_device *dev; +	 +	dev = ssb.chipco->dev; +	if (!dev) +		dev = ssb.extif->dev; +	if (!dev) +		return -EINVAL; + +	return ssb_mips_irq(dev) + 2; +} + +static inline int irq_to_gpio(unsigned gpio) +{ +	return -EINVAL; +} + + +static inline int gpio_get_value(unsigned gpio) +{ +	if (ssb.chipco->dev) +		return ssb_chipco_gpioin(&ssb.chipco, 1 << gpio) ? 1 : 0; +	else if (ssb.extif->dev) +		return ssb_extif_gpioin(&ssb.extif, 1 << gpio) ? 1 : 0; +	else +		return 0; +} + +static inline int gpio_set_value(unsigned gpio, int value) +{ +	if (ssb.chipco->dev) +		ssb_chipco_gpioout(&ssb.chipco, 1 << gpio, (value ? 1 << gpio : 0)); +	else if (ssb.extif->dev) +		ssb_extif_gpioout(&ssb.extif, 1 << gpio, (value ? 1 << gpio : 0)); +	 +	return 0; +} + + +/* cansleep wrappers */ +#include <asm-generic/gpio.h> + + +#endif /* __BCM947XX_GPIO_H */ + diff --git a/target/linux/brcm47xx-2.6/files/include/asm-mips/mach-bcm947xx/kernel-entry-init.h b/target/linux/brcm47xx-2.6/files/include/asm-mips/mach-bcm947xx/kernel-entry-init.h new file mode 100644 index 000000000..7df0dc2b5 --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/asm-mips/mach-bcm947xx/kernel-entry-init.h @@ -0,0 +1,26 @@ +/* + * This file is subject to the terms and conditions of the GNU General Public + * License.  See the file "COPYING" in the main directory of this archive + * for more details. + * + * Copyright (C) 2005 Embedded Alley Solutions, Inc + * Copyright (C) 2005 Ralf Baechle (ralf@linux-mips.org) + * Copyright (C) 2006 Michael Buesch + */ +#ifndef __ASM_MACH_GENERIC_KERNEL_ENTRY_H +#define __ASM_MACH_GENERIC_KERNEL_ENTRY_H + +/* Intentionally empty macro, used in head.S. Override in + * arch/mips/mach-xxx/kernel-entry-init.h when necessary. + */ +	.macro	kernel_entry_setup +	.endm + +/* + * Do SMP slave processor setup necessary before we can savely execute C code. + */ +	.macro	smp_slave_setup +	.endm + + +#endif /* __ASM_MACH_GENERIC_KERNEL_ENTRY_H */ diff --git a/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb.h b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb.h new file mode 100644 index 000000000..7fdeae71c --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb.h @@ -0,0 +1,375 @@ +#ifndef LINUX_SSB_H_ +#define LINUX_SSB_H_ +#ifdef __KERNEL__ + +#include <linux/device.h> +#include <linux/list.h> +#include <linux/types.h> +#include <linux/spinlock.h> + +#include <linux/ssb/ssb_regs.h> + + +struct pcmcia_device; +struct ssb_bus; +struct ssb_driver; + + +struct ssb_sprom_r1 { +	u16 pci_spid;		/* Subsystem Product ID for PCI */ +	u16 pci_svid;		/* Subsystem Vendor ID for PCI */ +	u16 pci_pid;		/* Product ID for PCI */ +	u8 il0mac[6];		/* MAC address for 802.11b/g */ +	u8 et0mac[6];		/* MAC address for Ethernet */ +	u8 et1mac[6];		/* MAC address for 802.11a */ +	u8 et0phyaddr:5;	/* MII address for enet0 */ +	u8 et1phyaddr:5;	/* MII address for enet1 */ +	u8 et0mdcport:1;	/* MDIO for enet0 */ +	u8 et1mdcport:1;	/* MDIO for enet1 */ +	u8 board_rev;		/* Board revision */ +	u8 country_code:4;	/* Country Code */ +	u8 antenna_a:2;		/* Antenna 0/1 available for A-PHY */ +	u8 antenna_bg:2;	/* Antenna 0/1 available for B-PHY and G-PHY */ +	u16 pa0b0; +	u16 pa0b1; +	u16 pa0b2; +	u16 pa1b0; +	u16 pa1b1; +	u16 pa1b2; +	u8 gpio0;		/* GPIO pin 0 */ +	u8 gpio1;		/* GPIO pin 1 */ +	u8 gpio2;		/* GPIO pin 2 */ +	u8 gpio3;		/* GPIO pin 3 */ +	u16 maxpwr_a;		/* A-PHY Power Amplifier Max Power (in dBm Q5.2) */ +	u16 maxpwr_bg;		/* B/G-PHY Power Amplifier Max Power (in dBm Q5.2) */ +	u8 itssi_a;		/* Idle TSSI Target for A-PHY */ +	u8 itssi_bg;		/* Idle TSSI Target for B/G-PHY */ +	u16 boardflags_lo;	/* Boardflags (low 16 bits) */ +	u8 antenna_gain_a;	/* A-PHY Antenna gain (in dBm Q5.2) */ +	u8 antenna_gain_bg;	/* B/G-PHY Antenna gain (in dBm Q5.2) */ +	u8 oem[8];		/* OEM string (rev 1 only) */ +}; + +struct ssb_sprom_r2 { +	u16 boardflags_hi;	/* Boardflags (high 16 bits) */ +	u8 maxpwr_a_lo;		/* A-PHY Max Power Low */ +	u8 maxpwr_a_hi;		/* A-PHY Max Power High */ +	u16 pa1lob0;		/* A-PHY PA Low Settings */ +	u16 pa1lob1;		/* A-PHY PA Low Settings */ +	u16 pa1lob2;		/* A-PHY PA Low Settings */ +	u16 pa1hib0;		/* A-PHY PA High Settings */ +	u16 pa1hib1;		/* A-PHY PA High Settings */ +	u16 pa1hib2;		/* A-PHY PA High Settings */ +	u8 ofdm_pwr_off;	/* OFDM Power Offset from CCK Level */ +	u8 country_str[2];	/* Two char Country Code */ +}; + +struct ssb_sprom_r3 { +	u32 ofdmapo;		/* A-PHY OFDM Mid Power Offset */ +	u32 ofdmalpo;		/* A-PHY OFDM Low Power Offset */ +	u32 ofdmahpo;		/* A-PHY OFDM High Power Offset */ +	u8 gpioldc_on_cnt;	/* GPIO LED Powersave Duty Cycle ON count */ +	u8 gpioldc_off_cnt;	/* GPIO LED Powersave Duty Cycle OFF count */ +	u8 cckpo_1M:4;		/* CCK Power Offset for Rate 1M */ +	u8 cckpo_2M:4;		/* CCK Power Offset for Rate 2M */ +	u8 cckpo_55M:4;		/* CCK Power Offset for Rate 5.5M */ +	u8 cckpo_11M:4;		/* CCK Power Offset for Rate 11M */ +	u32 ofdmgpo;		/* G-PHY OFDM Power Offset */ +}; + +struct ssb_sprom_r4 { +	/* TODO */ +}; + +struct ssb_sprom { +	u8 revision; +	u8 crc; +	/* The valid r# fields are selected by the "revision". +	 * Revision 3 and lower inherit from lower revisions. +	 */ +	union { +		struct { +			struct ssb_sprom_r1 r1; +			struct ssb_sprom_r2 r2; +			struct ssb_sprom_r3 r3; +		}; +		struct ssb_sprom_r4 r4; +	}; +}; + + +/* Core-ID values. */ +#define SSB_DEV_CHIPCOMMON	0x800 +#define SSB_DEV_ILINE20		0x801 +#define SSB_DEV_SDRAM		0x803 +#define SSB_DEV_PCI		0x804 +#define SSB_DEV_MIPS		0x805 +#define SSB_DEV_ETHERNET	0x806 +#define SSB_DEV_V90		0x807 +#define SSB_DEV_USB11_HOSTDEV	0x808 +#define SSB_DEV_ADSL		0x809 +#define SSB_DEV_ILINE100	0x80A +#define SSB_DEV_IPSEC		0x80B +#define SSB_DEV_PCMCIA		0x80D +#define SSB_DEV_INTERNAL_MEM	0x80E +#define SSB_DEV_MEMC_SDRAM	0x80F +#define SSB_DEV_EXTIF		0x811 +#define SSB_DEV_80211		0x812 +#define SSB_DEV_MIPS_3302	0x816 +#define SSB_DEV_USB11_HOST	0x817 +#define SSB_DEV_USB11_DEV	0x818 +#define SSB_DEV_USB20_HOST	0x819 +#define SSB_DEV_USB20_DEV	0x81A +#define SSB_DEV_SDIO_HOST	0x81B +#define SSB_DEV_ROBOSWITCH	0x81C +#define SSB_DEV_PARA_ATA	0x81D +#define SSB_DEV_SATA_XORDMA	0x81E +#define SSB_DEV_ETHERNET_GBIT	0x81F +#define SSB_DEV_PCIE		0x820 +#define SSB_DEV_MIMO_PHY	0x821 +#define SSB_DEV_SRAM_CTRLR	0x822 +#define SSB_DEV_MINI_MACPHY	0x823 +#define SSB_DEV_ARM_1176	0x824 +#define SSB_DEV_ARM_7TDMI	0x825 + +/* Vendor-ID values */ +#define SSB_VENDOR_BROADCOM	0x4243 + +struct ssb_device_id { +	u16 vendor; +	u16 coreid; +	u8 revision; +}; +#define SSB_DEVICE(_vendor, _coreid, _revision)  \ +	{ .vendor = _vendor, .coreid = _coreid, .revision = _revision, } +#define SSB_DEVTABLE_END  \ +	{ 0, }, + +#define SSB_ANY_VENDOR		0xFFFF +#define SSB_ANY_ID		0xFFFF +#define SSB_ANY_REV		0xFF + + +struct ssb_device { +	struct device dev; +	struct ssb_bus *bus; +	struct ssb_device_id id; + +	u8 core_index; +	unsigned int irq; +	void *drvdata;		/* Per-device data */ +	void *devtypedata;	/* Per-devicetype (eg 802.11) data */ +}; +#define dev_to_ssb_dev(_dev) container_of(_dev, struct ssb_device, dev) + +/* Device specific user data */ +static inline +void ssb_set_drvdata(struct ssb_device *dev, void *data) +{ +	dev->drvdata = data; +} +static inline +void * ssb_get_drvdata(struct ssb_device *dev) +{ +	return dev->drvdata; +} + +/* Devicetype specific user data. This is per device-type (not per device) */ +void ssb_set_devtypedata(struct ssb_device *dev, void *data); +static inline +void * ssb_get_devtypedata(struct ssb_device *dev) +{ +	return dev->devtypedata; +} + +struct ssb_bus_ops { +	u16 (*read16)(struct ssb_device *dev, u16 offset); +	u32 (*read32)(struct ssb_device *dev, u16 offset); +	void (*write16)(struct ssb_device *dev, u16 offset, u16 value); +	void (*write32)(struct ssb_device *dev, u16 offset, u32 value); +}; + + +struct ssb_driver { +	const char *name; +	const struct ssb_device_id *id_table; + +	int (*probe)(struct ssb_device *dev, const struct ssb_device_id *id); +	void (*remove)(struct ssb_device *dev); +	int (*suspend)(struct ssb_device *dev, pm_message_t state); +	int (*resume)(struct ssb_device *dev); +	void (*shutdown)(struct ssb_device *dev); + +	struct device_driver drv; +}; +#define drv_to_ssb_drv(_drv) container_of(_drv, struct ssb_driver, drv) + +extern int __ssb_driver_register(struct ssb_driver *drv, struct module *owner); +static inline int ssb_driver_register(struct ssb_driver *drv) +{ +	return __ssb_driver_register(drv, THIS_MODULE); +} +extern void ssb_driver_unregister(struct ssb_driver *drv); + + + + +enum ssb_bustype { +	SSB_BUSTYPE_SSB,	/* This SSB bus is the system bus */ +	SSB_BUSTYPE_PCI,	/* SSB is connected to PCI bus */ +	SSB_BUSTYPE_PCMCIA,	/* SSB is connected to PCMCIA bus */ +	//TODO SSB_BUSTYPE_JTAG, +}; + +/* board_vendor */ +#define SSB_BOARDVENDOR_BCM	0x14E4	/* Broadcom */ +#define SSB_BOARDVENDOR_DELL	0x1028	/* Dell */ +#define SSB_BOARDVENDOR_HP	0x0E11	/* HP */ +/* board_type */ +#define SSB_BOARD_BCM94306MP	0x0418 +#define SSB_BOARD_BCM4309G	0x0421 +#define SSB_BOARD_BCM4306CB	0x0417 +#define SSB_BOARD_BCM4309MP	0x040C +#define SSB_BOARD_MP4318	0x044A +#define SSB_BOARD_BU4306	0x0416 +#define SSB_BOARD_BU4309	0x040A +/* chip_package */ +#define SSB_CHIPPACK_BCM4712S	1	/* Small 200pin 4712 */ +#define SSB_CHIPPACK_BCM4712M	2	/* Medium 225pin 4712 */ +#define SSB_CHIPPACK_BCM4712L	0	/* Large 340pin 4712 */ + +static inline u16 ssb_read16(struct ssb_device *dev, u16 offset); +static inline u32 ssb_read32(struct ssb_device *dev, u16 offset); +static inline void ssb_write16(struct ssb_device *dev, u16 offset, u16 value); +static inline void ssb_write32(struct ssb_device *dev, u16 offset, u32 value); +static inline u32 ssb_write32_masked(struct ssb_device *dev, u16 offset, u32 mask, u32 value); + +#include <linux/ssb/ssb_driver_chipcommon.h> +#include <linux/ssb/ssb_driver_mips.h> +#include <linux/ssb/ssb_driver_extif.h> +#include <linux/ssb/ssb_driver_pci.h> + +struct ssb_bus { +	/* The MMIO area. */ +	void __iomem *mmio; + +	const struct ssb_bus_ops *ops; + +	/* The core in the basic address register window. (PCI bus only) */ +	struct ssb_device *mapped_device; +	/* Currently mapped PCMCIA segment. (bustype == SSB_BUSTYPE_PCMCIA only) */ +	u8 mapped_pcmcia_seg; +	/* Lock for core and segment switching. */ +	spinlock_t bar_lock; + +	/* The bus this backplane is running on. */ +	enum ssb_bustype bustype; +	/* Pointer to the PCI bus (only valid if bustype == SSB_BUSTYPE_PCI). */ +	struct pci_dev *host_pci; +	/* Pointer to the PCMCIA device (only if bustype == SSB_BUSTYPE_PCMCIA). */ +	struct pcmcia_device *host_pcmcia; + +	/* ID information about the PCB. */ +	u16 board_vendor; +	u16 board_type; +	u16 board_rev; +	/* ID information about the Chip. */ +	u16 chip_id; +	u16 chip_rev; +	u8 chip_package; + +	/* Contents of the SPROM. +	 * If there is no sprom (not on PCI-bus), this is emulated. */ +	struct ssb_sprom sprom; + +	/* List of devices (cores) on the backplane. */ +	struct ssb_device devices[SSB_MAX_NR_CORES]; +	u8 nr_devices; + +	/* Reference count. Number of suspended devices. */ +	u8 suspend_cnt; + +	/* Software ID number for this bus. */ +	int busnumber; + +	/* The ChipCommon device (if available). */ +	struct ssb_chipcommon chipco; +	/* The PCI-core device (if available). */ +	struct ssb_pcicore pcicore; +	/* The MIPS-core device (if available). */ +	struct ssb_mipscore mipscore; +	/* The EXTif-core device (if available). */ +	struct ssb_extif extif; + +	/* Internal. */ +	struct list_head list; +}; + +extern int ssb_bus_ssbbus_register(struct ssb_bus *bus, +				   unsigned long baseaddr, +				   void (*fill_sprom)(struct ssb_sprom *sprom)); +#ifdef CONFIG_SSB_PCIHOST +extern int ssb_bus_pcibus_register(struct ssb_bus *bus, +				   struct pci_dev *host_pci); +#endif /* CONFIG_SSB_PCIHOST */ +#ifdef CONFIG_SSB_PCMCIAHOST +extern int ssb_bus_pcmciabus_register(struct ssb_bus *bus, +				      struct pcmcia_device *pcmcia_dev, +				      unsigned long baseaddr, +				      void (*fill_sprom)(struct ssb_sprom *sprom)); +#endif /* CONFIG_SSB_PCMCIAHOST */ + +extern void ssb_bus_unregister(struct ssb_bus *bus); + +extern u32 ssb_clockspeed(struct ssb_bus *bus); + +int ssb_device_is_enabled(struct ssb_device *dev); +void ssb_device_enable(struct ssb_device *dev, u32 core_specific_flags); +void ssb_device_disable(struct ssb_device *dev, u32 core_specific_flags); + + +static inline u16 ssb_read16(struct ssb_device *dev, u16 offset) +{ +	return dev->bus->ops->read16(dev, offset); +} +static inline u32 ssb_read32(struct ssb_device *dev, u16 offset) +{ +	return dev->bus->ops->read32(dev, offset); +} +static inline void ssb_write16(struct ssb_device *dev, u16 offset, u16 value) +{ +	dev->bus->ops->write16(dev, offset, value); +} +static inline void ssb_write32(struct ssb_device *dev, u16 offset, u32 value) +{ +	dev->bus->ops->write32(dev, offset, value); +} + +static inline u32 ssb_write32_masked(struct ssb_device *dev, +				  u16 offset, +				  u32 mask, +				  u32 value) +{ +	value &= mask; +	value |= ssb_read32(dev, offset) & ~mask; +	ssb_write32(dev, offset, value); +	return value; +} + + +/* Translation (routing) bits that need to be ORed to DMA + * addresses before they are given to a device. */ +extern u32 ssb_dma_translation(struct ssb_device *dev); +#define SSB_DMA_TRANSLATION_MASK	0xC0000000 +#define SSB_DMA_TRANSLATION_SHIFT	30 + +extern int ssb_dma_set_mask(struct ssb_device *ssb_dev, u64 mask); + + +/* Various helper functions */ +extern u32 ssb_admatch_base(u32 adm); +extern u32 ssb_admatch_size(u32 adm); + + +#endif /* __KERNEL__ */ +#endif /* LINUX_SSB_H_ */ diff --git a/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_chipcommon.h b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_chipcommon.h new file mode 100644 index 000000000..3d4fbdd77 --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_chipcommon.h @@ -0,0 +1,427 @@ +#ifndef LINUX_SSB_CHIPCO_H_ +#define LINUX_SSB_CHIPCO_H_ + +/* SonicsSiliconBackplane CHIPCOMMON core hardware definitions + * + * The chipcommon core provides chip identification, SB control, + * jtag, 0/1/2 uarts, clock frequency control, a watchdog interrupt timer, + * gpio interface, extbus, and support for serial and parallel flashes. + * + * Copyright 2005, Broadcom Corporation + * Copyright 2006, Michael Buesch <mb@bu3sch.de> + * + * Licensed under the GPL version 2. See COPYING for details. + */ +#ifdef __KERNEL__ + +/** ChipCommon core registers. **/ + +#define SSB_CHIPCO_CHIPID		0x0000 +#define  SSB_CHIPCO_IDMASK		0x0000FFFF +#define  SSB_CHIPCO_REVMASK		0x000F0000 +#define  SSB_CHIPCO_REVSHIFT		16 +#define  SSB_CHIPCO_PACKMASK		0x00F00000 +#define  SSB_CHIPCO_PACKSHIFT		20 +#define  SSB_CHIPCO_NRCORESMASK		0x0F000000 +#define  SSB_CHIPCO_NRCORESSHIFT	24 +#define SSB_CHIPCO_CAP	 		0x0004		/* Capabilities */ +#define  SSB_CHIPCO_CAP_NRUART		0x00000003	/* # of UARTs */ +#define  SSB_CHIPCO_CAP_MIPSEB		0x00000004	/* MIPS in BigEndian Mode */ +#define  SSB_CHIPCO_CAP_UARTCLK		0x00000018	/* UART clock select */ +#define   SSB_CHIPCO_CAP_UARTCLK_INT	0x00000008	/* UARTs are driven by internal divided clock */ +#define  SSB_CHIPCO_CAP_UARTGPIO	0x00000020	/* UARTs on GPIO 15-12 */ +#define  SSB_CHIPCO_CAP_EXTBUS		0x000000C0	/* External buses present */ +#define  SSB_CHIPCO_CAP_FLASHT		0x00000700	/* Flash Type */ +#define   SSB_CHIPCO_FLASHT_NONE	0x00000000	/* No flash */ +#define   SSB_CHIPCO_FLASHT_STSER	0x00000100	/* ST serial flash */ +#define   SSB_CHIPCO_FLASHT_ATSER	0x00000200	/* Atmel serial flash */ +#define	  SSB_CHIPCO_FLASHT_PARA	0x00000700	/* Parallel flash */ +#define  SSB_CHIPCO_CAP_PLLT		0x00038000	/* PLL Type */ +#define   SSB_PLLTYPE_NONE		0x00000000 +#define   SSB_PLLTYPE_1			0x00010000	/* 48Mhz base, 3 dividers */ +#define   SSB_PLLTYPE_2			0x00020000	/* 48Mhz, 4 dividers */ +#define   SSB_PLLTYPE_3			0x00030000	/* 25Mhz, 2 dividers */ +#define   SSB_PLLTYPE_4			0x00008000	/* 48Mhz, 4 dividers */ +#define   SSB_PLLTYPE_5			0x00018000	/* 25Mhz, 4 dividers */ +#define   SSB_PLLTYPE_6			0x00028000	/* 100/200 or 120/240 only */ +#define   SSB_PLLTYPE_7			0x00038000	/* 25Mhz, 4 dividers */ +#define  SSB_CHIPCO_CAP_PCTL		0x00040000	/* Power Control */ +#define  SSB_CHIPCO_CAP_OTPS		0x00380000	/* OTP size */ +#define  SSB_CHIPCO_CAP_OTPS_SHIFT	19 +#define  SSB_CHIPCO_CAP_OTPS_BASE	5 +#define  SSB_CHIPCO_CAP_JTAGM		0x00400000	/* JTAG master present */ +#define  SSB_CHIPCO_CAP_BROM		0x00800000	/* Internal boot ROM active */ +#define  SSB_CHIPCO_CAP_64BIT		0x08000000	/* 64-bit Backplane */ +#define SSB_CHIPCO_CORECTL		0x0008 +#define  SSB_CHIPCO_CORECTL_UARTCLK0	0x00000001	/* Drive UART with internal clock */ +#define	 SSB_CHIPCO_CORECTL_SE		0x00000002	/* sync clk out enable (corerev >= 3) */ +#define SSB_CHIPCO_BIST			0x000C +#define SSB_CHIPCO_OTPS			0x0010		/* OTP status */ +#define	 SSB_CHIPCO_OTPS_PROGFAIL	0x80000000 +#define	 SSB_CHIPCO_OTPS_PROTECT	0x00000007 +#define	 SSB_CHIPCO_OTPS_HW_PROTECT	0x00000001 +#define	 SSB_CHIPCO_OTPS_SW_PROTECT	0x00000002 +#define	 SSB_CHIPCO_OTPS_CID_PROTECT	0x00000004 +#define SSB_CHIPCO_OTPC			0x0014		/* OTP control */ +#define	 SSB_CHIPCO_OTPC_RECWAIT	0xFF000000 +#define	 SSB_CHIPCO_OTPC_PROGWAIT	0x00FFFF00 +#define	 SSB_CHIPCO_OTPC_PRW_SHIFT	8 +#define	 SSB_CHIPCO_OTPC_MAXFAIL	0x00000038 +#define	 SSB_CHIPCO_OTPC_VSEL		0x00000006 +#define	 SSB_CHIPCO_OTPC_SELVL		0x00000001 +#define SSB_CHIPCO_OTPP			0x0018		/* OTP prog */ +#define	 SSB_CHIPCO_OTPP_COL		0x000000FF +#define	 SSB_CHIPCO_OTPP_ROW		0x0000FF00 +#define	 SSB_CHIPCO_OTPP_ROW_SHIFT	8 +#define	 SSB_CHIPCO_OTPP_READERR	0x10000000 +#define	 SSB_CHIPCO_OTPP_VALUE		0x20000000 +#define	 SSB_CHIPCO_OTPP_READ		0x40000000 +#define	 SSB_CHIPCO_OTPP_START		0x80000000 +#define	 SSB_CHIPCO_OTPP_BUSY		0x80000000 +#define SSB_CHIPCO_IRQSTAT		0x0020 +#define SSB_CHIPCO_IRQMASK		0x0024 +#define	 SSB_CHIPCO_IRQ_GPIO		0x00000001	/* gpio intr */ +#define	 SSB_CHIPCO_IRQ_EXT		0x00000002	/* ro: ext intr pin (corerev >= 3) */ +#define	 SSB_CHIPCO_IRQ_WDRESET		0x80000000	/* watchdog reset occurred */ +#define SSB_CHIPCO_CHIPCTL		0x0028		/* Rev >= 11 only */ +#define SSB_CHIPCO_CHIPSTAT		0x002C		/* Rev >= 11 only */ +#define SSB_CHIPCO_JCMD			0x0030		/* Rev >= 10 only */ +#define  SSB_CHIPCO_JCMD_START		0x80000000 +#define  SSB_CHIPCO_JCMD_BUSY		0x80000000 +#define  SSB_CHIPCO_JCMD_PAUSE		0x40000000 +#define  SSB_CHIPCO_JCMD0_ACC_MASK	0x0000F000 +#define  SSB_CHIPCO_JCMD0_ACC_IRDR	0x00000000 +#define  SSB_CHIPCO_JCMD0_ACC_DR	0x00001000 +#define  SSB_CHIPCO_JCMD0_ACC_IR	0x00002000 +#define  SSB_CHIPCO_JCMD0_ACC_RESET	0x00003000 +#define  SSB_CHIPCO_JCMD0_ACC_IRPDR	0x00004000 +#define  SSB_CHIPCO_JCMD0_ACC_PDR	0x00005000 +#define  SSB_CHIPCO_JCMD0_IRW_MASK	0x00000F00 +#define  SSB_CHIPCO_JCMD_ACC_MASK	0x000F0000	/* Changes for corerev 11 */ +#define  SSB_CHIPCO_JCMD_ACC_IRDR	0x00000000 +#define  SSB_CHIPCO_JCMD_ACC_DR		0x00010000 +#define  SSB_CHIPCO_JCMD_ACC_IR		0x00020000 +#define  SSB_CHIPCO_JCMD_ACC_RESET	0x00030000 +#define  SSB_CHIPCO_JCMD_ACC_IRPDR	0x00040000 +#define  SSB_CHIPCO_JCMD_ACC_PDR	0x00050000 +#define  SSB_CHIPCO_JCMD_IRW_MASK	0x00001F00 +#define  SSB_CHIPCO_JCMD_IRW_SHIFT	8 +#define  SSB_CHIPCO_JCMD_DRW_MASK	0x0000003F +#define SSB_CHIPCO_JIR			0x0034		/* Rev >= 10 only */ +#define SSB_CHIPCO_JDR			0x0038		/* Rev >= 10 only */ +#define SSB_CHIPCO_JCTL			0x003C		/* Rev >= 10 only */ +#define  SSB_CHIPCO_JCTL_FORCE_CLK	4		/* Force clock */ +#define  SSB_CHIPCO_JCTL_EXT_EN		2		/* Enable external targets */ +#define  SSB_CHIPCO_JCTL_EN		1		/* Enable Jtag master */ +#define SSB_CHIPCO_FLASHCTL		0x0040 +#define  SSB_CHIPCO_FLASHCTL_START	0x80000000 +#define  SSB_CHIPCO_FLASHCTL_BUSY	SSB_CHIPCO_FLASHCTL_START +#define SSB_CHIPCO_FLASHADDR		0x0044 +#define SSB_CHIPCO_FLASHDATA		0x0048 +#define SSB_CHIPCO_BCAST_ADDR		0x0050 +#define SSB_CHIPCO_BCAST_DATA		0x0054 +#define SSB_CHIPCO_GPIOIN		0x0060 +#define SSB_CHIPCO_GPIOOUT		0x0064 +#define SSB_CHIPCO_GPIOOUTEN		0x0068 +#define SSB_CHIPCO_GPIOCTL		0x006C +#define SSB_CHIPCO_GPIOINTPOL		0x0070 +#define SSB_CHIPCO_GPIOINTMASK		0x0074 +#define SSB_CHIPCO_WATCHDOG		0x0080 +#define SSB_CHIPCO_GPIOTIMER		0x0088		/* LED powersave (corerev >= 16) */ +#define  SSB_CHIPCO_GPIOTIMER_ONTIME_SHIFT	16 +#define SSB_CHIPCO_GPIOTOUTM		0x008C		/* LED powersave (corerev >= 16) */ +#define SSB_CHIPCO_CLOCK_N		0x0090 +#define SSB_CHIPCO_CLOCK_SB		0x0094 +#define SSB_CHIPCO_CLOCK_PCI		0x0098 +#define SSB_CHIPCO_CLOCK_M2		0x009C +#define SSB_CHIPCO_CLOCK_MIPS		0x00A0 +#define SSB_CHIPCO_CLKDIV		0x00A4		/* Rev >= 3 only */ +#define	 SSB_CHIPCO_CLKDIV_SFLASH	0x0F000000 +#define	 SSB_CHIPCO_CLKDIV_SFLASH_SHIFT	24 +#define	 SSB_CHIPCO_CLKDIV_OTP		0x000F0000 +#define	 SSB_CHIPCO_CLKDIV_OTP_SHIFT	16 +#define	 SSB_CHIPCO_CLKDIV_JTAG		0x00000F00 +#define	 SSB_CHIPCO_CLKDIV_JTAG_SHIFT	8 +#define	 SSB_CHIPCO_CLKDIV_UART		0x000000FF +#define SSB_CHIPCO_PLLONDELAY		0x00B0		/* Rev >= 4 only */ +#define SSB_CHIPCO_FREFSELDELAY		0x00B4		/* Rev >= 4 only */ +#define SSB_CHIPCO_SLOWCLKCTL		0x00B8		/* 6 <= Rev <= 9 only */ +#define  SSB_CHIPCO_SLOWCLKCTL_SRC	0x00000007	/* slow clock source mask */ +#define	  SSB_CHIPCO_SLOWCLKCTL_SRC_LPO		0x00000000	/* source of slow clock is LPO */ +#define   SSB_CHIPCO_SLOWCLKCTL_SRC_XTAL	0x00000001	/* source of slow clock is crystal */ +#define	  SSB_CHIPCO_SLOECLKCTL_SRC_PCI		0x00000002	/* source of slow clock is PCI */ +#define  SSB_CHIPCO_SLOWCLKCTL_LPOFREQ	0x00000200	/* LPOFreqSel, 1: 160Khz, 0: 32KHz */ +#define  SSB_CHIPCO_SLOWCLKCTL_LPOPD	0x00000400	/* LPOPowerDown, 1: LPO is disabled, 0: LPO is enabled */ +#define  SSB_CHIPCO_SLOWCLKCTL_FSLOW	0x00000800	/* ForceSlowClk, 1: sb/cores running on slow clock, 0: power logic control */ +#define  SSB_CHIPCO_SLOWCLKCTL_IPLL	0x00001000	/* IgnorePllOffReq, 1/0: power logic ignores/honors PLL clock disable requests from core */ +#define  SSB_CHIPCO_SLOWCLKCTL_ENXTAL	0x00002000	/* XtalControlEn, 1/0: power logic does/doesn't disable crystal when appropriate */ +#define  SSB_CHIPCO_SLOWCLKCTL_XTALPU	0x00004000	/* XtalPU (RO), 1/0: crystal running/disabled */ +#define  SSB_CHIPCO_SLOWCLKCTL_CLKDIV	0xFFFF0000	/* ClockDivider (SlowClk = 1/(4+divisor)) */ +#define  SSB_CHIPCO_SLOWCLKCTL_CLKDIV_SHIFT	16 +#define SSB_CHIPCO_SYSCLKCTL		0x00C0		/* Rev >= 3 only */ +#define	 SSB_CHIPCO_SYSCLKCTL_IDLPEN	0x00000001	/* ILPen: Enable Idle Low Power */ +#define	 SSB_CHIPCO_SYSCLKCTL_ALPEN	0x00000002	/* ALPen: Enable Active Low Power */ +#define	 SSB_CHIPCO_SYSCLKCTL_PLLEN	0x00000004	/* ForcePLLOn */ +#define	 SSB_CHIPCO_SYSCLKCTL_FORCEALP	0x00000008	/* Force ALP (or HT if ALPen is not set */ +#define	 SSB_CHIPCO_SYSCLKCTL_FORCEHT	0x00000010	/* Force HT */ +#define  SSB_CHIPCO_SYSCLKCTL_CLKDIV	0xFFFF0000	/* ClkDiv  (ILP = 1/(4+divisor)) */ +#define  SSB_CHIPCO_SYSCLKCTL_CLKDIV_SHIFT	16 +#define SSB_CHIPCO_CLKSTSTR		0x00C4		/* Rev >= 3 only */ +#define SSB_CHIPCO_PCMCIA_CFG		0x0100 +#define SSB_CHIPCO_PCMCIA_MEMWAIT	0x0104 +#define SSB_CHIPCO_PCMCIA_ATTRWAIT	0x0108 +#define SSB_CHIPCO_PCMCIA_IOWAIT	0x010C +#define SSB_CHIPCO_IDE_CFG		0x0110 +#define SSB_CHIPCO_IDE_MEMWAIT		0x0114 +#define SSB_CHIPCO_IDE_ATTRWAIT		0x0118 +#define SSB_CHIPCO_IDE_IOWAIT		0x011C +#define SSB_CHIPCO_PROG_CFG		0x0120 +#define SSB_CHIPCO_PROG_WAITCNT		0x0124 +#define SSB_CHIPCO_FLASH_CFG		0x0128 +#define SSB_CHIPCO_FLASH_WAITCNT	0x012C +#define SSB_CHIPCO_UART0_DATA		0x0300 +#define SSB_CHIPCO_UART0_IMR		0x0304 +#define SSB_CHIPCO_UART0_FCR		0x0308 +#define SSB_CHIPCO_UART0_LCR		0x030C +#define SSB_CHIPCO_UART0_MCR		0x0310 +#define SSB_CHIPCO_UART0_LSR		0x0314 +#define SSB_CHIPCO_UART0_MSR		0x0318 +#define SSB_CHIPCO_UART0_SCRATCH	0x031C +#define SSB_CHIPCO_UART1_DATA		0x0400 +#define SSB_CHIPCO_UART1_IMR		0x0404 +#define SSB_CHIPCO_UART1_FCR		0x0408 +#define SSB_CHIPCO_UART1_LCR		0x040C +#define SSB_CHIPCO_UART1_MCR		0x0410 +#define SSB_CHIPCO_UART1_LSR		0x0414 +#define SSB_CHIPCO_UART1_MSR		0x0418 +#define SSB_CHIPCO_UART1_SCRATCH	0x041C + + + +/** Clockcontrol masks and values **/ + +/* SSB_CHIPCO_CLOCK_N */ +#define	SSB_CHIPCO_CLK_N1		0x0000003F	/* n1 control */ +#define	SSB_CHIPCO_CLK_N2		0x00003F00	/* n2 control */ +#define	SSB_CHIPCO_CLK_N2_SHIFT		8 +#define	SSB_CHIPCO_CLK_PLLC		0x000F0000	/* pll control */ +#define	SSB_CHIPCO_CLK_PLLC_SHIFT	16 + +/* SSB_CHIPCO_CLOCK_SB/PCI/UART */ +#define	SSB_CHIPCO_CLK_M1		0x0000003F	/* m1 control */ +#define	SSB_CHIPCO_CLK_M2		0x00003F00	/* m2 control */ +#define	SSB_CHIPCO_CLK_M2_SHIFT		8 +#define	SSB_CHIPCO_CLK_M3		0x003F0000	/* m3 control */ +#define	SSB_CHIPCO_CLK_M3_SHIFT		16 +#define	SSB_CHIPCO_CLK_MC		0x1F000000	/* mux control */ +#define	SSB_CHIPCO_CLK_MC_SHIFT		24 + +/* N3M Clock control magic field values */ +#define	SSB_CHIPCO_CLK_F6_2		0x02		/* A factor of 2 in */ +#define	SSB_CHIPCO_CLK_F6_3		0x03		/* 6-bit fields like */ +#define	SSB_CHIPCO_CLK_F6_4		0x05		/* N1, M1 or M3 */ +#define	SSB_CHIPCO_CLK_F6_5		0x09 +#define	SSB_CHIPCO_CLK_F6_6		0x11 +#define	SSB_CHIPCO_CLK_F6_7		0x21 + +#define	SSB_CHIPCO_CLK_F5_BIAS		5		/* 5-bit fields get this added */ + +#define	SSB_CHIPCO_CLK_MC_BYPASS	0x08 +#define	SSB_CHIPCO_CLK_MC_M1		0x04 +#define	SSB_CHIPCO_CLK_MC_M1M2		0x02 +#define	SSB_CHIPCO_CLK_MC_M1M2M3	0x01 +#define	SSB_CHIPCO_CLK_MC_M1M3		0x11 + +/* Type 2 Clock control magic field values */ +#define	SSB_CHIPCO_CLK_T2_BIAS		2		/* n1, n2, m1 & m3 bias */ +#define	SSB_CHIPCO_CLK_T2M2_BIAS	3		/* m2 bias */ + +#define	SSB_CHIPCO_CLK_T2MC_M1BYP	1 +#define	SSB_CHIPCO_CLK_T2MC_M2BYP	2 +#define	SSB_CHIPCO_CLK_T2MC_M3BYP	4 + +/* Type 6 Clock control magic field values */ +#define	SSB_CHIPCO_CLK_T6_MMASK		1		/* bits of interest in m */ +#define	SSB_CHIPCO_CLK_T6_M0		120000000	/* sb clock for m = 0 */ +#define	SSB_CHIPCO_CLK_T6_M1		100000000	/* sb clock for m = 1 */ +#define	SSB_CHIPCO_CLK_SB2MIPS_T6(sb)	(2 * (sb)) + +/* Common clock base */ +#define	SSB_CHIPCO_CLK_BASE1		24000000	/* Half the clock freq */ +#define SSB_CHIPCO_CLK_BASE2		12500000	/* Alternate crystal on some PLL's */ + +/* Clock control values for 200Mhz in 5350 */ +#define	SSB_CHIPCO_CLK_5350_N		0x0311 +#define	SSB_CHIPCO_CLK_5350_M		0x04020009 + + +/** Bits in the config registers **/ + +#define	SSB_CHIPCO_CFG_EN		0x0001		/* Enable */ +#define	SSB_CHIPCO_CFG_EXTM		0x000E		/* Extif Mode */ +#define	 SSB_CHIPCO_CFG_EXTM_ASYNC	0x0002		/* Async/Parallel flash */ +#define	 SSB_CHIPCO_CFG_EXTM_SYNC	0x0004		/* Synchronous */ +#define	 SSB_CHIPCO_CFG_EXTM_PCMCIA	0x0008		/* PCMCIA */ +#define	 SSB_CHIPCO_CFG_EXTM_IDE	0x000A		/* IDE */ +#define	SSB_CHIPCO_CFG_DS16		0x0010		/* Data size, 0=8bit, 1=16bit */ +#define	SSB_CHIPCO_CFG_CLKDIV		0x0060		/* Sync: Clock divisor */ +#define	SSB_CHIPCO_CFG_CLKEN		0x0080		/* Sync: Clock enable */ +#define	SSB_CHIPCO_CFG_BSTRO		0x0100		/* Sync: Size/Bytestrobe */ + + +/** Flash-specific control/status values */ + +/* flashcontrol opcodes for ST flashes */ +#define SSB_CHIPCO_FLASHCTL_ST_WREN	0x0006		/* Write Enable */ +#define SSB_CHIPCO_FLASHCTL_ST_WRDIS	0x0004		/* Write Disable */ +#define SSB_CHIPCO_FLASHCTL_ST_RDSR	0x0105		/* Read Status Register */ +#define SSB_CHIPCO_FLASHCTL_ST_WRSR	0x0101		/* Write Status Register */ +#define SSB_CHIPCO_FLASHCTL_ST_READ	0x0303		/* Read Data Bytes */ +#define SSB_CHIPCO_FLASHCTL_ST_PP	0x0302		/* Page Program */ +#define SSB_CHIPCO_FLASHCTL_ST_SE	0x02D8		/* Sector Erase */ +#define SSB_CHIPCO_FLASHCTL_ST_BE	0x00C7		/* Bulk Erase */ +#define SSB_CHIPCO_FLASHCTL_ST_DP	0x00B9		/* Deep Power-down */ +#define SSB_CHIPCO_FLASHCTL_ST_RSIG	0x03AB		/* Read Electronic Signature */ + +/* Status register bits for ST flashes */ +#define SSB_CHIPCO_FLASHSTA_ST_WIP	0x01		/* Write In Progress */ +#define SSB_CHIPCO_FLASHSTA_ST_WEL	0x02		/* Write Enable Latch */ +#define SSB_CHIPCO_FLASHSTA_ST_BP	0x1C		/* Block Protect */ +#define SSB_CHIPCO_FLASHSTA_ST_BP_SHIFT	2 +#define SSB_CHIPCO_FLASHSTA_ST_SRWD	0x80		/* Status Register Write Disable */ + +/* flashcontrol opcodes for Atmel flashes */ +#define SSB_CHIPCO_FLASHCTL_AT_READ		0x07E8 +#define SSB_CHIPCO_FLASHCTL_AT_PAGE_READ	0x07D2 +#define SSB_CHIPCO_FLASHCTL_AT_BUF1_READ	/* FIXME */ +#define SSB_CHIPCO_FLASHCTL_AT_BUF2_READ	/* FIXME */ +#define SSB_CHIPCO_FLASHCTL_AT_STATUS		0x01D7 +#define SSB_CHIPCO_FLASHCTL_AT_BUF1_WRITE	0x0384 +#define SSB_CHIPCO_FLASHCTL_AT_BUF2_WRITE	0x0387 +#define SSB_CHIPCO_FLASHCTL_AT_BUF1_ERASE_PRGM	0x0283	/* Erase program */ +#define SSB_CHIPCO_FLASHCTL_AT_BUF2_ERASE_PRGM	0x0286	/* Erase program */ +#define SSB_CHIPCO_FLASHCTL_AT_BUF1_PROGRAM	0x0288 +#define SSB_CHIPCO_FLASHCTL_AT_BUF2_PROGRAM	0x0289 +#define SSB_CHIPCO_FLASHCTL_AT_PAGE_ERASE	0x0281 +#define SSB_CHIPCO_FLASHCTL_AT_BLOCK_ERASE	0x0250 +#define SSB_CHIPCO_FLASHCTL_AT_BUF1_WRER_PRGM	0x0382	/* Write erase program */ +#define SSB_CHIPCO_FLASHCTL_AT_BUF2_WRER_PRGM	0x0385	/* Write erase program */ +#define SSB_CHIPCO_FLASHCTL_AT_BUF1_LOAD	0x0253 +#define SSB_CHIPCO_FLASHCTL_AT_BUF2_LOAD	0x0255 +#define SSB_CHIPCO_FLASHCTL_AT_BUF1_COMPARE	0x0260 +#define SSB_CHIPCO_FLASHCTL_AT_BUF2_COMPARE	0x0261 +#define SSB_CHIPCO_FLASHCTL_AT_BUF1_REPROGRAM	0x0258 +#define SSB_CHIPCO_FLASHCTL_AT_BUF2_REPROGRAM	0x0259 + +/* Status register bits for Atmel flashes */ +#define SSB_CHIPCO_FLASHSTA_AT_READY	0x80 +#define SSB_CHIPCO_FLASHSTA_AT_MISMATCH	0x40 +#define SSB_CHIPCO_FLASHSTA_AT_ID	0x38 +#define SSB_CHIPCO_FLASHSTA_AT_ID_SHIFT	3 + + +/** OTP **/ + +/* OTP regions */ +#define	SSB_CHIPCO_OTP_HW_REGION	SSB_CHIPCO_OTPS_HW_PROTECT +#define	SSB_CHIPCO_OTP_SW_REGION	SSB_CHIPCO_OTPS_SW_PROTECT +#define	SSB_CHIPCO_OTP_CID_REGION	SSB_CHIPCO_OTPS_CID_PROTECT + +/* OTP regions (Byte offsets from otp size) */ +#define	SSB_CHIPCO_OTP_SWLIM_OFF	(-8) +#define	SSB_CHIPCO_OTP_CIDBASE_OFF	0 +#define	SSB_CHIPCO_OTP_CIDLIM_OFF	8 + +/* Predefined OTP words (Word offset from otp size) */ +#define	SSB_CHIPCO_OTP_BOUNDARY_OFF	(-4) +#define	SSB_CHIPCO_OTP_HWSIGN_OFF	(-3) +#define	SSB_CHIPCO_OTP_SWSIGN_OFF	(-2) +#define	SSB_CHIPCO_OTP_CIDSIGN_OFF	(-1) + +#define	SSB_CHIPCO_OTP_CID_OFF		0 +#define	SSB_CHIPCO_OTP_PKG_OFF		1 +#define	SSB_CHIPCO_OTP_FID_OFF		2 +#define	SSB_CHIPCO_OTP_RSV_OFF		3 +#define	SSB_CHIPCO_OTP_LIM_OFF		4 + +#define	SSB_CHIPCO_OTP_SIGNATURE	0x578A +#define	SSB_CHIPCO_OTP_MAGIC		0x4E56 + + +struct ssb_device; +struct ssb_serial_port; + +struct ssb_chipcommon { +	struct ssb_device *dev; +	u32 capabilities; +	/* Fast Powerup Delay constant */ +	u16 fast_pwrup_delay; +}; + +extern void ssb_chipcommon_init(struct ssb_chipcommon *cc); + +#include <linux/pm.h> +extern void ssb_chipco_suspend(struct ssb_chipcommon *cc, pm_message_t state); +extern void ssb_chipco_resume(struct ssb_chipcommon *cc); + +extern void ssb_chipco_get_clockcontrol(struct ssb_chipcommon *cc, +					u32 *plltype, u32 *n, u32 *m); +extern void ssb_chipco_timing_init(struct ssb_chipcommon *cc, +				   unsigned long ns_per_cycle); + +enum ssb_clkmode { +	SSB_CLKMODE_SLOW, +	SSB_CLKMODE_FAST, +	SSB_CLKMODE_DYNAMIC, +}; + +extern void ssb_chipco_set_clockmode(struct ssb_chipcommon *cc, +				     enum ssb_clkmode mode); + + +/* GPIO functions */ +static inline u32 ssb_chipco_gpio_in(struct ssb_chipcommon *cc, +				     u32 mask) +{ +	return ssb_read32(cc->dev, SSB_CHIPCO_GPIOIN) & mask; +} + +static inline u32 ssb_chipco_gpio_out(struct ssb_chipcommon *cc, +				     u32 mask, u32 value) +{ +	return ssb_write32_masked(cc->dev, SSB_CHIPCO_GPIOOUT, mask, value); +} + +static inline u32 ssb_chipco_gpio_outen(struct ssb_chipcommon *cc, +				     u32 mask, u32 value) +{ +	return ssb_write32_masked(cc->dev, SSB_CHIPCO_GPIOOUTEN, mask, value); +} + +static inline u32 ssb_chipco_gpio_control(struct ssb_chipcommon *cc, +				     u32 mask, u32 value) +{ +	return ssb_write32_masked(cc->dev, SSB_CHIPCO_GPIOCTL, mask, value); +} + +static inline u32 ssb_chipco_gpio_intmask(struct ssb_chipcommon *cc, +				     u32 mask, u32 value) +{ +	return ssb_write32_masked(cc->dev, SSB_CHIPCO_GPIOINTMASK, mask, value); +} + +static inline u32 ssb_chipco_gpio_polarity(struct ssb_chipcommon *cc, +				     u32 mask, u32 value) +{ +	return ssb_write32_masked(cc->dev, SSB_CHIPCO_GPIOINTPOL, mask, value); +} +/* TODO: GPIO reservation */ + + +#ifdef CONFIG_SSB_SERIAL +extern int ssb_chipco_serial_init(struct ssb_chipcommon *cc, +				  struct ssb_serial_port *ports); +#endif /* CONFIG_SSB_SERIAL */ + +#endif /* __KERNEL__ */ +#endif /* LINUX_SSB_CHIPCO_H_ */ diff --git a/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_extif.h b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_extif.h new file mode 100644 index 000000000..63add5662 --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_extif.h @@ -0,0 +1,195 @@ +/* + * Hardware-specific External Interface I/O core definitions + * for the BCM47xx family of SiliconBackplane-based chips. + * + * The External Interface core supports a total of three external chip selects + * supporting external interfaces. One of the external chip selects is + * used for Flash, one is used for PCMCIA, and the other may be + * programmed to support either a synchronous interface or an + * asynchronous interface. The asynchronous interface can be used to + * support external devices such as UARTs and the BCM2019 Bluetooth + * baseband processor. + * The external interface core also contains 2 on-chip 16550 UARTs, clock + * frequency control, a watchdog interrupt timer, and a GPIO interface. + * + * Copyright 2005, Broadcom Corporation + * Copyright 2006, Michael Buesch + * + * Licensed under the GPL version 2. See COPYING for details. + */ +#ifndef LINUX_SSB_EXTIFCORE_H_ +#define LINUX_SSB_EXTIFCORE_H_ + +#ifdef __KERNEL__ + +struct ssb_extif { +	struct ssb_device *dev; +}; + +/* external interface address space */ +#define	SSB_EXTIF_PCMCIA_MEMBASE(x)	(x) +#define	SSB_EXTIF_PCMCIA_IOBASE(x)	((x) + 0x100000) +#define	SSB_EXTIF_PCMCIA_CFGBASE(x)	((x) + 0x200000) +#define	SSB_EXTIF_CFGIF_BASE(x)		((x) + 0x800000) +#define	SSB_EXTIF_FLASH_BASE(x)		((x) + 0xc00000) + +#define SSB_EXTIF_NR_GPIOOUT		5 +/* GPIO NOTE: + * The multiple instances of output and output enable registers + * are present to allow driver software for multiple cores to control + * gpio outputs without needing to share a single register pair. + * Use the following helper macro to get a register offset value. + */ +#define SSB_EXTIF_GPIO_OUT(index)	({		\ +	BUILD_BUG_ON(index >= SSB_EXTIF_NR_GPIOOUT);	\ +	SSB_EXTIF_GPIO_OUT_BASE + ((index) * 8);	\ +					}) +#define SSB_EXTIF_GPIO_OUTEN(index)	({		\ +	BUILD_BUG_ON(index >= SSB_EXTIF_NR_GPIOOUT);	\ +	SSB_EXTIF_GPIO_OUTEN_BASE + ((index) * 8);	\ +					}) + +/** EXTIF core registers **/ + +#define SSB_EXTIF_CTL			0x0000 +#define  SSB_EXTIF_CTL_UARTEN		(1 << 0) /* UART enable */ +#define SSB_EXTIF_EXTSTAT		0x0004 +#define  SSB_EXTIF_EXTSTAT_EMODE	(1 << 0) /* Endian mode (ro) */ +#define  SSB_EXTIF_EXTSTAT_EIRQPIN	(1 << 1) /* External interrupt pin (ro) */ +#define  SSB_EXTIF_EXTSTAT_GPIOIRQPIN	(1 << 2) /* GPIO interrupt pin (ro) */ +#define SSB_EXTIF_PCMCIA_CFG		0x0010 +#define SSB_EXTIF_PCMCIA_MEMWAIT	0x0014 +#define SSB_EXTIF_PCMCIA_ATTRWAIT	0x0018 +#define SSB_EXTIF_PCMCIA_IOWAIT		0x001C +#define SSB_EXTIF_PROG_CFG		0x0020 +#define SSB_EXTIF_PROG_WAITCNT		0x0024 +#define SSB_EXTIF_FLASH_CFG		0x0028 +#define SSB_EXTIF_FLASH_WAITCNT		0x002C +#define SSB_EXTIF_WATCHDOG		0x0040 +#define SSB_EXTIF_CLOCK_N		0x0044 +#define SSB_EXTIF_CLOCK_SB		0x0048 +#define SSB_EXTIF_CLOCK_PCI		0x004C +#define SSB_EXTIF_CLOCK_MII		0x0050 +#define SSB_EXTIF_GPIO_IN		0x0060 +#define SSB_EXTIF_GPIO_OUT_BASE		0x0064 +#define SSB_EXTIF_GPIO_OUTEN_BASE	0x0068 +#define SSB_EXTIF_EJTAG_OUTEN		0x0090 +#define SSB_EXTIF_GPIO_INTPOL		0x0094 +#define SSB_EXTIF_GPIO_INTMASK		0x0098 +#define SSB_EXTIF_UART_DATA		0x0300 +#define SSB_EXTIF_UART_TIMER		0x0310 +#define SSB_EXTIF_UART_FCR		0x0320 +#define SSB_EXTIF_UART_LCR		0x0330 +#define SSB_EXTIF_UART_MCR		0x0340 +#define SSB_EXTIF_UART_LSR		0x0350 +#define SSB_EXTIF_UART_MSR		0x0360 +#define SSB_EXTIF_UART_SCRATCH		0x0370 + + + + +/* pcmcia/prog/flash_config */ +#define	SSB_EXTCFG_EN			(1 << 0)	/* enable */ +#define	SSB_EXTCFG_MODE			0xE		/* mode */ +#define	SSB_EXTCFG_MODE_SHIFT		1 +#define	 SSB_EXTCFG_MODE_FLASH		0x0		/* flash/asynchronous mode */ +#define	 SSB_EXTCFG_MODE_SYNC		0x2		/* synchronous mode */ +#define	 SSB_EXTCFG_MODE_PCMCIA		0x4		/* pcmcia mode */ +#define	SSB_EXTCFG_DS16			(1 << 4)	/* destsize:  0=8bit, 1=16bit */ +#define	SSB_EXTCFG_BSWAP		(1 << 5)	/* byteswap */ +#define	SSB_EXTCFG_CLKDIV		0xC0		/* clock divider */ +#define	SSB_EXTCFG_CLKDIV_SHIFT		6 +#define	 SSB_EXTCFG_CLKDIV_2		0x0		/* backplane/2 */ +#define	 SSB_EXTCFG_CLKDIV_3		0x40		/* backplane/3 */ +#define	 SSB_EXTCFG_CLKDIV_4		0x80		/* backplane/4 */ +#define	SSB_EXTCFG_CLKEN		(1 << 8)	/* clock enable */ +#define	SSB_EXTCFG_STROBE		(1 << 9)	/* size/bytestrobe (synch only) */ + +/* pcmcia_memwait */ +#define	SSB_PCMCIA_MEMW_0		0x0000003F	/* waitcount0 */ +#define	SSB_PCMCIA_MEMW_1		0x00001F00	/* waitcount1 */ +#define	SSB_PCMCIA_MEMW_1_SHIFT		8 +#define	SSB_PCMCIA_MEMW_2		0x001F0000	/* waitcount2 */ +#define	SSB_PCMCIA_MEMW_2_SHIFT		16 +#define	SSB_PCMCIA_MEMW_3		0x1F000000	/* waitcount3 */ +#define	SSB_PCMCIA_MEMW_3_SHIFT		24 + +/* pcmcia_attrwait */ +#define	SSB_PCMCIA_ATTW_0		0x0000003F	/* waitcount0 */ +#define	SSB_PCMCIA_ATTW_1		0x00001F00	/* waitcount1 */ +#define	SSB_PCMCIA_ATTW_1_SHIFT		8 +#define	SSB_PCMCIA_ATTW_2		0x001F0000	/* waitcount2 */ +#define	SSB_PCMCIA_ATTW_2_SHIFT		16 +#define	SSB_PCMCIA_ATTW_3		0x1F000000	/* waitcount3 */ +#define	SSB_PCMCIA_ATTW_3_SHIFT		24 + +/* pcmcia_iowait */ +#define	SSB_PCMCIA_IOW_0		0x0000003F	/* waitcount0 */ +#define	SSB_PCMCIA_IOW_1		0x00001F00	/* waitcount1 */ +#define	SSB_PCMCIA_IOW_1_SHIFT		8 +#define	SSB_PCMCIA_IOW_2		0x001F0000	/* waitcount2 */ +#define	SSB_PCMCIA_IOW_2_SHIFT		16 +#define	SSB_PCMCIA_IOW_3		0x1F000000	/* waitcount3 */ +#define	SSB_PCMCIA_IOW_3_SHIFT		24 + +/* prog_waitcount */ +#define	SSB_PROG_WCNT_0			0x0000001F	/* waitcount0 */ +#define	SSB_PROG_WCNT_1			0x00001F00	/* waitcount1 */ +#define	SSB_PROG_WCNT_1_SHIFT		8 +#define	SSB_PROG_WCNT_2			0x001F0000	/* waitcount2 */ +#define	SSB_PROG_WCNT_2_SHIFT		16 +#define	SSB_PROG_WCNT_3			0x1F000000	/* waitcount3 */ +#define	SSB_PROG_WCNT_3_SHIFT		24 + +#define SSB_PROG_W0			0x0000000C +#define SSB_PROG_W1			0x00000A00 +#define SSB_PROG_W2			0x00020000 +#define SSB_PROG_W3			0x01000000 + +/* flash_waitcount */ +#define	SSB_FLASH_WCNT_0		0x0000001F	/* waitcount0 */ +#define	SSB_FLASH_WCNT_1		0x00001F00	/* waitcount1 */ +#define	SSB_FLASH_WCNT_1_SHIFT		8 +#define	SSB_FLASH_WCNT_2		0x001F0000	/* waitcount2 */ +#define	SSB_FLASH_WCNT_2_SHIFT		16 +#define	SSB_FLASH_WCNT_3		0x1F000000	/* waitcount3 */ +#define	SSB_FLASH_WCNT_3_SHIFT		24 + +/* watchdog */ +#define SSB_EXTIF_WATCHDOG_CLK		48000000	/* Hz */ + + +/* GPIO functions */ +static inline u32 ssb_extif_gpio_in(struct ssb_extif *extif, +				     u32 mask) +{ +	return ssb_read32(extif->dev, SSB_EXTIF_GPIO_IN) & mask; +} + +static inline u32 ssb_extif_gpio_out(struct ssb_extif *extif, +				     u32 mask, u32 value) +{ +	return ssb_write32_masked(extif->dev, SSB_EXTIF_GPIO_OUT(0), mask, value); +} + +static inline u32 ssb_extif_gpio_outen(struct ssb_extif *extif, +				     u32 mask, u32 value) +{ +	return ssb_write32_masked(extif->dev, SSB_EXTIF_GPIO_OUTEN(0), mask, value); +} + +static inline u32 ssb_extif_gpio_polarity(struct ssb_extif *extif, +				     u32 mask, u32 value) +{ +	return ssb_write32_masked(extif->dev, SSB_EXTIF_GPIO_INTPOL, mask, value); +} + +static inline u32 ssb_extif_gpio_intmask(struct ssb_extif *extif, +				     u32 mask, u32 value) +{ +	return ssb_write32_masked(extif->dev, SSB_EXTIF_GPIO_INTMASK, mask, value); +} + + +#endif /* __KERNEL__ */ +#endif /* LINUX_SSB_EXTIFCORE_H_ */ diff --git a/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_mips.h b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_mips.h new file mode 100644 index 000000000..b1ce1144d --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_mips.h @@ -0,0 +1,47 @@ +#ifndef LINUX_SSB_MIPSCORE_H_ +#define LINUX_SSB_MIPSCORE_H_ + +#ifdef __KERNEL__ + +#ifdef CONFIG_BCM947XX + +struct ssb_device; + +struct ssb_serial_port { +	void *regs; +	unsigned long clockspeed; +	unsigned int irq; +	unsigned int baud_base; +	unsigned int reg_shift; +}; + + +struct ssb_mipscore { +	struct ssb_device *dev; + +	int nr_serial_ports; +	struct ssb_serial_port serial_ports[4]; + +	u32 flash_window; +	u32 flash_window_size; +}; + +extern void ssb_mipscore_init(struct ssb_mipscore *mcore); +extern u32 ssb_cpu_clock(struct ssb_mipscore *mcore); +extern unsigned int ssb_mips_irq(struct ssb_device *dev); + + +#else /* CONFIG_BCM947XX */ + +struct ssb_mipscore { +}; + +static inline +void ssb_mipscore_init(struct ssb_mipscore *mcore) +{ +} + +#endif /* CONFIG_BCM947XX */ + +#endif /* __KERNEL__ */ +#endif /* LINUX_SSB_MIPSCORE_H_ */ diff --git a/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_pci.h b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_pci.h new file mode 100644 index 000000000..5132f2610 --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_driver_pci.h @@ -0,0 +1,108 @@ +#ifndef LINUX_SSB_PCICORE_H_ +#define LINUX_SSB_PCICORE_H_ +#ifdef __KERNEL__ + +#ifdef CONFIG_SSB_DRIVER_PCICORE + +/* PCI core registers. */ +#define SSB_PCICORE_CTL			0x0000	/* PCI Control */ +#define  SSB_PCICORE_CTL_RST_OE		0x00000001 /* PCI_RESET Output Enable */ +#define  SSB_PCICORE_CTL_RST		0x00000002 /* PCI_RESET driven out to pin */ +#define  SSB_PCICORE_CTL_CLK_OE		0x00000004 /* Clock gate Output Enable */ +#define  SSB_PCICORE_CTL_CLK		0x00000008 /* Gate for clock driven out to pin */ +#define SSB_PCICORE_ARBCTL		0x0010	/* PCI Arbiter Control */ +#define  SSB_PCICORE_ARBCTL_INTERN	0x00000001 /* Use internal arbiter */ +#define  SSB_PCICORE_ARBCTL_EXTERN	0x00000002 /* Use external arbiter */ +#define  SSB_PCICORE_ARBCTL_PARKID	0x00000006 /* Mask, selects which agent is parked on an idle bus */ +#define   SSB_PCICORE_ARBCTL_PARKID_LAST	0x00000000 /* Last requestor */ +#define   SSB_PCICORE_ARBCTL_PARKID_4710	0x00000002 /* 4710 */ +#define   SSB_PCICORE_ARBCTL_PARKID_EXT0	0x00000004 /* External requestor 0 */ +#define   SSB_PCICORE_ARBCTL_PARKID_EXT1	0x00000006 /* External requestor 1 */ +#define SSB_PCICORE_ISTAT		0x0020	/* Interrupt status */ +#define  SSB_PCICORE_ISTAT_INTA		0x00000001 /* PCI INTA# */ +#define  SSB_PCICORE_ISTAT_INTB		0x00000002 /* PCI INTB# */ +#define  SSB_PCICORE_ISTAT_SERR		0x00000004 /* PCI SERR# (write to clear) */ +#define  SSB_PCICORE_ISTAT_PERR		0x00000008 /* PCI PERR# (write to clear) */ +#define  SSB_PCICORE_ISTAT_PME		0x00000010 /* PCI PME# */ +#define SSB_PCICORE_IMASK		0x0024	/* Interrupt mask */ +#define  SSB_PCICORE_IMASK_INTA		0x00000001 /* PCI INTA# */ +#define  SSB_PCICORE_IMASK_INTB		0x00000002 /* PCI INTB# */ +#define  SSB_PCICORE_IMASK_SERR		0x00000004 /* PCI SERR# */ +#define  SSB_PCICORE_IMASK_PERR		0x00000008 /* PCI PERR# */ +#define  SSB_PCICORE_IMASK_PME		0x00000010 /* PCI PME# */ +#define SSB_PCICORE_MBOX		0x0028	/* Backplane to PCI Mailbox */ +#define  SSB_PCICORE_MBOX_F0_0		0x00000100 /* PCI function 0, INT 0 */ +#define  SSB_PCICORE_MBOX_F0_1		0x00000200 /* PCI function 0, INT 1 */ +#define  SSB_PCICORE_MBOX_F1_0		0x00000400 /* PCI function 1, INT 0 */ +#define  SSB_PCICORE_MBOX_F1_1		0x00000800 /* PCI function 1, INT 1 */ +#define  SSB_PCICORE_MBOX_F2_0		0x00001000 /* PCI function 2, INT 0 */ +#define  SSB_PCICORE_MBOX_F2_1		0x00002000 /* PCI function 2, INT 1 */ +#define  SSB_PCICORE_MBOX_F3_0		0x00004000 /* PCI function 3, INT 0 */ +#define  SSB_PCICORE_MBOX_F3_1		0x00008000 /* PCI function 3, INT 1 */ +#define SSB_PCICORE_BCAST_ADDR		0x0050	/* Backplane Broadcast Address */ +#define  SSB_PCICORE_BCAST_ADDR_MASK	0x000000FF +#define SSB_PCICORE_BCAST_DATA		0x0054	/* Backplane Broadcast Data */ +#define SSB_PCICORE_GPIO_IN		0x0060	/* rev >= 2 only */ +#define SSB_PCICORE_GPIO_OUT		0x0064	/* rev >= 2 only */ +#define SSB_PCICORE_GPIO_ENABLE		0x0068	/* rev >= 2 only */ +#define SSB_PCICORE_GPIO_CTL		0x006C	/* rev >= 2 only */ +#define SSB_PCICORE_SBTOPCI0		0x0100	/* Backplane to PCI translation 0 (sbtopci0) */ +#define  SSB_PCICORE_SBTOPCI0_MASK	0xFC000000 +#define SSB_PCICORE_SBTOPCI1		0x0104	/* Backplane to PCI translation 1 (sbtopci1) */ +#define  SSB_PCICORE_SBTOPCI1_MASK	0xFC000000 +#define SSB_PCICORE_SBTOPCI2		0x0108	/* Backplane to PCI translation 2 (sbtopci2) */ +#define  SSB_PCICORE_SBTOPCI2_MASK	0xC0000000 + +/* SBtoPCIx */ +#define SSB_PCICORE_SBTOPCI_MEM		0x00000000 +#define SSB_PCICORE_SBTOPCI_IO		0x00000001 +#define SSB_PCICORE_SBTOPCI_CFG0	0x00000002 +#define SSB_PCICORE_SBTOPCI_CFG1	0x00000003 +#define SSB_PCICORE_SBTOPCI_PREF	0x00000004 /* Prefetch enable */ +#define SSB_PCICORE_SBTOPCI_BURST	0x00000008 /* Burst enable */ +#define SSB_PCICORE_SBTOPCI_MRM		0x00000020 /* Memory Read Multiple */ +#define SSB_PCICORE_SBTOPCI_RC		0x00000030 /* Read Command mask (rev >= 11) */ +#define  SSB_PCICORE_SBTOPCI_RC_READ	0x00000000 /* Memory read */ +#define  SSB_PCICORE_SBTOPCI_RC_READL	0x00000010 /* Memory read line */ +#define  SSB_PCICORE_SBTOPCI_RC_READM	0x00000020 /* Memory read multiple */ + + +/* PCIcore specific boardflags */ +#define SSB_PCICORE_BFL_NOPCI		0x00000400 /* Board leaves PCI floating */ + + +struct ssb_pcicore { +	struct ssb_device *dev; +	u8 setup_done:1; +	u8 hostmode:1; +	u8 cardbusmode:1; +}; + +extern void ssb_pcicore_init(struct ssb_pcicore *pc); + +/* Enable IRQ routing for a specific device */ +extern int ssb_pcicore_dev_irqvecs_enable(struct ssb_pcicore *pc, +					  struct ssb_device *dev); + + +#else /* CONFIG_SSB_DRIVER_PCICORE */ + + +struct ssb_pcicore { +}; + +static inline +void ssb_pcicore_init(struct ssb_pcicore *pc) +{ +} + +static inline +int ssb_pcicore_dev_irqvecs_enable(struct ssb_pcicore *pc, +				   struct ssb_device *dev) +{ +	return 0; +} + +#endif /* CONFIG_SSB_DRIVER_PCICORE */ +#endif /* __KERNEL__ */ +#endif /* LINUX_SSB_PCICORE_H_ */ diff --git a/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_regs.h b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_regs.h new file mode 100644 index 000000000..6bb40464d --- /dev/null +++ b/target/linux/brcm47xx-2.6/files/include/linux/ssb/ssb_regs.h @@ -0,0 +1,293 @@ +#ifndef LINUX_SSB_REGS_H_ +#define LINUX_SSB_REGS_H_ +#ifdef __KERNEL__ + + +/* SiliconBackplane Address Map. + * All regions may not exist on all chips. + */ +#define SSB_SDRAM_BASE		0x00000000	/* Physical SDRAM */ +#define SSB_PCI_MEM		0x08000000	/* Host Mode sb2pcitranslation0 (64 MB) */ +#define SSB_PCI_CFG		0x0c000000	/* Host Mode sb2pcitranslation1 (64 MB) */ +#define	SSB_SDRAM_SWAPPED	0x10000000	/* Byteswapped Physical SDRAM */ +#define SSB_ENUM_BASE    	0x18000000	/* Enumeration space base */ +#define	SSB_ENUM_LIMIT		0x18010000	/* Enumeration space limit */ + +#define	SSB_FLASH2		0x1c000000	/* Flash Region 2 (region 1 shadowed here) */ +#define	SSB_FLASH2_SZ		0x02000000	/* Size of Flash Region 2 */ + +#define	SSB_EXTIF_BASE		0x1f000000	/* External Interface region base address */ +#define	SSB_FLASH1		0x1fc00000	/* Flash Region 1 */ +#define	SSB_FLASH1_SZ		0x00400000	/* Size of Flash Region 1 */ + +#define SSB_PCI_DMA		0x40000000	/* Client Mode sb2pcitranslation2 (1 GB) */ +#define SSB_PCI_DMA_SZ		0x40000000	/* Client Mode sb2pcitranslation2 size in bytes */ +#define SSB_PCIE_DMA_L32		0x00000000	/* PCIE Client Mode sb2pcitranslation2 (2 ZettaBytes), low 32 bits */ +#define SSB_PCIE_DMA_H32		0x80000000	/* PCIE Client Mode sb2pcitranslation2 (2 ZettaBytes), high 32 bits */ +#define	SSB_EUART		(SB_EXTIF_BASE + 0x00800000) +#define	SSB_LED			(SB_EXTIF_BASE + 0x00900000) + + +/* Enumeration space constants */ +#define SSB_CORE_SIZE		0x1000	/* Size of a core MMIO area */ +#define SSB_MAX_NR_CORES	((SSB_ENUM_LIMIT - SSB_ENUM_BASE) / SSB_CORE_SIZE) + + +/* mips address */ +#define	SSB_EJTAG		0xff200000	/* MIPS EJTAG space (2M) */ + + +/* SSB PCI config space registers. */ +#define SSB_PMCSR		0x44 +#define  SSB_PE			0x100 +#define	SSB_BAR0_WIN		0x80	/* Backplane address space 0 */ +#define	SSB_BAR1_WIN		0x84	/* Backplane address space 1 */ +#define	SSB_SPROMCTL		0x88	/* SPROM control */ +#define  SSB_SPROMCTL_WE	0x10	/* SPROM write enable */ +#define	SSB_BAR1_CONTROL	0x8c	/* Address space 1 burst control */ +#define SSB_PCI_IRQS		0x90	/* PCI interrupts */ +#define SSB_PCI_IRQMASK		0x94	/* PCI IRQ control and mask (pcirev >= 6 only) */ +#define SSB_BACKPLANE_IRQS	0x98	/* Backplane Interrupts */ +#define SSB_GPIO_IN		0xB0	/* GPIO Input (pcirev >= 3 only) */ +#define SSB_GPIO_OUT		0xB4	/* GPIO Output (pcirev >= 3 only) */ +#define SSB_GPIO_OUT_ENABLE	0xB8	/* GPIO Output Enable/Disable (pcirev >= 3 only) */ +#define  SSB_GPIO_SCS		0x10	/* PCI config space bit 4 for 4306c0 slow clock source */ +#define  SSB_GPIO_HWRAD		0x20	/* PCI config space GPIO 13 for hw radio disable */ +#define  SSB_GPIO_XTAL		0x40	/* PCI config space GPIO 14 for Xtal powerup */ +#define  SSB_GPIO_PLL		0x80	/* PCI config space GPIO 15 for PLL powerdown */ + + +#define SSB_BAR0_MAX_RETRIES	50 + +/* Silicon backplane configuration register definitions */ +#define SSB_IPSFLAG		0x0F08 +#define	 SSB_IPSFLAG_IRQ1	0x0000003F /* which sbflags get routed to mips interrupt 1 */ +#define	 SSB_IPSFLAG_IRQ1_SHIFT	0 +#define	 SSB_IPSFLAG_IRQ2	0x00003F00 /* which sbflags get routed to mips interrupt 2 */ +#define	 SSB_IPSFLAG_IRQ2_SHIFT	8 +#define	 SSB_IPSFLAG_IRQ3	0x003F0000 /* which sbflags get routed to mips interrupt 3 */ +#define	 SSB_IPSFLAG_IRQ3_SHIFT	16 +#define	 SSB_IPSFLAG_IRQ4	0x3F000000 /* which sbflags get routed to mips interrupt 4 */ +#define	 SSB_IPSFLAG_IRQ4_SHIFT	24 +#define SSB_TPSFLAG		0x0F18 +#define  SSB_TPSFLAG_BPFLAG	0x0000003F /* Backplane flag # */ +#define  SSB_TPSFLAG_ALWAYSIRQ	0x00000040 /* IRQ is always sent on the Backplane */ +#define SSB_TMERRLOGA		0x0F48 +#define SSB_TMERRLOG		0x0F50 +#define SSB_ADMATCH3		0x0F60 +#define SSB_ADMATCH2		0x0F68 +#define SSB_ADMATCH1		0x0F70 +#define SSB_IMSTATE		0x0F90     /* SB Initiator Agent State */ +#define  SSB_IMSTATE_PC		0x0000000f /* Pipe Count */ +#define  SSB_IMSTATE_AP_MASK	0x00000030 /* Arbitration Priority */ +#define  SSB_IMSTATE_AP_BOTH	0x00000000 /* Use both timeslices and token */ +#define  SSB_IMSTATE_AP_TS	0x00000010 /* Use timeslices only */ +#define  SSB_IMSTATE_AP_TK	0x00000020 /* Use token only */ +#define  SSB_IMSTATE_AP_RSV	0x00000030 /* Reserved */ +#define  SSB_IMSTATE_IBE	0x00020000 /* In Band Error */ +#define  SSB_IMSTATE_TO		0x00040000 /* Timeout */ +#define SSB_INTVEC		0x0F94     /* SB Interrupt Mask */ +#define  SSB_INTVEC_PCI		0x00000001 /* Enable interrupts for PCI */ +#define  SSB_INTVEC_ENET0	0x00000002 /* Enable interrupts for enet 0 */ +#define  SSB_INTVEC_ILINE20	0x00000004 /* Enable interrupts for iline20 */ +#define  SSB_INTVEC_CODEC	0x00000008 /* Enable interrupts for v90 codec */ +#define  SSB_INTVEC_USB		0x00000010 /* Enable interrupts for usb */ +#define  SSB_INTVEC_EXTIF	0x00000020 /* Enable interrupts for external i/f */ +#define  SSB_INTVEC_ENET1	0x00000040 /* Enable interrupts for enet 1 */ +#define SSB_TMSLOW		0x0F98     /* SB Target State Low */ +#define  SSB_TMSLOW_RESET	0x00000001 /* Reset */ +#define  SSB_TMSLOW_REJECT	0x00000002 /* Reject */ +#define  SSB_TMSLOW_CLOCK	0x00010000 /* Clock Enable */ +#define  SSB_TMSLOW_FGC		0x00020000 /* Force Gated Clocks On */ +#define  SSB_TMSLOW_PE		0x40000000 /* Power Management Enable */ +#define  SSB_TMSLOW_BE		0x80000000 /* BIST Enable */ +#define SSB_TMSHIGH		0x0F9C     /* SB Target State High */ +#define  SSB_TMSHIGH_SERR	0x00000001 /* S-error */ +#define  SSB_TMSHIGH_INT	0x00000002 /* Interrupt */ +#define  SSB_TMSHIGH_BUSY	0x00000004 /* Busy */ +#define  SSB_TMSHIGH_TO		0x00000020 /* Timeout. Backplane rev >= 2.3 only */ +#define  SSB_TMSHIGH_COREFL	0x1FFF0000 /* Core specific flags */ +#define  SSB_TMSHIGH_COREFL_SHIFT	16 +#define  SSB_TMSHIGH_DMA64	0x10000000 /* 64bit DMA supported */ +#define  SSB_TMSHIGH_GCR	0x20000000 /* Gated Clock Request */ +#define  SSB_TMSHIGH_BISTF	0x40000000 /* BIST Failed */ +#define  SSB_TMSHIGH_BISTD	0x80000000 /* BIST Done */ +#define SSB_BWA0		0x0FA0 +#define SSB_IMCFGLO		0x0FA8 +#define  SSB_IMCFGLO_SERTO	0x00000007 /* Service timeout */ +#define  SSB_IMCFGLO_REQTO	0x00000070 /* Request timeout */ +#define  SSB_IMCFGLO_REQTO_SHIFT	4 +#define  SSB_IMCFGLO_CONNID	0x00FF0000 /* Connection ID */ +#define  SSB_IMCFGLO_CONNID_SHIFT	16 +#define SSB_IMCFGHI		0x0FAC +#define SSB_ADMATCH0		0x0FB0 +#define SSB_TMCFGLO		0x0FB8 +#define SSB_TMCFGHI		0x0FBC +#define SSB_BCONFIG		0x0FC0 +#define SSB_BSTATE		0x0FC8 +#define SSB_ACTCFG		0x0FD8 +#define SSB_FLAGST		0x0FE8 +#define SSB_IDLOW		0x0FF8 +#define  SSB_IDLOW_CFGSP	0x00000003 /* Config Space */ +#define  SSB_IDLOW_ADDRNGE	0x00000038 /* Address Ranges supported */ +#define  SSB_IDLOW_ADDRNGE_SHIFT	3 +#define  SSB_IDLOW_SYNC		0x00000040 +#define  SSB_IDLOW_INITIATOR	0x00000080 +#define  SSB_IDLOW_MIBL		0x00000F00 /* Minimum Backplane latency */ +#define  SSB_IDLOW_MIBL_SHIFT	8 +#define  SSB_IDLOW_MABL		0x0000F000 /* Maximum Backplane latency */ +#define  SSB_IDLOW_MABL_SHIFT	12 +#define  SSB_IDLOW_TIF		0x00010000 /* This Initiator is first */ +#define  SSB_IDLOW_CCW		0x000C0000 /* Cycle counter width */ +#define  SSB_IDLOW_CCW_SHIFT	18 +#define  SSB_IDLOW_TPT		0x00F00000 /* Target ports */ +#define  SSB_IDLOW_TPT_SHIFT	20 +#define  SSB_IDLOW_INITP	0x0F000000 /* Initiator ports */ +#define  SSB_IDLOW_INITP_SHIFT	24 +#define  SSB_IDLOW_SSBREV	0xF0000000 /* Sonics Backplane Revision code */ +#define  SSB_IDLOW_SSBREV_22	0x00000000 /* <= 2.2 */ +#define  SSB_IDLOW_SSBREV_23	0x10000000 /* 2.3 */ +#define SSB_IDHIGH		0x0FFC     /* SB Identification High */ +#define  SSB_IDHIGH_RCLO	0x0000000F /* Revision Code (low part) */ +#define  SSB_IDHIGH_CC		0x00008FF0 /* Core Code */ +#define  SSB_IDHIGH_CC_SHIFT	4 +#define  SSB_IDHIGH_RCHI	0x00007000 /* Revision Code (high part) */ +#define  SSB_IDHIGH_RCHI_SHIFT	8	   /* yes, shift 8 is right */ +#define  SSB_IDHIGH_VC		0xFFFF0000 /* Vendor Code */ +#define  SSB_IDHIGH_VC_SHIFT	16 + +/* SPROM shadow area. If not otherwise noted, fields are + * two bytes wide. Note that the SPROM can _only_ be read + * in two-byte quantinies. + */ +#define SSB_SPROMSIZE_WORDS		64 +#define SSB_SPROMSIZE_BYTES		(SSB_SPROMSIZE_WORDS * sizeof(u16)) +#define SSB_SPROM_BASE			0x1000 +#define SSB_SPROM_REVISION		0x107E +#define  SSB_SPROM_REVISION_REV		0x00FF	/* SPROM Revision number */ +#define  SSB_SPROM_REVISION_CRC		0xFF00	/* SPROM CRC8 value */ +#define  SSB_SPROM_REVISION_CRC_SHIFT	8 +/* SPROM Revision 1 */ +#define SSB_SPROM1_SPID			0x1004	/* Subsystem Product ID for PCI */ +#define SSB_SPROM1_SVID			0x1006	/* Subsystem Vendor ID for PCI */ +#define SSB_SPROM1_PID			0x1008	/* Product ID for PCI */ +#define SSB_SPROM1_IL0MAC		0x1048	/* 6 bytes MAC address for 802.11b/g */ +#define SSB_SPROM1_ET0MAC		0x104E	/* 6 bytes MAC address for Ethernet */ +#define SSB_SPROM1_ET1MAC		0x1054	/* 6 bytes MAC address for 802.11a */ +#define SSB_SPROM1_ETHPHY		0x105A	/* Ethernet PHY settings */ +#define  SSB_SPROM1_ETHPHY_ET0A		0x001F	/* MII Address for enet0 */ +#define  SSB_SPROM1_ETHPHY_ET1A		0x03E0	/* MII Address for enet1 */ +#define  SSB_SPROM1_ETHPHY_ET1A_SHIFT	5 +#define  SSB_SPROM1_ETHPHY_ET0M		(1<<14)	/* MDIO for enet0 */ +#define  SSB_SPROM1_ETHPHY_ET1M		(1<<15)	/* MDIO for enet1 */ +#define SSB_SPROM1_BINF			0x105C	/* Board info */ +#define  SSB_SPROM1_BINF_BREV		0x00FF	/* Board Revision */ +#define  SSB_SPROM1_BINF_CCODE		0x0F00	/* Country Code */ +#define  SSB_SPROM1_BINF_CCODE_SHIFT	8 +#define  SSB_SPROM1_BINF_ANTA		0x3000	/* Available A-PHY antennas */ +#define  SSB_SPROM1_BINF_ANTA_SHIFT	12 +#define  SSB_SPROM1_BINF_ANTBG		0xC000	/* Available B-PHY antennas */ +#define  SSB_SPROM1_BINF_ANTBG_SHIFT	14 +#define SSB_SPROM1_PA0B0		0x105E +#define SSB_SPROM1_PA0B1		0x1060 +#define SSB_SPROM1_PA0B2		0x1062 +#define SSB_SPROM1_GPIOA		0x1064	/* General Purpose IO pins 0 and 1 */ +#define  SSB_SPROM1_GPIOA_P0		0x00FF	/* Pin 0 */ +#define  SSB_SPROM1_GPIOA_P1		0xFF00	/* Pin 1 */ +#define  SSB_SPROM1_GPIOA_P1_SHIFT	8 +#define SSB_SPROM1_GPIOB		0x1066	/* General Purpuse IO pins 2 and 3 */ +#define  SSB_SPROM1_GPIOB_P2		0x00FF	/* Pin 2 */ +#define  SSB_SPROM1_GPIOB_P3		0xFF00	/* Pin 3 */ +#define  SSB_SPROM1_GPIOB_P3_SHIFT	8 +#define SSB_SPROM1_MAXPWR		0x1068	/* Power Amplifier Max Power */ +#define  SSB_SPROM1_MAXPWR_A		0x00FF	/* A-PHY (in dBm Q5.2) */ +#define  SSB_SPROM1_MAXPWR_BG		0xFF00	/* B-PHY and G-PHY (in dBm Q5.2) */ +#define  SSB_SPROM1_MAXPWR_BG_SHIFT	8 +#define SSB_SPROM1_PA1B0		0x106A +#define SSB_SPROM1_PA1B1		0x106C +#define SSB_SPROM1_PA1B2		0x106E +#define SSB_SPROM1_ITSSI		0x1070	/* Idle TSSI Target */ +#define  SSB_SPROM1_ITSSI_A		0x00FF	/* A-PHY */ +#define  SSB_SPROM1_ITSSI_BG		0xFF00	/* B-PHY and G-PHY */ +#define  SSB_SPROM1_ITSSI_BG_SHIFT	8 +#define SSB_SPROM1_BFLLO		0x1072	/* Boardflags (low 16 bits) */ +#define SSB_SPROM1_AGAIN		0x1074	/* Antenna Gain (in dBm Q5.2) */ +#define  SSB_SPROM1_AGAIN_A		0x00FF	/* A-PHY */ +#define  SSB_SPROM1_AGAIN_BG		0xFF00	/* B-PHY and G-PHY */ +#define  SSB_SPROM1_AGAIN_BG_SHIFT	8 +#define SSB_SPROM1_OEM			0x1076	/* 8 bytes OEM string (rev 1 only) */ +/* SPROM Revision 2 (inherits from rev 1) */ +#define SSB_SPROM2_BFLHI		0x1038	/* Boardflags (high 16 bits) */ +#define SSB_SPROM2_MAXP_A		0x103A	/* A-PHY Max Power */ +#define  SSB_SPROM2_MAXP_A_HI		0x00FF	/* Max Power High */ +#define  SSB_SPROM2_MAXP_A_LO		0xFF00	/* Max Power Low */ +#define  SSB_SPROM2_MAXP_A_LO_SHIFT	8 +#define SSB_SPROM2_PA1LOB0		0x103C	/* A-PHY PowerAmplifier Low Settings */ +#define SSB_SPROM2_PA1LOB1		0x103E	/* A-PHY PowerAmplifier Low Settings */ +#define SSB_SPROM2_PA1LOB2		0x1040	/* A-PHY PowerAmplifier Low Settings */ +#define SSB_SPROM2_PA1HIB0		0x1042	/* A-PHY PowerAmplifier High Settings */ +#define SSB_SPROM2_PA1HIB1		0x1044	/* A-PHY PowerAmplifier High Settings */ +#define SSB_SPROM2_PA1HIB2		0x1046	/* A-PHY PowerAmplifier High Settings */ +#define SSB_SPROM2_OPO			0x1078	/* OFDM Power Offset from CCK Level */ +#define  SSB_SPROM2_OPO_VALUE		0x00FF +#define  SSB_SPROM2_OPO_UNUSED		0xFF00 +#define SSB_SPROM2_CCODE		0x107C	/* Two char Country Code */ +/* SPROM Revision 3 (inherits from rev 2) */ +#define SSB_SPROM3_OFDMAPO		0x102C	/* A-PHY OFDM Mid Power Offset (4 bytes, BigEndian) */ +#define SSB_SPROM3_OFDMALPO		0x1030	/* A-PHY OFDM Low Power Offset (4 bytes, BigEndian) */ +#define SSB_SPROM3_OFDMAHPO		0x1034	/* A-PHY OFDM High Power Offset (4 bytes, BigEndian) */ +#define SSB_SPROM3_GPIOLDC		0x1042	/* GPIO LED Powersave Duty Cycle (4 bytes, BigEndian) */ +#define  SSB_SPROM3_GPIOLDC_OFF		0x0000FF00	/* Off Count */ +#define  SSB_SPROM3_GPIOLDC_OFF_SHIFT	8 +#define  SSB_SPROM3_GPIOLDC_ON		0x00FF0000	/* On Count */ +#define  SSB_SPROM3_GPIOLDC_ON_SHIFT	16 +#define SSB_SPROM3_CCKPO		0x1078	/* CCK Power Offset */ +#define  SSB_SPROM3_CCKPO_1M		0x000F	/* 1M Rate PO */ +#define  SSB_SPROM3_CCKPO_2M		0x00F0	/* 2M Rate PO */ +#define  SSB_SPROM3_CCKPO_2M_SHIFT	4 +#define  SSB_SPROM3_CCKPO_55M		0x0F00	/* 5.5M Rate PO */ +#define  SSB_SPROM3_CCKPO_55M_SHIFT	8 +#define  SSB_SPROM3_CCKPO_11M		0xF000	/* 11M Rate PO */ +#define  SSB_SPROM3_CCKPO_11M_SHIFT	12 +#define  SSB_SPROM3_OFDMGPO		0x107A	/* G-PHY OFDM Power Offset (4 bytes, BigEndian) */ + +/* Values for SSB_SPROM1_BINF_CCODE */ +enum { +	SSB_SPROM1CCODE_WORLD = 0, +	SSB_SPROM1CCODE_THAILAND, +	SSB_SPROM1CCODE_ISRAEL, +	SSB_SPROM1CCODE_JORDAN, +	SSB_SPROM1CCODE_CHINA, +	SSB_SPROM1CCODE_JAPAN, +	SSB_SPROM1CCODE_USA_CANADA_ANZ, +	SSB_SPROM1CCODE_EUROPE, +	SSB_SPROM1CCODE_USA_LOW, +	SSB_SPROM1CCODE_JAPAN_HIGH, +	SSB_SPROM1CCODE_ALL, +	SSB_SPROM1CCODE_NONE, +}; + +/* Address-Match values and masks (SSB_ADMATCH?) */ +#define SSB_ADM_TYPE			0x00000003	/* Address type */ +#define  SSB_ADM_TYPE0			0 +#define  SSB_ADM_TYPE1			1 +#define  SSB_ADM_TYPE2			2 +#define SSB_ADM_AD64			0x00000004 +#define SSB_ADM_SZ0			0x000000F8	/* Type0 size */ +#define SSB_ADM_SZ0_SHIFT		3 +#define SSB_ADM_SZ1			0x000001F8	/* Type1 size */ +#define SSB_ADM_SZ1_SHIFT		3 +#define SSB_ADM_SZ2			0x000001F8	/* Type2 size */ +#define SSB_ADM_SZ2_SHIFT		3 +#define SSB_ADM_EN			0x00000400	/* Enable */ +#define SSB_ADM_NEG			0x00000800	/* Negative decode */ +#define SSB_ADM_BASE0			0xFFFFFF00	/* Type0 base address */ +#define SSB_ADM_BASE0_SHIFT		8 +#define SSB_ADM_BASE1			0xFFFFF000	/* Type1 base address for the core */ +#define SSB_ADM_BASE1_SHIFT		12 +#define SSB_ADM_BASE2			0xFFFF0000	/* Type2 base address for the core */ +#define SSB_ADM_BASE2_SHIFT		16 + + +#endif /* __KERNEL__ */ +#endif /* LINUX_SSB_REGS_H_ */ | 
