diff options
| author | David S. Miller <davem@davemloft.net> | 2008-07-18 02:39:39 -0700 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2008-07-18 02:39:39 -0700 | 
| commit | 49997d75152b3d23c53b0fa730599f2f74c92c65 (patch) | |
| tree | 46e93126170d02cfec9505172e545732c1b69656 /drivers/net | |
| parent | a0c80b80e0fb48129e4e9d6a9ede914f9ff1850d (diff) | |
| parent | 5b664cb235e97afbf34db9c4d77f08ebd725335e (diff) | |
| download | olio-linux-3.10-49997d75152b3d23c53b0fa730599f2f74c92c65.tar.xz olio-linux-3.10-49997d75152b3d23c53b0fa730599f2f74c92c65.zip  | |
Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/torvalds/linux-2.6
Conflicts:
	Documentation/powerpc/booting-without-of.txt
	drivers/atm/Makefile
	drivers/net/fs_enet/fs_enet-main.c
	drivers/pci/pci-acpi.c
	net/8021q/vlan.c
	net/iucv/iucv.c
Diffstat (limited to 'drivers/net')
53 files changed, 492 insertions, 3826 deletions
diff --git a/drivers/net/Kconfig b/drivers/net/Kconfig index 9490cb17233..611e9fb18b6 100644 --- a/drivers/net/Kconfig +++ b/drivers/net/Kconfig @@ -209,7 +209,7 @@ config MII  config MACB  	tristate "Atmel MACB support" -	depends on AVR32 || ARCH_AT91SAM9260 || ARCH_AT91SAM9263 || ARCH_AT91CAP9 +	depends on AVR32 || ARCH_AT91SAM9260 || ARCH_AT91SAM9263 || ARCH_AT91SAM9G20 || ARCH_AT91CAP9  	select PHYLIB  	help  	  The Atmel MACB ethernet interface is found on many AT32 and AT91 @@ -1848,7 +1848,6 @@ config NE_H8300  	  Say Y here if you want to use the NE2000 compatible  	  controller on the Renesas H8/300 processor. -source "drivers/net/fec_8xx/Kconfig"  source "drivers/net/fs_enet/Kconfig"  endif # NET_ETHERNET diff --git a/drivers/net/Makefile b/drivers/net/Makefile index 3292d0af59c..4b17a9ab786 100644 --- a/drivers/net/Makefile +++ b/drivers/net/Makefile @@ -217,7 +217,6 @@ obj-$(CONFIG_SMC91X) += smc91x.o  obj-$(CONFIG_SMC911X) += smc911x.o  obj-$(CONFIG_BFIN_MAC) += bfin_mac.o  obj-$(CONFIG_DM9000) += dm9000.o -obj-$(CONFIG_FEC_8XX) += fec_8xx/  obj-$(CONFIG_PASEMI_MAC) += pasemi_mac_driver.o  pasemi_mac_driver-objs := pasemi_mac.o pasemi_mac_ethtool.o  obj-$(CONFIG_MLX4_CORE) += mlx4/ diff --git a/drivers/net/arm/etherh.c b/drivers/net/arm/etherh.c index 00081d2b9cd..e9d15eccad0 100644 --- a/drivers/net/arm/etherh.c +++ b/drivers/net/arm/etherh.c @@ -647,7 +647,7 @@ etherh_probe(struct expansion_card *ec, const struct ecard_id *id)  	struct ei_device *ei_local;  	struct net_device *dev;  	struct etherh_priv *eh; -	int i, ret; +	int ret;  	DECLARE_MAC_BUF(mac);  	etherh_banner(); diff --git a/drivers/net/cxgb3/common.h b/drivers/net/cxgb3/common.h index d444f5881f5..9ecf8a6dc97 100644 --- a/drivers/net/cxgb3/common.h +++ b/drivers/net/cxgb3/common.h @@ -687,8 +687,9 @@ int t3_seeprom_write(struct adapter *adapter, u32 addr, __le32 data);  int t3_seeprom_wp(struct adapter *adapter, int enable);  int t3_get_tp_version(struct adapter *adapter, u32 *vers);  int t3_check_tpsram_version(struct adapter *adapter, int *must_load); -int t3_check_tpsram(struct adapter *adapter, u8 *tp_ram, unsigned int size); -int t3_set_proto_sram(struct adapter *adap, u8 *data); +int t3_check_tpsram(struct adapter *adapter, const u8 *tp_ram, +		    unsigned int size); +int t3_set_proto_sram(struct adapter *adap, const u8 *data);  int t3_read_flash(struct adapter *adapter, unsigned int addr,  		  unsigned int nwords, u32 *data, int byte_oriented);  int t3_load_fw(struct adapter *adapter, const u8 * fw_data, unsigned int size); diff --git a/drivers/net/cxgb3/cxgb3_ctl_defs.h b/drivers/net/cxgb3/cxgb3_ctl_defs.h index d38e6cc9266..6ad92405d9a 100644 --- a/drivers/net/cxgb3/cxgb3_ctl_defs.h +++ b/drivers/net/cxgb3/cxgb3_ctl_defs.h @@ -54,6 +54,7 @@ enum {  	RDMA_CQ_DISABLE		= 16,  	RDMA_CTRL_QP_SETUP	= 17,  	RDMA_GET_MEM		= 18, +	RDMA_GET_MIB		= 19,  	GET_RX_PAGE_INFO	= 50,  }; diff --git a/drivers/net/cxgb3/cxgb3_offload.c b/drivers/net/cxgb3/cxgb3_offload.c index c69f4c0187d..c5b3de1bb45 100644 --- a/drivers/net/cxgb3/cxgb3_offload.c +++ b/drivers/net/cxgb3/cxgb3_offload.c @@ -314,6 +314,12 @@ static int cxgb_rdma_ctl(struct adapter *adapter, unsigned int req, void *data)  		spin_unlock_irq(&adapter->sge.reg_lock);  		break;  	} +	case RDMA_GET_MIB: { +		spin_lock(&adapter->stats_lock); +		t3_tp_get_mib_stats(adapter, (struct tp_mib_stats *)data); +		spin_unlock(&adapter->stats_lock); +		break; +	}  	default:  		ret = -EOPNOTSUPP;  	} @@ -392,6 +398,7 @@ static int cxgb_offload_ctl(struct t3cdev *tdev, unsigned int req, void *data)  	case RDMA_CQ_DISABLE:  	case RDMA_CTRL_QP_SETUP:  	case RDMA_GET_MEM: +	case RDMA_GET_MIB:  		if (!offload_running(adapter))  			return -EAGAIN;  		return cxgb_rdma_ctl(adapter, req, data); diff --git a/drivers/net/cxgb3/t3_hw.c b/drivers/net/cxgb3/t3_hw.c index d405a932c73..47d51788a46 100644 --- a/drivers/net/cxgb3/t3_hw.c +++ b/drivers/net/cxgb3/t3_hw.c @@ -923,7 +923,8 @@ int t3_check_tpsram_version(struct adapter *adapter, int *must_load)   *	Checks if an adapter's tp sram is compatible with the driver.   *	Returns 0 if the versions are compatible, a negative error otherwise.   */ -int t3_check_tpsram(struct adapter *adapter, u8 *tp_sram, unsigned int size) +int t3_check_tpsram(struct adapter *adapter, const u8 *tp_sram, +		    unsigned int size)  {  	u32 csum;  	unsigned int i; @@ -2875,10 +2876,10 @@ static void ulp_config(struct adapter *adap, const struct tp_params *p)   *   *	Write the contents of the protocol SRAM.   */ -int t3_set_proto_sram(struct adapter *adap, u8 *data) +int t3_set_proto_sram(struct adapter *adap, const u8 *data)  {  	int i; -	__be32 *buf = (__be32 *)data; +	const __be32 *buf = (const __be32 *)data;  	for (i = 0; i < PROTO_SRAM_LINES; i++) {  		t3_write_reg(adap, A_TP_EMBED_OP_FIELD5, be32_to_cpu(*buf++)); diff --git a/drivers/net/cxgb3/version.h b/drivers/net/cxgb3/version.h index a0177fc55e2..29db711303b 100644 --- a/drivers/net/cxgb3/version.h +++ b/drivers/net/cxgb3/version.h @@ -38,7 +38,7 @@  #define DRV_VERSION "1.0-ko"  /* Firmware version */ -#define FW_VERSION_MAJOR 6 +#define FW_VERSION_MAJOR 7  #define FW_VERSION_MINOR 0  #define FW_VERSION_MICRO 0  #endif				/* __CHELSIO_VERSION_H */ diff --git a/drivers/net/fec_8xx/Kconfig b/drivers/net/fec_8xx/Kconfig deleted file mode 100644 index afb34ded26e..00000000000 --- a/drivers/net/fec_8xx/Kconfig +++ /dev/null @@ -1,20 +0,0 @@ -config FEC_8XX -	tristate "Motorola 8xx FEC driver" -	depends on 8XX -	select MII - -config FEC_8XX_GENERIC_PHY -	bool "Support any generic PHY" -	depends on FEC_8XX -	default y - -config FEC_8XX_DM9161_PHY -	bool "Support DM9161 PHY" -	depends on FEC_8XX -	default n - -config FEC_8XX_LXT971_PHY -	bool "Support LXT971/LXT972 PHY" -	depends on FEC_8XX -	default n - diff --git a/drivers/net/fec_8xx/Makefile b/drivers/net/fec_8xx/Makefile deleted file mode 100644 index 70c54f8c48e..00000000000 --- a/drivers/net/fec_8xx/Makefile +++ /dev/null @@ -1,12 +0,0 @@ -# -# Makefile for the Motorola 8xx FEC ethernet controller -# - -obj-$(CONFIG_FEC_8XX) += fec_8xx.o - -fec_8xx-objs := fec_main.o fec_mii.o - -# the platform instantatiation objects -ifeq ($(CONFIG_NETTA),y) -fec_8xx-objs	+= fec_8xx-netta.o -endif diff --git a/drivers/net/fec_8xx/fec_8xx-netta.c b/drivers/net/fec_8xx/fec_8xx-netta.c deleted file mode 100644 index 79deee222e2..00000000000 --- a/drivers/net/fec_8xx/fec_8xx-netta.c +++ /dev/null @@ -1,151 +0,0 @@ -/* - * FEC instantatiation file for NETTA - */ - -#include <linux/kernel.h> -#include <linux/types.h> -#include <linux/string.h> -#include <linux/ptrace.h> -#include <linux/errno.h> -#include <linux/ioport.h> -#include <linux/slab.h> -#include <linux/interrupt.h> -#include <linux/pci.h> -#include <linux/init.h> -#include <linux/delay.h> -#include <linux/netdevice.h> -#include <linux/etherdevice.h> -#include <linux/skbuff.h> -#include <linux/spinlock.h> -#include <linux/mii.h> -#include <linux/ethtool.h> -#include <linux/bitops.h> - -#include <asm/8xx_immap.h> -#include <asm/pgtable.h> -#include <asm/mpc8xx.h> -#include <asm/irq.h> -#include <asm/uaccess.h> -#include <asm/cpm1.h> - -#include "fec_8xx.h" - -/*************************************************/ - -static struct fec_platform_info fec1_info = { -	.fec_no = 0, -	.use_mdio = 1, -	.phy_addr = 8, -	.fec_irq = SIU_LEVEL1, -	.phy_irq = CPM_IRQ_OFFSET + CPMVEC_PIO_PC6, -	.rx_ring = 128, -	.tx_ring = 16, -	.rx_copybreak = 240, -	.use_napi = 1, -	.napi_weight = 17, -}; - -static struct fec_platform_info fec2_info = { -	.fec_no = 1, -	.use_mdio = 1, -	.phy_addr = 2, -	.fec_irq = SIU_LEVEL3, -	.phy_irq = CPM_IRQ_OFFSET + CPMVEC_PIO_PC7, -	.rx_ring = 128, -	.tx_ring = 16, -	.rx_copybreak = 240, -	.use_napi = 1, -	.napi_weight = 17, -}; - -static struct net_device *fec1_dev; -static struct net_device *fec2_dev; - -/* XXX custom u-boot & Linux startup needed */ -extern const char *__fw_getenv(const char *var); - -/* access ports */ -#define setbits32(_addr, _v) __fec_out32(&(_addr), __fec_in32(&(_addr)) |  (_v)) -#define clrbits32(_addr, _v) __fec_out32(&(_addr), __fec_in32(&(_addr)) & ~(_v)) - -#define setbits16(_addr, _v) __fec_out16(&(_addr), __fec_in16(&(_addr)) |  (_v)) -#define clrbits16(_addr, _v) __fec_out16(&(_addr), __fec_in16(&(_addr)) & ~(_v)) - -int fec_8xx_platform_init(void) -{ -	immap_t *immap = (immap_t *)IMAP_ADDR; -	bd_t *bd = (bd_t *) __res; -	const char *s; -	char *e; -	int i; - -	/* use MDC for MII */ -	setbits16(immap->im_ioport.iop_pdpar, 0x0080); -	clrbits16(immap->im_ioport.iop_pddir, 0x0080); - -	/* configure FEC1 pins */ -	setbits16(immap->im_ioport.iop_papar, 0xe810); -	setbits16(immap->im_ioport.iop_padir, 0x0810); -	clrbits16(immap->im_ioport.iop_padir, 0xe000); - -	setbits32(immap->im_cpm.cp_pbpar, 0x00000001); -	clrbits32(immap->im_cpm.cp_pbdir, 0x00000001); - -	setbits32(immap->im_cpm.cp_cptr, 0x00000100); -	clrbits32(immap->im_cpm.cp_cptr, 0x00000050); - -	clrbits16(immap->im_ioport.iop_pcpar, 0x0200); -	clrbits16(immap->im_ioport.iop_pcdir, 0x0200); -	clrbits16(immap->im_ioport.iop_pcso, 0x0200); -	setbits16(immap->im_ioport.iop_pcint, 0x0200); - -	/* configure FEC2 pins */ -	setbits32(immap->im_cpm.cp_pepar, 0x00039620); -	setbits32(immap->im_cpm.cp_pedir, 0x00039620); -	setbits32(immap->im_cpm.cp_peso, 0x00031000); -	clrbits32(immap->im_cpm.cp_peso, 0x00008620); - -	setbits32(immap->im_cpm.cp_cptr, 0x00000080); -	clrbits32(immap->im_cpm.cp_cptr, 0x00000028); - -	clrbits16(immap->im_ioport.iop_pcpar, 0x0200); -	clrbits16(immap->im_ioport.iop_pcdir, 0x0200); -	clrbits16(immap->im_ioport.iop_pcso, 0x0200); -	setbits16(immap->im_ioport.iop_pcint, 0x0200); - -	/* fill up */ -	fec1_info.sys_clk = bd->bi_intfreq; -	fec2_info.sys_clk = bd->bi_intfreq; - -	s = __fw_getenv("ethaddr"); -	if (s != NULL) { -		for (i = 0; i < 6; i++) { -			fec1_info.macaddr[i] = simple_strtoul(s, &e, 16); -			if (*e) -				s = e + 1; -		} -	} - -	s = __fw_getenv("eth1addr"); -	if (s != NULL) { -		for (i = 0; i < 6; i++) { -			fec2_info.macaddr[i] = simple_strtoul(s, &e, 16); -			if (*e) -				s = e + 1; -		} -	} - -	fec_8xx_init_one(&fec1_info, &fec1_dev); -	fec_8xx_init_one(&fec2_info, &fec2_dev); - -	return fec1_dev != NULL && fec2_dev != NULL ? 0 : -1; -} - -void fec_8xx_platform_cleanup(void) -{ -	if (fec2_dev != NULL) -		fec_8xx_cleanup_one(fec2_dev); - -	if (fec1_dev != NULL) -		fec_8xx_cleanup_one(fec1_dev); -} diff --git a/drivers/net/fec_8xx/fec_8xx.h b/drivers/net/fec_8xx/fec_8xx.h deleted file mode 100644 index f3b1c6fbba8..00000000000 --- a/drivers/net/fec_8xx/fec_8xx.h +++ /dev/null @@ -1,220 +0,0 @@ -#ifndef FEC_8XX_H -#define FEC_8XX_H - -#include <linux/mii.h> -#include <linux/netdevice.h> - -#include <linux/types.h> - -/* HW info */ - -/* CRC polynomium used by the FEC for the multicast group filtering */ -#define FEC_CRC_POLY   0x04C11DB7 - -#define MII_ADVERTISE_HALF	(ADVERTISE_100HALF | \ -				 ADVERTISE_10HALF | ADVERTISE_CSMA) -#define MII_ADVERTISE_ALL	(ADVERTISE_100FULL | \ -				 ADVERTISE_10FULL | MII_ADVERTISE_HALF) - -/* Interrupt events/masks. -*/ -#define FEC_ENET_HBERR	0x80000000U	/* Heartbeat error          */ -#define FEC_ENET_BABR	0x40000000U	/* Babbling receiver        */ -#define FEC_ENET_BABT	0x20000000U	/* Babbling transmitter     */ -#define FEC_ENET_GRA	0x10000000U	/* Graceful stop complete   */ -#define FEC_ENET_TXF	0x08000000U	/* Full frame transmitted   */ -#define FEC_ENET_TXB	0x04000000U	/* A buffer was transmitted */ -#define FEC_ENET_RXF	0x02000000U	/* Full frame received      */ -#define FEC_ENET_RXB	0x01000000U	/* A buffer was received    */ -#define FEC_ENET_MII	0x00800000U	/* MII interrupt            */ -#define FEC_ENET_EBERR	0x00400000U	/* SDMA bus error           */ - -#define FEC_ECNTRL_PINMUX	0x00000004 -#define FEC_ECNTRL_ETHER_EN	0x00000002 -#define FEC_ECNTRL_RESET	0x00000001 - -#define FEC_RCNTRL_BC_REJ	0x00000010 -#define FEC_RCNTRL_PROM		0x00000008 -#define FEC_RCNTRL_MII_MODE	0x00000004 -#define FEC_RCNTRL_DRT		0x00000002 -#define FEC_RCNTRL_LOOP		0x00000001 - -#define FEC_TCNTRL_FDEN		0x00000004 -#define FEC_TCNTRL_HBC		0x00000002 -#define FEC_TCNTRL_GTS		0x00000001 - -/* values for MII phy_status */ - -#define PHY_CONF_ANE	0x0001	/* 1 auto-negotiation enabled     */ -#define PHY_CONF_LOOP	0x0002	/* 1 loopback mode enabled        */ -#define PHY_CONF_SPMASK	0x00f0	/* mask for speed                 */ -#define PHY_CONF_10HDX	0x0010	/* 10 Mbit half duplex supported  */ -#define PHY_CONF_10FDX	0x0020	/* 10 Mbit full duplex supported  */ -#define PHY_CONF_100HDX	0x0040	/* 100 Mbit half duplex supported */ -#define PHY_CONF_100FDX	0x0080	/* 100 Mbit full duplex supported */ - -#define PHY_STAT_LINK	0x0100	/* 1 up - 0 down                  */ -#define PHY_STAT_FAULT	0x0200	/* 1 remote fault                 */ -#define PHY_STAT_ANC	0x0400	/* 1 auto-negotiation complete    */ -#define PHY_STAT_SPMASK	0xf000	/* mask for speed                 */ -#define PHY_STAT_10HDX	0x1000	/* 10 Mbit half duplex selected   */ -#define PHY_STAT_10FDX	0x2000	/* 10 Mbit full duplex selected   */ -#define PHY_STAT_100HDX	0x4000	/* 100 Mbit half duplex selected  */ -#define PHY_STAT_100FDX	0x8000	/* 100 Mbit full duplex selected  */ - -typedef struct phy_info { -	unsigned int id; -	const char *name; -	void (*startup) (struct net_device * dev); -	void (*shutdown) (struct net_device * dev); -	void (*ack_int) (struct net_device * dev); -} phy_info_t; - -/* The FEC stores dest/src/type, data, and checksum for receive packets. - */ -#define MAX_MTU 1508		/* Allow fullsized pppoe packets over VLAN */ -#define MIN_MTU 46		/* this is data size */ -#define CRC_LEN 4 - -#define PKT_MAXBUF_SIZE		(MAX_MTU+ETH_HLEN+CRC_LEN) -#define PKT_MINBUF_SIZE		(MIN_MTU+ETH_HLEN+CRC_LEN) - -/* Must be a multiple of 4 */ -#define PKT_MAXBLR_SIZE		((PKT_MAXBUF_SIZE+3) & ~3) -/* This is needed so that invalidate_xxx wont invalidate too much */ -#define ENET_RX_FRSIZE		L1_CACHE_ALIGN(PKT_MAXBUF_SIZE) - -/* platform interface */ - -struct fec_platform_info { -	int fec_no;		/* FEC index                  */ -	int use_mdio;		/* use external MII           */ -	int phy_addr;		/* the phy address            */ -	int fec_irq, phy_irq;	/* the irq for the controller */ -	int rx_ring, tx_ring;	/* number of buffers on rx    */ -	int sys_clk;		/* system clock               */ -	__u8 macaddr[6];	/* mac address                */ -	int rx_copybreak;	/* limit we copy small frames */ -	int use_napi;		/* use NAPI                   */ -	int napi_weight;	/* NAPI weight                */ -}; - -/* forward declaration */ -struct fec; - -struct fec_enet_private { -	spinlock_t lock;	/* during all ops except TX pckt processing */ -	spinlock_t tx_lock;	/* during fec_start_xmit and fec_tx         */ -	struct net_device *dev; -	struct napi_struct napi; -	int fecno; -	struct fec *fecp; -	const struct fec_platform_info *fpi; -	int rx_ring, tx_ring; -	dma_addr_t ring_mem_addr; -	void *ring_base; -	struct sk_buff **rx_skbuff; -	struct sk_buff **tx_skbuff; -	cbd_t *rx_bd_base;	/* Address of Rx and Tx buffers.    */ -	cbd_t *tx_bd_base; -	cbd_t *dirty_tx;	/* ring entries to be free()ed.     */ -	cbd_t *cur_rx; -	cbd_t *cur_tx; -	int tx_free; -	struct net_device_stats stats; -	struct timer_list phy_timer_list; -	const struct phy_info *phy; -	unsigned int fec_phy_speed; -	__u32 msg_enable; -	struct mii_if_info mii_if; -}; - -/***************************************************************************/ - -void fec_restart(struct net_device *dev, int duplex, int speed); -void fec_stop(struct net_device *dev); - -/***************************************************************************/ - -int fec_mii_read(struct net_device *dev, int phy_id, int location); -void fec_mii_write(struct net_device *dev, int phy_id, int location, int value); - -int fec_mii_phy_id_detect(struct net_device *dev); -void fec_mii_startup(struct net_device *dev); -void fec_mii_shutdown(struct net_device *dev); -void fec_mii_ack_int(struct net_device *dev); - -void fec_mii_link_status_change_check(struct net_device *dev, int init_media); - -/***************************************************************************/ - -#define FEC1_NO	0x00 -#define FEC2_NO	0x01 -#define FEC3_NO	0x02 - -int fec_8xx_init_one(const struct fec_platform_info *fpi, -		     struct net_device **devp); -int fec_8xx_cleanup_one(struct net_device *dev); - -/***************************************************************************/ - -#define DRV_MODULE_NAME		"fec_8xx" -#define PFX DRV_MODULE_NAME	": " -#define DRV_MODULE_VERSION	"0.1" -#define DRV_MODULE_RELDATE	"May 6, 2004" - -/***************************************************************************/ - -int fec_8xx_platform_init(void); -void fec_8xx_platform_cleanup(void); - -/***************************************************************************/ - -/* FEC access macros */ -#if defined(CONFIG_8xx) -/* for a 8xx __raw_xxx's are sufficient */ -#define __fec_out32(addr, x)	__raw_writel(x, addr) -#define __fec_out16(addr, x)	__raw_writew(x, addr) -#define __fec_in32(addr)	__raw_readl(addr) -#define __fec_in16(addr)	__raw_readw(addr) -#else -/* for others play it safe */ -#define __fec_out32(addr, x)	out_be32(addr, x) -#define __fec_out16(addr, x)	out_be16(addr, x) -#define __fec_in32(addr)	in_be32(addr) -#define __fec_in16(addr)	in_be16(addr) -#endif - -/* write */ -#define FW(_fecp, _reg, _v) __fec_out32(&(_fecp)->fec_ ## _reg, (_v)) - -/* read */ -#define FR(_fecp, _reg)	__fec_in32(&(_fecp)->fec_ ## _reg) - -/* set bits */ -#define FS(_fecp, _reg, _v) FW(_fecp, _reg, FR(_fecp, _reg) | (_v)) - -/* clear bits */ -#define FC(_fecp, _reg, _v) FW(_fecp, _reg, FR(_fecp, _reg) & ~(_v)) - -/* buffer descriptor access macros */ - -/* write */ -#define CBDW_SC(_cbd, _sc) 		__fec_out16(&(_cbd)->cbd_sc, (_sc)) -#define CBDW_DATLEN(_cbd, _datlen)	__fec_out16(&(_cbd)->cbd_datlen, (_datlen)) -#define CBDW_BUFADDR(_cbd, _bufaddr)	__fec_out32(&(_cbd)->cbd_bufaddr, (_bufaddr)) - -/* read */ -#define CBDR_SC(_cbd) 			__fec_in16(&(_cbd)->cbd_sc) -#define CBDR_DATLEN(_cbd)		__fec_in16(&(_cbd)->cbd_datlen) -#define CBDR_BUFADDR(_cbd)		__fec_in32(&(_cbd)->cbd_bufaddr) - -/* set bits */ -#define CBDS_SC(_cbd, _sc) 		CBDW_SC(_cbd, CBDR_SC(_cbd) | (_sc)) - -/* clear bits */ -#define CBDC_SC(_cbd, _sc) 		CBDW_SC(_cbd, CBDR_SC(_cbd) & ~(_sc)) - -/***************************************************************************/ - -#endif diff --git a/drivers/net/fec_8xx/fec_main.c b/drivers/net/fec_8xx/fec_main.c deleted file mode 100644 index ca8d2e83ab0..00000000000 --- a/drivers/net/fec_8xx/fec_main.c +++ /dev/null @@ -1,1264 +0,0 @@ -/* - * Fast Ethernet Controller (FEC) driver for Motorola MPC8xx. - * - * Copyright (c) 2003 Intracom S.A.  - *  by Pantelis Antoniou <panto@intracom.gr> - * - * Heavily based on original FEC driver by Dan Malek <dan@embeddededge.com> - * and modifications by Joakim Tjernlund <joakim.tjernlund@lumentis.se> - * - * Released under the GPL - */ - -#include <linux/module.h> -#include <linux/kernel.h> -#include <linux/types.h> -#include <linux/string.h> -#include <linux/ptrace.h> -#include <linux/errno.h> -#include <linux/ioport.h> -#include <linux/slab.h> -#include <linux/interrupt.h> -#include <linux/init.h> -#include <linux/delay.h> -#include <linux/netdevice.h> -#include <linux/etherdevice.h> -#include <linux/skbuff.h> -#include <linux/spinlock.h> -#include <linux/mii.h> -#include <linux/ethtool.h> -#include <linux/bitops.h> -#include <linux/dma-mapping.h> - -#include <asm/8xx_immap.h> -#include <asm/pgtable.h> -#include <asm/mpc8xx.h> -#include <asm/irq.h> -#include <asm/uaccess.h> -#include <asm/cpm1.h> - -#include "fec_8xx.h" - -/*************************************************/ - -#define FEC_MAX_MULTICAST_ADDRS	64 - -/*************************************************/ - -static char version[] __devinitdata = -    DRV_MODULE_NAME ".c:v" DRV_MODULE_VERSION " (" DRV_MODULE_RELDATE ")" "\n"; - -MODULE_AUTHOR("Pantelis Antoniou <panto@intracom.gr>"); -MODULE_DESCRIPTION("Motorola 8xx FEC ethernet driver"); -MODULE_LICENSE("GPL"); - -int fec_8xx_debug = -1;		/* -1 == use FEC_8XX_DEF_MSG_ENABLE as value */ -module_param(fec_8xx_debug, int, 0); -MODULE_PARM_DESC(fec_8xx_debug, -		 "FEC 8xx bitmapped debugging message enable value"); - - -/*************************************************/ - -/* - * Delay to wait for FEC reset command to complete (in us)  - */ -#define FEC_RESET_DELAY		50 - -/*****************************************************************************************/ - -static void fec_whack_reset(fec_t * fecp) -{ -	int i; - -	/* -	 * Whack a reset.  We should wait for this.   -	 */ -	FW(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_RESET); -	for (i = 0; -	     (FR(fecp, ecntrl) & FEC_ECNTRL_RESET) != 0 && i < FEC_RESET_DELAY; -	     i++) -		udelay(1); - -	if (i == FEC_RESET_DELAY) -		printk(KERN_WARNING "FEC Reset timeout!\n"); - -} - -/****************************************************************************/ - -/* - * Transmitter timeout.   - */ -#define TX_TIMEOUT (2*HZ) - -/****************************************************************************/ - -/* - * Returns the CRC needed when filling in the hash table for - * multicast group filtering - * pAddr must point to a MAC address (6 bytes) - */ -static __u32 fec_mulicast_calc_crc(char *pAddr) -{ -	u8 byte; -	int byte_count; -	int bit_count; -	__u32 crc = 0xffffffff; -	u8 msb; - -	for (byte_count = 0; byte_count < 6; byte_count++) { -		byte = pAddr[byte_count]; -		for (bit_count = 0; bit_count < 8; bit_count++) { -			msb = crc >> 31; -			crc <<= 1; -			if (msb ^ (byte & 0x1)) { -				crc ^= FEC_CRC_POLY; -			} -			byte >>= 1; -		} -	} -	return (crc); -} - -/* - * Set or clear the multicast filter for this adaptor. - * Skeleton taken from sunlance driver. - * The CPM Ethernet implementation allows Multicast as well as individual - * MAC address filtering.  Some of the drivers check to make sure it is - * a group multicast address, and discard those that are not.  I guess I - * will do the same for now, but just remove the test if you want - * individual filtering as well (do the upper net layers want or support - * this kind of feature?). - */ -static void fec_set_multicast_list(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	fec_t *fecp = fep->fecp; -	struct dev_mc_list *pmc; -	__u32 crc; -	int temp; -	__u32 csrVal; -	int hash_index; -	__u32 hthi, htlo; -	unsigned long flags; - - -	if ((dev->flags & IFF_PROMISC) != 0) { - -		spin_lock_irqsave(&fep->lock, flags); -		FS(fecp, r_cntrl, FEC_RCNTRL_PROM); -		spin_unlock_irqrestore(&fep->lock, flags); - -		/* -		 * Log any net taps.  -		 */ -		printk(KERN_WARNING DRV_MODULE_NAME -		       ": %s: Promiscuous mode enabled.\n", dev->name); -		return; - -	} - -	if ((dev->flags & IFF_ALLMULTI) != 0 || -	    dev->mc_count > FEC_MAX_MULTICAST_ADDRS) { -		/* -		 * Catch all multicast addresses, set the filter to all 1's. -		 */ -		hthi = 0xffffffffU; -		htlo = 0xffffffffU; -	} else { -		hthi = 0; -		htlo = 0; - -		/* -		 * Now populate the hash table  -		 */ -		for (pmc = dev->mc_list; pmc != NULL; pmc = pmc->next) { -			crc = fec_mulicast_calc_crc(pmc->dmi_addr); -			temp = (crc & 0x3f) >> 1; -			hash_index = ((temp & 0x01) << 4) | -				     ((temp & 0x02) << 2) | -				     ((temp & 0x04)) | -				     ((temp & 0x08) >> 2) | -				     ((temp & 0x10) >> 4); -			csrVal = (1 << hash_index); -			if (crc & 1) -				hthi |= csrVal; -			else -				htlo |= csrVal; -		} -	} - -	spin_lock_irqsave(&fep->lock, flags); -	FC(fecp, r_cntrl, FEC_RCNTRL_PROM); -	FW(fecp, hash_table_high, hthi); -	FW(fecp, hash_table_low, htlo); -	spin_unlock_irqrestore(&fep->lock, flags); -} - -static int fec_set_mac_address(struct net_device *dev, void *addr) -{ -	struct sockaddr *mac = addr; -	struct fec_enet_private *fep = netdev_priv(dev); -	struct fec *fecp = fep->fecp; -	int i; -	__u32 addrhi, addrlo; -	unsigned long flags; - -	/* Get pointer to SCC area in parameter RAM. */ -	for (i = 0; i < 6; i++) -		dev->dev_addr[i] = mac->sa_data[i]; - -	/* -	 * Set station address.  -	 */ -	addrhi = ((__u32) dev->dev_addr[0] << 24) | -		 ((__u32) dev->dev_addr[1] << 16) | -	   	 ((__u32) dev->dev_addr[2] <<  8) | -	    	  (__u32) dev->dev_addr[3]; -	addrlo = ((__u32) dev->dev_addr[4] << 24) | -	    	 ((__u32) dev->dev_addr[5] << 16); - -	spin_lock_irqsave(&fep->lock, flags); -	FW(fecp, addr_low, addrhi); -	FW(fecp, addr_high, addrlo); -	spin_unlock_irqrestore(&fep->lock, flags); - -	return 0; -} - -/* - * This function is called to start or restart the FEC during a link - * change.  This only happens when switching between half and full - * duplex. - */ -void fec_restart(struct net_device *dev, int duplex, int speed) -{ -#ifdef CONFIG_DUET -	immap_t *immap = (immap_t *) IMAP_ADDR; -	__u32 cptr; -#endif -	struct fec_enet_private *fep = netdev_priv(dev); -	struct fec *fecp = fep->fecp; -	const struct fec_platform_info *fpi = fep->fpi; -	cbd_t *bdp; -	struct sk_buff *skb; -	int i; -	__u32 addrhi, addrlo; - -	fec_whack_reset(fep->fecp); - -	/* -	 * Set station address.  -	 */ -	addrhi = ((__u32) dev->dev_addr[0] << 24) | -		 ((__u32) dev->dev_addr[1] << 16) | -		 ((__u32) dev->dev_addr[2] <<  8) | -		 (__u32) dev->dev_addr[3]; -	addrlo = ((__u32) dev->dev_addr[4] << 24) | -		 ((__u32) dev->dev_addr[5] << 16); -	FW(fecp, addr_low, addrhi); -	FW(fecp, addr_high, addrlo); - -	/* -	 * Reset all multicast.  -	 */ -	FW(fecp, hash_table_high, 0); -	FW(fecp, hash_table_low, 0); - -	/* -	 * Set maximum receive buffer size.  -	 */ -	FW(fecp, r_buff_size, PKT_MAXBLR_SIZE); -	FW(fecp, r_hash, PKT_MAXBUF_SIZE); - -	/* -	 * Set receive and transmit descriptor base.  -	 */ -	FW(fecp, r_des_start, iopa((__u32) (fep->rx_bd_base))); -	FW(fecp, x_des_start, iopa((__u32) (fep->tx_bd_base))); - -	fep->dirty_tx = fep->cur_tx = fep->tx_bd_base; -	fep->tx_free = fep->tx_ring; -	fep->cur_rx = fep->rx_bd_base; - -	/* -	 * Reset SKB receive buffers  -	 */ -	for (i = 0; i < fep->rx_ring; i++) { -		if ((skb = fep->rx_skbuff[i]) == NULL) -			continue; -		fep->rx_skbuff[i] = NULL; -		dev_kfree_skb(skb); -	} - -	/* -	 * Initialize the receive buffer descriptors.  -	 */ -	for (i = 0, bdp = fep->rx_bd_base; i < fep->rx_ring; i++, bdp++) { -		skb = dev_alloc_skb(ENET_RX_FRSIZE); -		if (skb == NULL) { -			printk(KERN_WARNING DRV_MODULE_NAME -			       ": %s Memory squeeze, unable to allocate skb\n", -			       dev->name); -			fep->stats.rx_dropped++; -			break; -		} -		fep->rx_skbuff[i] = skb; -		skb->dev = dev; -		CBDW_BUFADDR(bdp, dma_map_single(NULL, skb->data, -					 L1_CACHE_ALIGN(PKT_MAXBUF_SIZE), -					 DMA_FROM_DEVICE)); -		CBDW_DATLEN(bdp, 0);	/* zero */ -		CBDW_SC(bdp, BD_ENET_RX_EMPTY | -			((i < fep->rx_ring - 1) ? 0 : BD_SC_WRAP)); -	} -	/* -	 * if we failed, fillup remainder  -	 */ -	for (; i < fep->rx_ring; i++, bdp++) { -		fep->rx_skbuff[i] = NULL; -		CBDW_SC(bdp, (i < fep->rx_ring - 1) ? 0 : BD_SC_WRAP); -	} - -	/* -	 * Reset SKB transmit buffers.   -	 */ -	for (i = 0; i < fep->tx_ring; i++) { -		if ((skb = fep->tx_skbuff[i]) == NULL) -			continue; -		fep->tx_skbuff[i] = NULL; -		dev_kfree_skb(skb); -	} - -	/* -	 * ...and the same for transmit.   -	 */ -	for (i = 0, bdp = fep->tx_bd_base; i < fep->tx_ring; i++, bdp++) { -		fep->tx_skbuff[i] = NULL; -		CBDW_BUFADDR(bdp, virt_to_bus(NULL)); -		CBDW_DATLEN(bdp, 0); -		CBDW_SC(bdp, (i < fep->tx_ring - 1) ? 0 : BD_SC_WRAP); -	} - -	/* -	 * Enable big endian and don't care about SDMA FC.  -	 */ -	FW(fecp, fun_code, 0x78000000); - -	/* -	 * Set MII speed.  -	 */ -	FW(fecp, mii_speed, fep->fec_phy_speed); - -	/* -	 * Clear any outstanding interrupt.  -	 */ -	FW(fecp, ievent, 0xffc0); -	FW(fecp, ivec, (fpi->fec_irq / 2) << 29); - -	/* -	 * adjust to speed (only for DUET & RMII)  -	 */ -#ifdef CONFIG_DUET -	cptr = in_be32(&immap->im_cpm.cp_cptr); -	switch (fpi->fec_no) { -	case 0: -		/* -		 * check if in RMII mode  -		 */ -		if ((cptr & 0x100) == 0) -			break; - -		if (speed == 10) -			cptr |= 0x0000010; -		else if (speed == 100) -			cptr &= ~0x0000010; -		break; -	case 1: -		/* -		 * check if in RMII mode  -		 */ -		if ((cptr & 0x80) == 0) -			break; - -		if (speed == 10) -			cptr |= 0x0000008; -		else if (speed == 100) -			cptr &= ~0x0000008; -		break; -	default: -		break; -	} -	out_be32(&immap->im_cpm.cp_cptr, cptr); -#endif - -	FW(fecp, r_cntrl, FEC_RCNTRL_MII_MODE);	/* MII enable */ -	/* -	 * adjust to duplex mode  -	 */ -	if (duplex) { -		FC(fecp, r_cntrl, FEC_RCNTRL_DRT); -		FS(fecp, x_cntrl, FEC_TCNTRL_FDEN);	/* FD enable */ -	} else { -		FS(fecp, r_cntrl, FEC_RCNTRL_DRT); -		FC(fecp, x_cntrl, FEC_TCNTRL_FDEN);	/* FD disable */ -	} - -	/* -	 * Enable interrupts we wish to service.  -	 */ -	FW(fecp, imask, FEC_ENET_TXF | FEC_ENET_TXB | -	   FEC_ENET_RXF | FEC_ENET_RXB); - -	/* -	 * And last, enable the transmit and receive processing.  -	 */ -	FW(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_ETHER_EN); -	FW(fecp, r_des_active, 0x01000000); -} - -void fec_stop(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	fec_t *fecp = fep->fecp; -	struct sk_buff *skb; -	int i; - -	if ((FR(fecp, ecntrl) & FEC_ECNTRL_ETHER_EN) == 0) -		return;		/* already down */ - -	FW(fecp, x_cntrl, 0x01);	/* Graceful transmit stop */ -	for (i = 0; ((FR(fecp, ievent) & 0x10000000) == 0) && -	     i < FEC_RESET_DELAY; i++) -		udelay(1); - -	if (i == FEC_RESET_DELAY) -		printk(KERN_WARNING DRV_MODULE_NAME -		       ": %s FEC timeout on graceful transmit stop\n", -		       dev->name); -	/* -	 * Disable FEC. Let only MII interrupts.  -	 */ -	FW(fecp, imask, 0); -	FW(fecp, ecntrl, ~FEC_ECNTRL_ETHER_EN); - -	/* -	 * Reset SKB transmit buffers.   -	 */ -	for (i = 0; i < fep->tx_ring; i++) { -		if ((skb = fep->tx_skbuff[i]) == NULL) -			continue; -		fep->tx_skbuff[i] = NULL; -		dev_kfree_skb(skb); -	} - -	/* -	 * Reset SKB receive buffers  -	 */ -	for (i = 0; i < fep->rx_ring; i++) { -		if ((skb = fep->rx_skbuff[i]) == NULL) -			continue; -		fep->rx_skbuff[i] = NULL; -		dev_kfree_skb(skb); -	} -} - -/* common receive function */ -static int fec_enet_rx_common(struct fec_enet_private *ep, -			      struct net_device *dev, int budget) -{ -	fec_t *fecp = fep->fecp; -	const struct fec_platform_info *fpi = fep->fpi; -	cbd_t *bdp; -	struct sk_buff *skb, *skbn, *skbt; -	int received = 0; -	__u16 pkt_len, sc; -	int curidx; - -	/* -	 * First, grab all of the stats for the incoming packet. -	 * These get messed up if we get called due to a busy condition. -	 */ -	bdp = fep->cur_rx; - -	/* clear RX status bits for napi*/ -	if (fpi->use_napi) -		FW(fecp, ievent, FEC_ENET_RXF | FEC_ENET_RXB); - -	while (((sc = CBDR_SC(bdp)) & BD_ENET_RX_EMPTY) == 0) { - -		curidx = bdp - fep->rx_bd_base; - -		/* -		 * Since we have allocated space to hold a complete frame, -		 * the last indicator should be set. -		 */ -		if ((sc & BD_ENET_RX_LAST) == 0) -			printk(KERN_WARNING DRV_MODULE_NAME -			       ": %s rcv is not +last\n", -			       dev->name); - -		/* -		 * Check for errors.  -		 */ -		if (sc & (BD_ENET_RX_LG | BD_ENET_RX_SH | BD_ENET_RX_CL | -			  BD_ENET_RX_NO | BD_ENET_RX_CR | BD_ENET_RX_OV)) { -			fep->stats.rx_errors++; -			/* Frame too long or too short. */ -			if (sc & (BD_ENET_RX_LG | BD_ENET_RX_SH)) -				fep->stats.rx_length_errors++; -			/* Frame alignment */ -			if (sc & (BD_ENET_RX_NO | BD_ENET_RX_CL)) -				fep->stats.rx_frame_errors++; -			/* CRC Error */ -			if (sc & BD_ENET_RX_CR) -				fep->stats.rx_crc_errors++; -			/* FIFO overrun */ -			if (sc & BD_ENET_RX_OV) -				fep->stats.rx_crc_errors++; - -			skbn = fep->rx_skbuff[curidx]; -			BUG_ON(skbn == NULL); - -		} else { -			skb = fep->rx_skbuff[curidx]; -			BUG_ON(skb == NULL); - -			/* -			 * Process the incoming frame. -			 */ -			fep->stats.rx_packets++; -			pkt_len = CBDR_DATLEN(bdp) - 4;	/* remove CRC */ -			fep->stats.rx_bytes += pkt_len + 4; - -			if (pkt_len <= fpi->rx_copybreak) { -				/* +2 to make IP header L1 cache aligned */ -				skbn = dev_alloc_skb(pkt_len + 2); -				if (skbn != NULL) { -					skb_reserve(skbn, 2);	/* align IP header */ -					skb_copy_from_linear_data(skb, -								  skbn->data, -								  pkt_len); -					/* swap */ -					skbt = skb; -					skb = skbn; -					skbn = skbt; -				} -			} else -				skbn = dev_alloc_skb(ENET_RX_FRSIZE); - -			if (skbn != NULL) { -				skb_put(skb, pkt_len);	/* Make room */ -				skb->protocol = eth_type_trans(skb, dev); -				received++; -				if (!fpi->use_napi) -					netif_rx(skb); -				else -					netif_receive_skb(skb); -			} else { -				printk(KERN_WARNING DRV_MODULE_NAME -				       ": %s Memory squeeze, dropping packet.\n", -				       dev->name); -				fep->stats.rx_dropped++; -				skbn = skb; -			} -		} - -		fep->rx_skbuff[curidx] = skbn; -		CBDW_BUFADDR(bdp, dma_map_single(NULL, skbn->data, -						 L1_CACHE_ALIGN(PKT_MAXBUF_SIZE), -						 DMA_FROM_DEVICE)); -		CBDW_DATLEN(bdp, 0); -		CBDW_SC(bdp, (sc & ~BD_ENET_RX_STATS) | BD_ENET_RX_EMPTY); - -		/* -		 * Update BD pointer to next entry.  -		 */ -		if ((sc & BD_ENET_RX_WRAP) == 0) -			bdp++; -		else -			bdp = fep->rx_bd_base; - -		/* -		 * Doing this here will keep the FEC running while we process -		 * incoming frames.  On a heavily loaded network, we should be -		 * able to keep up at the expense of system resources. -		 */ -		FW(fecp, r_des_active, 0x01000000); - -		if (received >= budget) -			break; - -	} - -	fep->cur_rx = bdp; - -	if (fpi->use_napi) { -		if (received < budget) { -			netif_rx_complete(dev, &fep->napi); - -			/* enable RX interrupt bits */ -			FS(fecp, imask, FEC_ENET_RXF | FEC_ENET_RXB); -		} -	} - -	return received; -} - -static void fec_enet_tx(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	cbd_t *bdp; -	struct sk_buff *skb; -	int dirtyidx, do_wake; -	__u16 sc; - -	spin_lock(&fep->lock); -	bdp = fep->dirty_tx; - -	do_wake = 0; -	while (((sc = CBDR_SC(bdp)) & BD_ENET_TX_READY) == 0) { - -		dirtyidx = bdp - fep->tx_bd_base; - -		if (fep->tx_free == fep->tx_ring) -			break; - -		skb = fep->tx_skbuff[dirtyidx]; - -		/* -		 * Check for errors.  -		 */ -		if (sc & (BD_ENET_TX_HB | BD_ENET_TX_LC | -			  BD_ENET_TX_RL | BD_ENET_TX_UN | BD_ENET_TX_CSL)) { -			fep->stats.tx_errors++; -			if (sc & BD_ENET_TX_HB)	/* No heartbeat */ -				fep->stats.tx_heartbeat_errors++; -			if (sc & BD_ENET_TX_LC)	/* Late collision */ -				fep->stats.tx_window_errors++; -			if (sc & BD_ENET_TX_RL)	/* Retrans limit */ -				fep->stats.tx_aborted_errors++; -			if (sc & BD_ENET_TX_UN)	/* Underrun */ -				fep->stats.tx_fifo_errors++; -			if (sc & BD_ENET_TX_CSL)	/* Carrier lost */ -				fep->stats.tx_carrier_errors++; -		} else -			fep->stats.tx_packets++; - -		if (sc & BD_ENET_TX_READY) -			printk(KERN_WARNING DRV_MODULE_NAME -			       ": %s HEY! Enet xmit interrupt and TX_READY.\n", -			       dev->name); - -		/* -		 * Deferred means some collisions occurred during transmit, -		 * but we eventually sent the packet OK. -		 */ -		if (sc & BD_ENET_TX_DEF) -			fep->stats.collisions++; - -		/* -		 * Free the sk buffer associated with this last transmit.  -		 */ -		dev_kfree_skb_irq(skb); -		fep->tx_skbuff[dirtyidx] = NULL; - -		/* -		 * Update pointer to next buffer descriptor to be transmitted.  -		 */ -		if ((sc & BD_ENET_TX_WRAP) == 0) -			bdp++; -		else -			bdp = fep->tx_bd_base; - -		/* -		 * Since we have freed up a buffer, the ring is no longer -		 * full. -		 */ -		if (!fep->tx_free++) -			do_wake = 1; -	} - -	fep->dirty_tx = bdp; - -	spin_unlock(&fep->lock); - -	if (do_wake && netif_queue_stopped(dev)) -		netif_wake_queue(dev); -} - -/* - * The interrupt handler. - * This is called from the MPC core interrupt. - */ -static irqreturn_t -fec_enet_interrupt(int irq, void *dev_id) -{ -	struct net_device *dev = dev_id; -	struct fec_enet_private *fep; -	const struct fec_platform_info *fpi; -	fec_t *fecp; -	__u32 int_events; -	__u32 int_events_napi; - -	if (unlikely(dev == NULL)) -		return IRQ_NONE; - -	fep = netdev_priv(dev); -	fecp = fep->fecp; -	fpi = fep->fpi; - -	/* -	 * Get the interrupt events that caused us to be here. -	 */ -	while ((int_events = FR(fecp, ievent) & FR(fecp, imask)) != 0) { - -		if (!fpi->use_napi) -			FW(fecp, ievent, int_events); -		else { -			int_events_napi = int_events & ~(FEC_ENET_RXF | FEC_ENET_RXB); -			FW(fecp, ievent, int_events_napi); -		} - -		if ((int_events & (FEC_ENET_HBERR | FEC_ENET_BABR | -				   FEC_ENET_BABT | FEC_ENET_EBERR)) != 0) -			printk(KERN_WARNING DRV_MODULE_NAME -			       ": %s FEC ERROR(s) 0x%x\n", -			       dev->name, int_events); - -		if ((int_events & FEC_ENET_RXF) != 0) { -			if (!fpi->use_napi) -				fec_enet_rx_common(fep, dev, ~0); -			else { -				if (netif_rx_schedule_prep(dev, &fep->napi)) { -					/* disable rx interrupts */ -					FC(fecp, imask, FEC_ENET_RXF | FEC_ENET_RXB); -					__netif_rx_schedule(dev, &fep->napi); -				} else { -					printk(KERN_ERR DRV_MODULE_NAME -					       ": %s driver bug! interrupt while in poll!\n", -					       dev->name); -					FC(fecp, imask, FEC_ENET_RXF | FEC_ENET_RXB); -				} -			} -		} - -		if ((int_events & FEC_ENET_TXF) != 0) -			fec_enet_tx(dev); -	} - -	return IRQ_HANDLED; -} - -/* This interrupt occurs when the PHY detects a link change. */ -static irqreturn_t -fec_mii_link_interrupt(int irq, void *dev_id) -{ -	struct net_device *dev = dev_id; -	struct fec_enet_private *fep; -	const struct fec_platform_info *fpi; - -	if (unlikely(dev == NULL)) -		return IRQ_NONE; - -	fep = netdev_priv(dev); -	fpi = fep->fpi; - -	if (!fpi->use_mdio) -		return IRQ_NONE; - -	/* -	 * Acknowledge the interrupt if possible. If we have not -	 * found the PHY yet we can't process or acknowledge the -	 * interrupt now. Instead we ignore this interrupt for now, -	 * which we can do since it is edge triggered. It will be -	 * acknowledged later by fec_enet_open(). -	 */ -	if (!fep->phy) -		return IRQ_NONE; - -	fec_mii_ack_int(dev); -	fec_mii_link_status_change_check(dev, 0); - -	return IRQ_HANDLED; -} - - -/**********************************************************************************/ - -static int fec_enet_start_xmit(struct sk_buff *skb, struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	fec_t *fecp = fep->fecp; -	cbd_t *bdp; -	int curidx; -	unsigned long flags; - -	spin_lock_irqsave(&fep->tx_lock, flags); - -	/* -	 * Fill in a Tx ring entry  -	 */ -	bdp = fep->cur_tx; - -	if (!fep->tx_free || (CBDR_SC(bdp) & BD_ENET_TX_READY)) { -		netif_stop_queue(dev); -		spin_unlock_irqrestore(&fep->tx_lock, flags); - -		/* -		 * Ooops.  All transmit buffers are full.  Bail out. -		 * This should not happen, since the tx queue should be stopped. -		 */ -		printk(KERN_WARNING DRV_MODULE_NAME -		       ": %s tx queue full!.\n", dev->name); -		return 1; -	} - -	curidx = bdp - fep->tx_bd_base; -	/* -	 * Clear all of the status flags.  -	 */ -	CBDC_SC(bdp, BD_ENET_TX_STATS); - -	/* -	 * Save skb pointer.  -	 */ -	fep->tx_skbuff[curidx] = skb; - -	fep->stats.tx_bytes += skb->len; - -	/* -	 * Push the data cache so the CPM does not get stale memory data.  -	 */ -	CBDW_BUFADDR(bdp, dma_map_single(NULL, skb->data, -					 skb->len, DMA_TO_DEVICE)); -	CBDW_DATLEN(bdp, skb->len); - -	dev->trans_start = jiffies; - -	/* -	 * If this was the last BD in the ring, start at the beginning again.  -	 */ -	if ((CBDR_SC(bdp) & BD_ENET_TX_WRAP) == 0) -		fep->cur_tx++; -	else -		fep->cur_tx = fep->tx_bd_base; - -	if (!--fep->tx_free) -		netif_stop_queue(dev); - -	/* -	 * Trigger transmission start  -	 */ -	CBDS_SC(bdp, BD_ENET_TX_READY | BD_ENET_TX_INTR | -		BD_ENET_TX_LAST | BD_ENET_TX_TC); -	FW(fecp, x_des_active, 0x01000000); - -	spin_unlock_irqrestore(&fep->tx_lock, flags); - -	return 0; -} - -static void fec_timeout(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); - -	fep->stats.tx_errors++; - -	if (fep->tx_free) -		netif_wake_queue(dev); - -	/* check link status again */ -	fec_mii_link_status_change_check(dev, 0); -} - -static int fec_enet_open(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	const struct fec_platform_info *fpi = fep->fpi; -	unsigned long flags; - -	napi_enable(&fep->napi); - -	/* Install our interrupt handler. */ -	if (request_irq(fpi->fec_irq, fec_enet_interrupt, 0, "fec", dev) != 0) { -		printk(KERN_ERR DRV_MODULE_NAME -		       ": %s Could not allocate FEC IRQ!", dev->name); -		napi_disable(&fep->napi); -		return -EINVAL; -	} - -	/* Install our phy interrupt handler */ -	if (fpi->phy_irq != -1 &&  -		request_irq(fpi->phy_irq, fec_mii_link_interrupt, 0, "fec-phy", -				dev) != 0) { -		printk(KERN_ERR DRV_MODULE_NAME -		       ": %s Could not allocate PHY IRQ!", dev->name); -		free_irq(fpi->fec_irq, dev); -		napi_disable(&fep->napi); -		return -EINVAL; -	} - -	if (fpi->use_mdio) { -		fec_mii_startup(dev); -		netif_carrier_off(dev); -		fec_mii_link_status_change_check(dev, 1); -	} else { -		spin_lock_irqsave(&fep->lock, flags); -		fec_restart(dev, 1, 100);	/* XXX this sucks */ -		spin_unlock_irqrestore(&fep->lock, flags); - -		netif_carrier_on(dev); -		netif_start_queue(dev); -	} -	return 0; -} - -static int fec_enet_close(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	const struct fec_platform_info *fpi = fep->fpi; -	unsigned long flags; - -	netif_stop_queue(dev); -	napi_disable(&fep->napi); -	netif_carrier_off(dev); - -	if (fpi->use_mdio) -		fec_mii_shutdown(dev); - -	spin_lock_irqsave(&fep->lock, flags); -	fec_stop(dev); -	spin_unlock_irqrestore(&fep->lock, flags); - -	/* release any irqs */ -	if (fpi->phy_irq != -1) -		free_irq(fpi->phy_irq, dev); -	free_irq(fpi->fec_irq, dev); - -	return 0; -} - -static struct net_device_stats *fec_enet_get_stats(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	return &fep->stats; -} - -static int fec_enet_poll(struct napi_struct *napi, int budget) -{ -	struct fec_enet_private *fep = container_of(napi, struct fec_enet_private, napi); -	struct net_device *dev = fep->dev; - -	return fec_enet_rx_common(fep, dev, budget); -} - -/*************************************************************************/ - -static void fec_get_drvinfo(struct net_device *dev, -			    struct ethtool_drvinfo *info) -{ -	strcpy(info->driver, DRV_MODULE_NAME); -	strcpy(info->version, DRV_MODULE_VERSION); -} - -static int fec_get_regs_len(struct net_device *dev) -{ -	return sizeof(fec_t); -} - -static void fec_get_regs(struct net_device *dev, struct ethtool_regs *regs, -			 void *p) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	unsigned long flags; - -	if (regs->len < sizeof(fec_t)) -		return; - -	regs->version = 0; -	spin_lock_irqsave(&fep->lock, flags); -	memcpy_fromio(p, fep->fecp, sizeof(fec_t)); -	spin_unlock_irqrestore(&fep->lock, flags); -} - -static int fec_get_settings(struct net_device *dev, struct ethtool_cmd *cmd) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	unsigned long flags; -	int rc; - -	spin_lock_irqsave(&fep->lock, flags); -	rc = mii_ethtool_gset(&fep->mii_if, cmd); -	spin_unlock_irqrestore(&fep->lock, flags); - -	return rc; -} - -static int fec_set_settings(struct net_device *dev, struct ethtool_cmd *cmd) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	unsigned long flags; -	int rc; - -	spin_lock_irqsave(&fep->lock, flags); -	rc = mii_ethtool_sset(&fep->mii_if, cmd); -	spin_unlock_irqrestore(&fep->lock, flags); - -	return rc; -} - -static int fec_nway_reset(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	return mii_nway_restart(&fep->mii_if); -} - -static __u32 fec_get_msglevel(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	return fep->msg_enable; -} - -static void fec_set_msglevel(struct net_device *dev, __u32 value) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	fep->msg_enable = value; -} - -static const struct ethtool_ops fec_ethtool_ops = { -	.get_drvinfo	= fec_get_drvinfo, -	.get_regs_len	= fec_get_regs_len, -	.get_settings	= fec_get_settings, -	.set_settings	= fec_set_settings, -	.nway_reset	= fec_nway_reset, -	.get_link	= ethtool_op_get_link, -	.get_msglevel	= fec_get_msglevel, -	.set_msglevel	= fec_set_msglevel, -	.set_tx_csum	= ethtool_op_set_tx_csum,	/* local! */ -	.set_sg		= ethtool_op_set_sg, -	.get_regs	= fec_get_regs, -}; - -static int fec_ioctl(struct net_device *dev, struct ifreq *rq, int cmd) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	struct mii_ioctl_data *mii = (struct mii_ioctl_data *)&rq->ifr_data; -	unsigned long flags; -	int rc; - -	if (!netif_running(dev)) -		return -EINVAL; - -	spin_lock_irqsave(&fep->lock, flags); -	rc = generic_mii_ioctl(&fep->mii_if, mii, cmd, NULL); -	spin_unlock_irqrestore(&fep->lock, flags); -	return rc; -} - -int fec_8xx_init_one(const struct fec_platform_info *fpi, -		     struct net_device **devp) -{ -	immap_t *immap = (immap_t *) IMAP_ADDR; -	static int fec_8xx_version_printed = 0; -	struct net_device *dev = NULL; -	struct fec_enet_private *fep = NULL; -	fec_t *fecp = NULL; -	int i; -	int err = 0; -	int registered = 0; -	__u32 siel; - -	*devp = NULL; - -	switch (fpi->fec_no) { -	case 0: -		fecp = &((immap_t *) IMAP_ADDR)->im_cpm.cp_fec; -		break; -#ifdef CONFIG_DUET -	case 1: -		fecp = &((immap_t *) IMAP_ADDR)->im_cpm.cp_fec2; -		break; -#endif -	default: -		return -EINVAL; -	} - -	if (fec_8xx_version_printed++ == 0) -		printk(KERN_INFO "%s", version); - -	i = sizeof(*fep) + (sizeof(struct sk_buff **) * -			    (fpi->rx_ring + fpi->tx_ring)); - -	dev = alloc_etherdev(i); -	if (!dev) { -		err = -ENOMEM; -		goto err; -	} - -	fep = netdev_priv(dev); -	fep->dev = dev; - -	/* partial reset of FEC */ -	fec_whack_reset(fecp); - -	/* point rx_skbuff, tx_skbuff */ -	fep->rx_skbuff = (struct sk_buff **)&fep[1]; -	fep->tx_skbuff = fep->rx_skbuff + fpi->rx_ring; - -	fep->fecp = fecp; -	fep->fpi = fpi; - -	/* init locks */ -	spin_lock_init(&fep->lock); -	spin_lock_init(&fep->tx_lock); - -	/* -	 * Set the Ethernet address.  -	 */ -	for (i = 0; i < 6; i++) -		dev->dev_addr[i] = fpi->macaddr[i]; - -	fep->ring_base = dma_alloc_coherent(NULL, -					    (fpi->tx_ring + fpi->rx_ring) * -					    sizeof(cbd_t), &fep->ring_mem_addr, -					    GFP_KERNEL); -	if (fep->ring_base == NULL) { -		printk(KERN_ERR DRV_MODULE_NAME -		       ": %s dma alloc failed.\n", dev->name); -		err = -ENOMEM; -		goto err; -	} - -	/* -	 * Set receive and transmit descriptor base. -	 */ -	fep->rx_bd_base = fep->ring_base; -	fep->tx_bd_base = fep->rx_bd_base + fpi->rx_ring; - -	/* initialize ring size variables */ -	fep->tx_ring = fpi->tx_ring; -	fep->rx_ring = fpi->rx_ring; - -	/* SIU interrupt */ -	if (fpi->phy_irq != -1 && -		(fpi->phy_irq >= SIU_IRQ0 && fpi->phy_irq < SIU_LEVEL7)) { - -		siel = in_be32(&immap->im_siu_conf.sc_siel); -		if ((fpi->phy_irq & 1) == 0) -			siel |= (0x80000000 >> fpi->phy_irq); -		else -			siel &= ~(0x80000000 >> (fpi->phy_irq & ~1)); -		out_be32(&immap->im_siu_conf.sc_siel, siel); -	} - -	/* -	 * The FEC Ethernet specific entries in the device structure.  -	 */ -	dev->open = fec_enet_open; -	dev->hard_start_xmit = fec_enet_start_xmit; -	dev->tx_timeout = fec_timeout; -	dev->watchdog_timeo = TX_TIMEOUT; -	dev->stop = fec_enet_close; -	dev->get_stats = fec_enet_get_stats; -	dev->set_multicast_list = fec_set_multicast_list; -	dev->set_mac_address = fec_set_mac_address; -	netif_napi_add(dev, &fec->napi, -		       fec_enet_poll, fpi->napi_weight); - -	dev->ethtool_ops = &fec_ethtool_ops; -	dev->do_ioctl = fec_ioctl; - -	fep->fec_phy_speed = -	    ((((fpi->sys_clk + 4999999) / 2500000) / 2) & 0x3F) << 1; - -	init_timer(&fep->phy_timer_list); - -	/* partial reset of FEC so that only MII works */ -	FW(fecp, mii_speed, fep->fec_phy_speed); -	FW(fecp, ievent, 0xffc0); -	FW(fecp, ivec, (fpi->fec_irq / 2) << 29); -	FW(fecp, imask, 0); -	FW(fecp, r_cntrl, FEC_RCNTRL_MII_MODE);	/* MII enable */ -	FW(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_ETHER_EN); - -	netif_carrier_off(dev); - -	err = register_netdev(dev); -	if (err != 0) -		goto err; -	registered = 1; - -	if (fpi->use_mdio) { -		fep->mii_if.dev = dev; -		fep->mii_if.mdio_read = fec_mii_read; -		fep->mii_if.mdio_write = fec_mii_write; -		fep->mii_if.phy_id_mask = 0x1f; -		fep->mii_if.reg_num_mask = 0x1f; -		fep->mii_if.phy_id = fec_mii_phy_id_detect(dev); -	} - -	*devp = dev; - -	return 0; - -      err: -	if (dev != NULL) { -		if (fecp != NULL) -			fec_whack_reset(fecp); - -		if (registered) -			unregister_netdev(dev); - -		if (fep != NULL) { -			if (fep->ring_base) -				dma_free_coherent(NULL, -						  (fpi->tx_ring + -						   fpi->rx_ring) * -						  sizeof(cbd_t), fep->ring_base, -						  fep->ring_mem_addr); -		} -		free_netdev(dev); -	} -	return err; -} - -int fec_8xx_cleanup_one(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	fec_t *fecp = fep->fecp; -	const struct fec_platform_info *fpi = fep->fpi; - -	fec_whack_reset(fecp); - -	unregister_netdev(dev); - -	dma_free_coherent(NULL, (fpi->tx_ring + fpi->rx_ring) * sizeof(cbd_t), -			  fep->ring_base, fep->ring_mem_addr); - -	free_netdev(dev); - -	return 0; -} - -/**************************************************************************************/ -/**************************************************************************************/ -/**************************************************************************************/ - -static int __init fec_8xx_init(void) -{ -	return fec_8xx_platform_init(); -} - -static void __exit fec_8xx_cleanup(void) -{ -	fec_8xx_platform_cleanup(); -} - -/**************************************************************************************/ -/**************************************************************************************/ -/**************************************************************************************/ - -module_init(fec_8xx_init); -module_exit(fec_8xx_cleanup); diff --git a/drivers/net/fec_8xx/fec_mii.c b/drivers/net/fec_8xx/fec_mii.c deleted file mode 100644 index 3b6ca29d31f..00000000000 --- a/drivers/net/fec_8xx/fec_mii.c +++ /dev/null @@ -1,418 +0,0 @@ -/* - * Fast Ethernet Controller (FEC) driver for Motorola MPC8xx. - * - * Copyright (c) 2003 Intracom S.A.  - *  by Pantelis Antoniou <panto@intracom.gr> - * - * Heavily based on original FEC driver by Dan Malek <dan@embeddededge.com> - * and modifications by Joakim Tjernlund <joakim.tjernlund@lumentis.se> - * - * Released under the GPL - */ - -#include <linux/module.h> -#include <linux/types.h> -#include <linux/kernel.h> -#include <linux/string.h> -#include <linux/ptrace.h> -#include <linux/errno.h> -#include <linux/ioport.h> -#include <linux/slab.h> -#include <linux/interrupt.h> -#include <linux/init.h> -#include <linux/delay.h> -#include <linux/netdevice.h> -#include <linux/etherdevice.h> -#include <linux/skbuff.h> -#include <linux/spinlock.h> -#include <linux/mii.h> -#include <linux/ethtool.h> -#include <linux/bitops.h> - -#include <asm/8xx_immap.h> -#include <asm/pgtable.h> -#include <asm/mpc8xx.h> -#include <asm/irq.h> -#include <asm/uaccess.h> -#include <asm/cpm1.h> - -/*************************************************/ - -#include "fec_8xx.h" - -/*************************************************/ - -/* Make MII read/write commands for the FEC. -*/ -#define mk_mii_read(REG)	(0x60020000 | ((REG & 0x1f) << 18)) -#define mk_mii_write(REG, VAL)	(0x50020000 | ((REG & 0x1f) << 18) | (VAL & 0xffff)) -#define mk_mii_end		0 - -/*************************************************/ - -/* XXX both FECs use the MII interface of FEC1 */ -static DEFINE_SPINLOCK(fec_mii_lock); - -#define FEC_MII_LOOPS	10000 - -int fec_mii_read(struct net_device *dev, int phy_id, int location) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	fec_t *fecp; -	int i, ret = -1; -	unsigned long flags; - -	/* XXX MII interface is only connected to FEC1 */ -	fecp = &((immap_t *) IMAP_ADDR)->im_cpm.cp_fec; - -	spin_lock_irqsave(&fec_mii_lock, flags); - -	if ((FR(fecp, r_cntrl) & FEC_RCNTRL_MII_MODE) == 0) { -		FS(fecp, r_cntrl, FEC_RCNTRL_MII_MODE);	/* MII enable */ -		FS(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_ETHER_EN); -		FW(fecp, ievent, FEC_ENET_MII); -	} - -	/* Add PHY address to register command.  */ -	FW(fecp, mii_speed, fep->fec_phy_speed); -	FW(fecp, mii_data, (phy_id << 23) | mk_mii_read(location)); - -	for (i = 0; i < FEC_MII_LOOPS; i++) -		if ((FR(fecp, ievent) & FEC_ENET_MII) != 0) -			break; - -	if (i < FEC_MII_LOOPS) { -		FW(fecp, ievent, FEC_ENET_MII); -		ret = FR(fecp, mii_data) & 0xffff; -	} - -	spin_unlock_irqrestore(&fec_mii_lock, flags); - -	return ret; -} - -void fec_mii_write(struct net_device *dev, int phy_id, int location, int value) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	fec_t *fecp; -	unsigned long flags; -	int i; - -	/* XXX MII interface is only connected to FEC1 */ -	fecp = &((immap_t *) IMAP_ADDR)->im_cpm.cp_fec; - -	spin_lock_irqsave(&fec_mii_lock, flags); - -	if ((FR(fecp, r_cntrl) & FEC_RCNTRL_MII_MODE) == 0) { -		FS(fecp, r_cntrl, FEC_RCNTRL_MII_MODE);	/* MII enable */ -		FS(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_ETHER_EN); -		FW(fecp, ievent, FEC_ENET_MII); -	} - -	/* Add PHY address to register command.  */ -	FW(fecp, mii_speed, fep->fec_phy_speed);	/* always adapt mii speed */ -	FW(fecp, mii_data, (phy_id << 23) | mk_mii_write(location, value)); - -	for (i = 0; i < FEC_MII_LOOPS; i++) -		if ((FR(fecp, ievent) & FEC_ENET_MII) != 0) -			break; - -	if (i < FEC_MII_LOOPS) -		FW(fecp, ievent, FEC_ENET_MII); - -	spin_unlock_irqrestore(&fec_mii_lock, flags); -} - -/*************************************************/ - -#ifdef CONFIG_FEC_8XX_GENERIC_PHY - -/* - * Generic PHY support. - * Should work for all PHYs, but link change is detected by polling - */ - -static void generic_timer_callback(unsigned long data) -{ -	struct net_device *dev = (struct net_device *)data; -	struct fec_enet_private *fep = netdev_priv(dev); - -	fep->phy_timer_list.expires = jiffies + HZ / 2; - -	add_timer(&fep->phy_timer_list); - -	fec_mii_link_status_change_check(dev, 0); -} - -static void generic_startup(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); - -	fep->phy_timer_list.expires = jiffies + HZ / 2;	/* every 500ms */ -	fep->phy_timer_list.data = (unsigned long)dev; -	fep->phy_timer_list.function = generic_timer_callback; -	add_timer(&fep->phy_timer_list); -} - -static void generic_shutdown(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); - -	del_timer_sync(&fep->phy_timer_list); -} - -#endif - -#ifdef CONFIG_FEC_8XX_DM9161_PHY - -/* ------------------------------------------------------------------------- */ -/* The Davicom DM9161 is used on the NETTA board			     */ - -/* register definitions */ - -#define MII_DM9161_ACR		16	/* Aux. Config Register         */ -#define MII_DM9161_ACSR		17	/* Aux. Config/Status Register  */ -#define MII_DM9161_10TCSR	18	/* 10BaseT Config/Status Reg.   */ -#define MII_DM9161_INTR		21	/* Interrupt Register           */ -#define MII_DM9161_RECR		22	/* Receive Error Counter Reg.   */ -#define MII_DM9161_DISCR	23	/* Disconnect Counter Register  */ - -static void dm9161_startup(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); - -	fec_mii_write(dev, fep->mii_if.phy_id, MII_DM9161_INTR, 0x0000); -} - -static void dm9161_ack_int(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); - -	fec_mii_read(dev, fep->mii_if.phy_id, MII_DM9161_INTR); -} - -static void dm9161_shutdown(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); - -	fec_mii_write(dev, fep->mii_if.phy_id, MII_DM9161_INTR, 0x0f00); -} - -#endif - -#ifdef CONFIG_FEC_8XX_LXT971_PHY - -/* Support for LXT971/972 PHY */ - -#define MII_LXT971_PCR		16 /* Port Control Register */ -#define MII_LXT971_SR2		17 /* Status Register 2 */ -#define MII_LXT971_IER		18 /* Interrupt Enable Register */ -#define MII_LXT971_ISR		19 /* Interrupt Status Register */ -#define MII_LXT971_LCR		20 /* LED Control Register */ -#define MII_LXT971_TCR		30 /* Transmit Control Register */ - -static void lxt971_startup(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); - -	fec_mii_write(dev, fep->mii_if.phy_id, MII_LXT971_IER, 0x00F2); -} - -static void lxt971_ack_int(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); - -	fec_mii_read(dev, fep->mii_if.phy_id, MII_LXT971_ISR); -} - -static void lxt971_shutdown(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); - -	fec_mii_write(dev, fep->mii_if.phy_id, MII_LXT971_IER, 0x0000); -} -#endif - -/**********************************************************************************/ - -static const struct phy_info phy_info[] = { -#ifdef CONFIG_FEC_8XX_DM9161_PHY -	{ -	 .id = 0x00181b88, -	 .name = "DM9161", -	 .startup = dm9161_startup, -	 .ack_int = dm9161_ack_int, -	 .shutdown = dm9161_shutdown, -	 }, -#endif -#ifdef CONFIG_FEC_8XX_LXT971_PHY -	{ -	 .id = 0x0001378e, -	 .name = "LXT971/972", -	 .startup = lxt971_startup, -	 .ack_int = lxt971_ack_int, -	 .shutdown = lxt971_shutdown, -	}, -#endif -#ifdef CONFIG_FEC_8XX_GENERIC_PHY -	{ -	 .id = 0, -	 .name = "GENERIC", -	 .startup = generic_startup, -	 .shutdown = generic_shutdown, -	 }, -#endif -}; - -/**********************************************************************************/ - -int fec_mii_phy_id_detect(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	const struct fec_platform_info *fpi = fep->fpi; -	int i, r, start, end, phytype, physubtype; -	const struct phy_info *phy; -	int phy_hwid, phy_id; - -	/* if no MDIO */ -	if (fpi->use_mdio == 0) -		return -1; - -	phy_hwid = -1; -	fep->phy = NULL; - -	/* auto-detect? */ -	if (fpi->phy_addr == -1) { -		start = 0; -		end = 32; -	} else {		/* direct */ -		start = fpi->phy_addr; -		end = start + 1; -	} - -	for (phy_id = start; phy_id < end; phy_id++) { -		r = fec_mii_read(dev, phy_id, MII_PHYSID1); -		if (r == -1 || (phytype = (r & 0xffff)) == 0xffff) -			continue; -		r = fec_mii_read(dev, phy_id, MII_PHYSID2); -		if (r == -1 || (physubtype = (r & 0xffff)) == 0xffff) -			continue; -		phy_hwid = (phytype << 16) | physubtype; -		if (phy_hwid != -1) -			break; -	} - -	if (phy_hwid == -1) { -		printk(KERN_ERR DRV_MODULE_NAME -		       ": %s No PHY detected!\n", dev->name); -		return -1; -	} - -	for (i = 0, phy = phy_info; i < ARRAY_SIZE(phy_info); i++, phy++) -		if (phy->id == (phy_hwid >> 4) || phy->id == 0) -			break; - -	if (i >= ARRAY_SIZE(phy_info)) { -		printk(KERN_ERR DRV_MODULE_NAME -		       ": %s PHY id 0x%08x is not supported!\n", -		       dev->name, phy_hwid); -		return -1; -	} - -	fep->phy = phy; - -	printk(KERN_INFO DRV_MODULE_NAME -	       ": %s Phy @ 0x%x, type %s (0x%08x)\n", -	       dev->name, phy_id, fep->phy->name, phy_hwid); - -	return phy_id; -} - -void fec_mii_startup(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	const struct fec_platform_info *fpi = fep->fpi; - -	if (!fpi->use_mdio || fep->phy == NULL) -		return; - -	if (fep->phy->startup == NULL) -		return; - -	(*fep->phy->startup) (dev); -} - -void fec_mii_shutdown(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	const struct fec_platform_info *fpi = fep->fpi; - -	if (!fpi->use_mdio || fep->phy == NULL) -		return; - -	if (fep->phy->shutdown == NULL) -		return; - -	(*fep->phy->shutdown) (dev); -} - -void fec_mii_ack_int(struct net_device *dev) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	const struct fec_platform_info *fpi = fep->fpi; - -	if (!fpi->use_mdio || fep->phy == NULL) -		return; - -	if (fep->phy->ack_int == NULL) -		return; - -	(*fep->phy->ack_int) (dev); -} - -/* helper function */ -static int mii_negotiated(struct mii_if_info *mii) -{ -	int advert, lpa, val; - -	if (!mii_link_ok(mii)) -		return 0; - -	val = (*mii->mdio_read) (mii->dev, mii->phy_id, MII_BMSR); -	if ((val & BMSR_ANEGCOMPLETE) == 0) -		return 0; - -	advert = (*mii->mdio_read) (mii->dev, mii->phy_id, MII_ADVERTISE); -	lpa = (*mii->mdio_read) (mii->dev, mii->phy_id, MII_LPA); - -	return mii_nway_result(advert & lpa); -} - -void fec_mii_link_status_change_check(struct net_device *dev, int init_media) -{ -	struct fec_enet_private *fep = netdev_priv(dev); -	unsigned int media; -	unsigned long flags; - -	if (mii_check_media(&fep->mii_if, netif_msg_link(fep), init_media) == 0) -		return; - -	media = mii_negotiated(&fep->mii_if); - -	if (netif_carrier_ok(dev)) { -		spin_lock_irqsave(&fep->lock, flags); -		fec_restart(dev, !!(media & ADVERTISE_FULL), -			    (media & (ADVERTISE_100FULL | ADVERTISE_100HALF)) ? -			    100 : 10); -		spin_unlock_irqrestore(&fep->lock, flags); - -		netif_start_queue(dev); -	} else { -		netif_stop_queue(dev); - -		spin_lock_irqsave(&fep->lock, flags); -		fec_stop(dev); -		spin_unlock_irqrestore(&fep->lock, flags); - -	} -} diff --git a/drivers/net/fs_enet/fs_enet-main.c b/drivers/net/fs_enet/fs_enet-main.c index bdb81f5750a..445763e5648 100644 --- a/drivers/net/fs_enet/fs_enet-main.c +++ b/drivers/net/fs_enet/fs_enet-main.c @@ -44,7 +44,7 @@  #ifdef CONFIG_PPC_CPM_NEW_BINDING  #include <linux/of_gpio.h> -#include <asm/of_platform.h> +#include <linux/of_platform.h>  #endif  #include "fs_enet.h" diff --git a/drivers/net/fs_enet/mac-scc.c b/drivers/net/fs_enet/mac-scc.c index d7ca31945c8..e3557eca7b6 100644 --- a/drivers/net/fs_enet/mac-scc.c +++ b/drivers/net/fs_enet/mac-scc.c @@ -44,7 +44,7 @@  #endif  #ifdef CONFIG_PPC_CPM_NEW_BINDING -#include <asm/of_platform.h> +#include <linux/of_platform.h>  #endif  #include "fs_enet.h" diff --git a/drivers/net/fs_enet/mii-fec.c b/drivers/net/fs_enet/mii-fec.c index f0014cfbb27..8f6a43b0e0f 100644 --- a/drivers/net/fs_enet/mii-fec.c +++ b/drivers/net/fs_enet/mii-fec.c @@ -37,7 +37,7 @@  #include <asm/uaccess.h>  #ifdef CONFIG_PPC_CPM_NEW_BINDING -#include <asm/of_platform.h> +#include <linux/of_platform.h>  #endif  #include "fs_enet.h" diff --git a/drivers/net/ibm_newemac/core.c b/drivers/net/ibm_newemac/core.c index 9ca57d36559..2e720f26ca8 100644 --- a/drivers/net/ibm_newemac/core.c +++ b/drivers/net/ibm_newemac/core.c @@ -367,25 +367,31 @@ static int emac_reset(struct emac_instance *dev)  static void emac_hash_mc(struct emac_instance *dev)  { -	struct emac_regs __iomem *p = dev->emacp; -	u16 gaht[4] = { 0 }; +	const int regs = EMAC_XAHT_REGS(dev); +	u32 *gaht_base = emac_gaht_base(dev); +	u32 gaht_temp[regs];  	struct dev_mc_list *dmi; +	int i;  	DBG(dev, "hash_mc %d" NL, dev->ndev->mc_count); +	memset(gaht_temp, 0, sizeof (gaht_temp)); +  	for (dmi = dev->ndev->mc_list; dmi; dmi = dmi->next) { -		int bit; +		int slot, reg, mask;  		DBG2(dev, "mc %02x:%02x:%02x:%02x:%02x:%02x" NL,  		     dmi->dmi_addr[0], dmi->dmi_addr[1], dmi->dmi_addr[2],  		     dmi->dmi_addr[3], dmi->dmi_addr[4], dmi->dmi_addr[5]); -		bit = 63 - (ether_crc(ETH_ALEN, dmi->dmi_addr) >> 26); -		gaht[bit >> 4] |= 0x8000 >> (bit & 0x0f); +		slot = EMAC_XAHT_CRC_TO_SLOT(dev, ether_crc(ETH_ALEN, dmi->dmi_addr)); +		reg = EMAC_XAHT_SLOT_TO_REG(dev, slot); +		mask = EMAC_XAHT_SLOT_TO_MASK(dev, slot); + +		gaht_temp[reg] |= mask;  	} -	out_be32(&p->gaht1, gaht[0]); -	out_be32(&p->gaht2, gaht[1]); -	out_be32(&p->gaht3, gaht[2]); -	out_be32(&p->gaht4, gaht[3]); + +	for (i = 0; i < regs; i++) +		out_be32(gaht_base + i, gaht_temp[i]);  }  static inline u32 emac_iff2rmr(struct net_device *ndev) @@ -402,7 +408,8 @@ static inline u32 emac_iff2rmr(struct net_device *ndev)  	if (ndev->flags & IFF_PROMISC)  		r |= EMAC_RMR_PME; -	else if (ndev->flags & IFF_ALLMULTI || ndev->mc_count > 32) +	else if (ndev->flags & IFF_ALLMULTI || +			 (ndev->mc_count > EMAC_XAHT_SLOTS(dev)))  		r |= EMAC_RMR_PMME;  	else if (ndev->mc_count > 0)  		r |= EMAC_RMR_MAE; @@ -546,7 +553,7 @@ static int emac_configure(struct emac_instance *dev)  			/* Put some arbitrary OUI, Manuf & Rev IDs so we can  			 * identify this GPCS PHY later.  			 */ -			out_be32(&p->ipcr, 0xdeadbeef); +			out_be32(&p->u1.emac4.ipcr, 0xdeadbeef);  		} else  			mr1 |= EMAC_MR1_MF_1000; @@ -2025,10 +2032,10 @@ static int emac_get_regs_len(struct emac_instance *dev)  {  	if (emac_has_feature(dev, EMAC_FTR_EMAC4))  		return sizeof(struct emac_ethtool_regs_subhdr) + -			EMAC4_ETHTOOL_REGS_SIZE; +			EMAC4_ETHTOOL_REGS_SIZE(dev);  	else  		return sizeof(struct emac_ethtool_regs_subhdr) + -			EMAC_ETHTOOL_REGS_SIZE; +			EMAC_ETHTOOL_REGS_SIZE(dev);  }  static int emac_ethtool_get_regs_len(struct net_device *ndev) @@ -2055,12 +2062,12 @@ static void *emac_dump_regs(struct emac_instance *dev, void *buf)  	hdr->index = dev->cell_index;  	if (emac_has_feature(dev, EMAC_FTR_EMAC4)) {  		hdr->version = EMAC4_ETHTOOL_REGS_VER; -		memcpy_fromio(hdr + 1, dev->emacp, EMAC4_ETHTOOL_REGS_SIZE); -		return ((void *)(hdr + 1) + EMAC4_ETHTOOL_REGS_SIZE); +		memcpy_fromio(hdr + 1, dev->emacp, EMAC4_ETHTOOL_REGS_SIZE(dev)); +		return ((void *)(hdr + 1) + EMAC4_ETHTOOL_REGS_SIZE(dev));  	} else {  		hdr->version = EMAC_ETHTOOL_REGS_VER; -		memcpy_fromio(hdr + 1, dev->emacp, EMAC_ETHTOOL_REGS_SIZE); -		return ((void *)(hdr + 1) + EMAC_ETHTOOL_REGS_SIZE); +		memcpy_fromio(hdr + 1, dev->emacp, EMAC_ETHTOOL_REGS_SIZE(dev)); +		return ((void *)(hdr + 1) + EMAC_ETHTOOL_REGS_SIZE(dev));  	}  } @@ -2550,7 +2557,9 @@ static int __devinit emac_init_config(struct emac_instance *dev)  	}  	/* Check EMAC version */ -	if (of_device_is_compatible(np, "ibm,emac4")) { +	if (of_device_is_compatible(np, "ibm,emac4sync")) { +		dev->features |= (EMAC_FTR_EMAC4 | EMAC_FTR_EMAC4SYNC); +	} else if (of_device_is_compatible(np, "ibm,emac4")) {  		dev->features |= EMAC_FTR_EMAC4;  		if (of_device_is_compatible(np, "ibm,emac-440gx"))  			dev->features |= EMAC_FTR_440GX_PHY_CLK_FIX; @@ -2611,6 +2620,15 @@ static int __devinit emac_init_config(struct emac_instance *dev)  	}  	memcpy(dev->ndev->dev_addr, p, 6); +	/* IAHT and GAHT filter parameterization */ +	if (emac_has_feature(dev, EMAC_FTR_EMAC4SYNC)) { +		dev->xaht_slots_shift = EMAC4SYNC_XAHT_SLOTS_SHIFT; +		dev->xaht_width_shift = EMAC4SYNC_XAHT_WIDTH_SHIFT; +	} else { +		dev->xaht_slots_shift = EMAC4_XAHT_SLOTS_SHIFT; +		dev->xaht_width_shift = EMAC4_XAHT_WIDTH_SHIFT; +	} +  	DBG(dev, "features     : 0x%08x / 0x%08x\n", dev->features, EMAC_FTRS_POSSIBLE);  	DBG(dev, "tx_fifo_size : %d (%d gige)\n", dev->tx_fifo_size, dev->tx_fifo_size_gige);  	DBG(dev, "rx_fifo_size : %d (%d gige)\n", dev->rx_fifo_size, dev->rx_fifo_size_gige); @@ -2682,7 +2700,8 @@ static int __devinit emac_probe(struct of_device *ofdev,  		goto err_irq_unmap;  	}  	// TODO : request_mem_region -	dev->emacp = ioremap(dev->rsrc_regs.start, sizeof(struct emac_regs)); +	dev->emacp = ioremap(dev->rsrc_regs.start, +			     dev->rsrc_regs.end - dev->rsrc_regs.start + 1);  	if (dev->emacp == NULL) {  		printk(KERN_ERR "%s: Can't map device registers!\n",  		       np->full_name); @@ -2896,6 +2915,10 @@ static struct of_device_id emac_match[] =  		.type		= "network",  		.compatible	= "ibm,emac4",  	}, +	{ +		.type		= "network", +		.compatible	= "ibm,emac4sync", +	},  	{},  }; diff --git a/drivers/net/ibm_newemac/core.h b/drivers/net/ibm_newemac/core.h index 1683db9870a..6545e69d12c 100644 --- a/drivers/net/ibm_newemac/core.h +++ b/drivers/net/ibm_newemac/core.h @@ -33,8 +33,8 @@  #include <linux/netdevice.h>  #include <linux/dma-mapping.h>  #include <linux/spinlock.h> +#include <linux/of_platform.h> -#include <asm/of_platform.h>  #include <asm/io.h>  #include <asm/dcr.h> @@ -235,6 +235,10 @@ struct emac_instance {  	u32				fifo_entry_size;  	u32				mal_burst_size; /* move to MAL ? */ +	/* IAHT and GAHT filter parameterization */ +	u32				xaht_slots_shift; +	u32				xaht_width_shift; +  	/* Descriptor management  	 */  	struct mal_descriptor		*tx_desc; @@ -309,6 +313,10 @@ struct emac_instance {   * Set if we need phy clock workaround for 440ep or 440gr   */  #define EMAC_FTR_440EP_PHY_CLK_FIX	0x00000100 +/* + * The 405EX and 460EX contain the EMAC4SYNC core + */ +#define EMAC_FTR_EMAC4SYNC		0x00000200  /* Right now, we don't quite handle the always/possible masks on the @@ -320,7 +328,8 @@ enum {  	EMAC_FTRS_POSSIBLE	=  #ifdef CONFIG_IBM_NEW_EMAC_EMAC4 -	    EMAC_FTR_EMAC4 | EMAC_FTR_HAS_NEW_STACR | +	    EMAC_FTR_EMAC4	| EMAC_FTR_EMAC4SYNC	| +	    EMAC_FTR_HAS_NEW_STACR	|  	    EMAC_FTR_STACR_OC_INVERT | EMAC_FTR_440GX_PHY_CLK_FIX |  #endif  #ifdef CONFIG_IBM_NEW_EMAC_TAH @@ -342,6 +351,71 @@ static inline int emac_has_feature(struct emac_instance *dev,  	       (EMAC_FTRS_POSSIBLE & dev->features & feature);  } +/* + * Various instances of the EMAC core have varying 1) number of + * address match slots, 2) width of the registers for handling address + * match slots, 3) number of registers for handling address match + * slots and 4) base offset for those registers. + * + * These macros and inlines handle these differences based on + * parameters supplied by the device structure which are, in turn, + * initialized based on the "compatible" entry in the device tree. + */ + +#define	EMAC4_XAHT_SLOTS_SHIFT		6 +#define	EMAC4_XAHT_WIDTH_SHIFT		4 + +#define	EMAC4SYNC_XAHT_SLOTS_SHIFT	8 +#define	EMAC4SYNC_XAHT_WIDTH_SHIFT	5 + +#define	EMAC_XAHT_SLOTS(dev)         	(1 << (dev)->xaht_slots_shift) +#define	EMAC_XAHT_WIDTH(dev)         	(1 << (dev)->xaht_width_shift) +#define	EMAC_XAHT_REGS(dev)          	(1 << ((dev)->xaht_slots_shift - \ +					       (dev)->xaht_width_shift)) + +#define	EMAC_XAHT_CRC_TO_SLOT(dev, crc)			\ +	((EMAC_XAHT_SLOTS(dev) - 1) -			\ +	 ((crc) >> ((sizeof (u32) * BITS_PER_BYTE) -	\ +		    (dev)->xaht_slots_shift))) + +#define	EMAC_XAHT_SLOT_TO_REG(dev, slot)		\ +	((slot) >> (dev)->xaht_width_shift) + +#define	EMAC_XAHT_SLOT_TO_MASK(dev, slot)		\ +	((u32)(1 << (EMAC_XAHT_WIDTH(dev) - 1)) >>	\ +	 ((slot) & (u32)(EMAC_XAHT_WIDTH(dev) - 1))) + +static inline u32 *emac_xaht_base(struct emac_instance *dev) +{ +	struct emac_regs __iomem *p = dev->emacp; +	int offset; + +	/* The first IAHT entry always is the base of the block of +	 * IAHT and GAHT registers. +	 */ +	if (emac_has_feature(dev, EMAC_FTR_EMAC4SYNC)) +		offset = offsetof(struct emac_regs, u1.emac4sync.iaht1); +	else +		offset = offsetof(struct emac_regs, u0.emac4.iaht1); + +	return ((u32 *)((ptrdiff_t)p + offset)); +} + +static inline u32 *emac_gaht_base(struct emac_instance *dev) +{ +	/* GAHT registers always come after an identical number of +	 * IAHT registers. +	 */ +	return (emac_xaht_base(dev) + EMAC_XAHT_REGS(dev)); +} + +static inline u32 *emac_iaht_base(struct emac_instance *dev) +{ +	/* IAHT registers always come before an identical number of +	 * GAHT registers. +	 */ +	return (emac_xaht_base(dev)); +}  /* Ethtool get_regs complex data.   * We want to get not just EMAC registers, but also MAL, ZMII, RGMII, TAH @@ -366,4 +440,11 @@ struct emac_ethtool_regs_subhdr {  	u32 index;  }; +#define EMAC_ETHTOOL_REGS_VER		0 +#define EMAC_ETHTOOL_REGS_SIZE(dev) 	((dev)->rsrc_regs.end - \ +					 (dev)->rsrc_regs.start + 1) +#define EMAC4_ETHTOOL_REGS_VER      	1 +#define EMAC4_ETHTOOL_REGS_SIZE(dev)	((dev)->rsrc_regs.end -	\ +					 (dev)->rsrc_regs.start + 1) +  #endif /* __IBM_NEWEMAC_CORE_H */ diff --git a/drivers/net/ibm_newemac/debug.c b/drivers/net/ibm_newemac/debug.c index 86b756a3078..775c850a425 100644 --- a/drivers/net/ibm_newemac/debug.c +++ b/drivers/net/ibm_newemac/debug.c @@ -67,29 +67,55 @@ static void emac_desc_dump(struct emac_instance *p)  static void emac_mac_dump(struct emac_instance *dev)  {  	struct emac_regs __iomem *p = dev->emacp; +	const int xaht_regs = EMAC_XAHT_REGS(dev); +	u32 *gaht_base = emac_gaht_base(dev); +	u32 *iaht_base = emac_iaht_base(dev); +	int emac4sync = emac_has_feature(dev, EMAC_FTR_EMAC4SYNC); +	int n;  	printk("** EMAC %s registers **\n"  	       "MR0 = 0x%08x MR1 = 0x%08x TMR0 = 0x%08x TMR1 = 0x%08x\n"  	       "RMR = 0x%08x ISR = 0x%08x ISER = 0x%08x\n" -	       "IAR = %04x%08x VTPID = 0x%04x VTCI = 0x%04x\n" -	       "IAHT: 0x%04x 0x%04x 0x%04x 0x%04x " -	       "GAHT: 0x%04x 0x%04x 0x%04x 0x%04x\n" -	       "LSA = %04x%08x IPGVR = 0x%04x\n" -	       "STACR = 0x%08x TRTR = 0x%08x RWMR = 0x%08x\n" -	       "OCTX = 0x%08x OCRX = 0x%08x IPCR = 0x%08x\n", +	       "IAR = %04x%08x VTPID = 0x%04x VTCI = 0x%04x\n",  	       dev->ofdev->node->full_name, in_be32(&p->mr0), in_be32(&p->mr1),  	       in_be32(&p->tmr0), in_be32(&p->tmr1),  	       in_be32(&p->rmr), in_be32(&p->isr), in_be32(&p->iser),  	       in_be32(&p->iahr), in_be32(&p->ialr), in_be32(&p->vtpid), -	       in_be32(&p->vtci), -	       in_be32(&p->iaht1), in_be32(&p->iaht2), in_be32(&p->iaht3), -	       in_be32(&p->iaht4), -	       in_be32(&p->gaht1), in_be32(&p->gaht2), in_be32(&p->gaht3), -	       in_be32(&p->gaht4), +	       in_be32(&p->vtci) +	       ); + +	if (emac4sync) +		printk("MAR = %04x%08x MMAR = %04x%08x\n", +		       in_be32(&p->u0.emac4sync.mahr), +		       in_be32(&p->u0.emac4sync.malr), +		       in_be32(&p->u0.emac4sync.mmahr), +		       in_be32(&p->u0.emac4sync.mmalr) +		       ); + +	for (n = 0; n < xaht_regs; n++) +		printk("IAHT%02d = 0x%08x\n", n + 1, in_be32(iaht_base + n)); + +	for (n = 0; n < xaht_regs; n++) +		printk("GAHT%02d = 0x%08x\n", n + 1, in_be32(gaht_base + n)); + +	printk("LSA = %04x%08x IPGVR = 0x%04x\n" +	       "STACR = 0x%08x TRTR = 0x%08x RWMR = 0x%08x\n" +	       "OCTX = 0x%08x OCRX = 0x%08x\n",  	       in_be32(&p->lsah), in_be32(&p->lsal), in_be32(&p->ipgvr),  	       in_be32(&p->stacr), in_be32(&p->trtr), in_be32(&p->rwmr), -	       in_be32(&p->octx), in_be32(&p->ocrx), in_be32(&p->ipcr) -	    ); +	       in_be32(&p->octx), in_be32(&p->ocrx) +	       ); + +	if (!emac4sync) { +		printk("IPCR = 0x%08x\n", +		       in_be32(&p->u1.emac4.ipcr) +		       ); +	} else { +		printk("REVID = 0x%08x TPC = 0x%08x\n", +		       in_be32(&p->u1.emac4sync.revid), +		       in_be32(&p->u1.emac4sync.tpc) +		       ); +	}  	emac_desc_dump(dev);  } diff --git a/drivers/net/ibm_newemac/emac.h b/drivers/net/ibm_newemac/emac.h index 91cb096ab40..0afc2cf5c52 100644 --- a/drivers/net/ibm_newemac/emac.h +++ b/drivers/net/ibm_newemac/emac.h @@ -27,37 +27,80 @@  #include <linux/types.h> -/* EMAC registers 		Write Access rules */ +/* EMAC registers 			Write Access rules */  struct emac_regs { -	u32 mr0;		/* special 	*/ -	u32 mr1;		/* Reset 	*/ -	u32 tmr0;		/* special 	*/ -	u32 tmr1;		/* special 	*/ -	u32 rmr;		/* Reset 	*/ -	u32 isr;		/* Always 	*/ -	u32 iser;		/* Reset 	*/ -	u32 iahr;		/* Reset, R, T 	*/ -	u32 ialr;		/* Reset, R, T 	*/ -	u32 vtpid;		/* Reset, R, T 	*/ -	u32 vtci;		/* Reset, R, T 	*/ -	u32 ptr;		/* Reset,    T 	*/ -	u32 iaht1;		/* Reset, R	*/ -	u32 iaht2;		/* Reset, R	*/ -	u32 iaht3;		/* Reset, R	*/ -	u32 iaht4;		/* Reset, R	*/ -	u32 gaht1;		/* Reset, R	*/ -	u32 gaht2;		/* Reset, R	*/ -	u32 gaht3;		/* Reset, R	*/ -	u32 gaht4;		/* Reset, R	*/ +	/* Common registers across all EMAC implementations. */ +	u32 mr0;			/* Special 	*/ +	u32 mr1;			/* Reset 	*/ +	u32 tmr0;			/* Special 	*/ +	u32 tmr1;			/* Special 	*/ +	u32 rmr;			/* Reset 	*/ +	u32 isr;			/* Always 	*/ +	u32 iser;			/* Reset 	*/ +	u32 iahr;			/* Reset, R, T 	*/ +	u32 ialr;			/* Reset, R, T 	*/ +	u32 vtpid;			/* Reset, R, T 	*/ +	u32 vtci;			/* Reset, R, T 	*/ +	u32 ptr;			/* Reset,    T 	*/ +	union { +		/* Registers unique to EMAC4 implementations */ +		struct { +			u32 iaht1;	/* Reset, R	*/ +			u32 iaht2;	/* Reset, R	*/ +			u32 iaht3;	/* Reset, R	*/ +			u32 iaht4;	/* Reset, R	*/ +			u32 gaht1;	/* Reset, R	*/ +			u32 gaht2;	/* Reset, R	*/ +			u32 gaht3;	/* Reset, R	*/ +			u32 gaht4;	/* Reset, R	*/ +		} emac4; +		/* Registers unique to EMAC4SYNC implementations */ +		struct { +			u32 mahr;	/* Reset, R, T  */ +			u32 malr;	/* Reset, R, T  */ +			u32 mmahr;	/* Reset, R, T  */ +			u32 mmalr;	/* Reset, R, T  */ +			u32 rsvd0[4]; +		} emac4sync; +	} u0; +	/* Common registers across all EMAC implementations. */  	u32 lsah;  	u32 lsal; -	u32 ipgvr;		/* Reset,    T 	*/ -	u32 stacr;		/* special 	*/ -	u32 trtr;		/* special 	*/ -	u32 rwmr;		/* Reset 	*/ +	u32 ipgvr;			/* Reset,    T 	*/ +	u32 stacr;			/* Special 	*/ +	u32 trtr;			/* Special 	*/ +	u32 rwmr;			/* Reset 	*/  	u32 octx;  	u32 ocrx; -	u32 ipcr; +	union { +		/* Registers unique to EMAC4 implementations */ +		struct { +			u32 ipcr; +		} emac4; +		/* Registers unique to EMAC4SYNC implementations */ +		struct { +			u32 rsvd1; +			u32 revid; + 			u32 rsvd2[2]; +			u32 iaht1;	/* Reset, R     */ +			u32 iaht2;	/* Reset, R     */ +			u32 iaht3;	/* Reset, R     */ +			u32 iaht4;	/* Reset, R     */ +			u32 iaht5;	/* Reset, R     */ +			u32 iaht6;	/* Reset, R     */ +			u32 iaht7;	/* Reset, R     */ +			u32 iaht8;	/* Reset, R     */ +			u32 gaht1;	/* Reset, R     */ +			u32 gaht2;	/* Reset, R     */ +			u32 gaht3;	/* Reset, R     */ +			u32 gaht4;	/* Reset, R     */ +			u32 gaht5;	/* Reset, R     */ +			u32 gaht6;	/* Reset, R     */ +			u32 gaht7;	/* Reset, R     */ +			u32 gaht8;	/* Reset, R     */ +			u32 tpc;	/* Reset, T     */ +		} emac4sync; +	} u1;  };  /* @@ -73,12 +116,6 @@ struct emac_regs {  #define PHY_MODE_RTBI	7  #define PHY_MODE_SGMII	8 - -#define EMAC_ETHTOOL_REGS_VER		0 -#define EMAC_ETHTOOL_REGS_SIZE		(sizeof(struct emac_regs) - sizeof(u32)) -#define EMAC4_ETHTOOL_REGS_VER      	1 -#define EMAC4_ETHTOOL_REGS_SIZE		sizeof(struct emac_regs) -  /* EMACx_MR0 */  #define EMAC_MR0_RXI			0x80000000  #define EMAC_MR0_TXI			0x40000000 diff --git a/drivers/net/ibm_newemac/rgmii.c b/drivers/net/ibm_newemac/rgmii.c index e32da3de269..1d5379de690 100644 --- a/drivers/net/ibm_newemac/rgmii.c +++ b/drivers/net/ibm_newemac/rgmii.c @@ -39,6 +39,7 @@  #define RGMII_FER_RGMII(idx)	(0x5 << ((idx) * 4))  #define RGMII_FER_TBI(idx)	(0x6 << ((idx) * 4))  #define RGMII_FER_GMII(idx)	(0x7 << ((idx) * 4)) +#define RGMII_FER_MII(idx)	RGMII_FER_GMII(idx)  /* RGMIIx_SSR */  #define RGMII_SSR_MASK(idx)	(0x7 << ((idx) * 8)) @@ -49,6 +50,7 @@  static inline int rgmii_valid_mode(int phy_mode)  {  	return  phy_mode == PHY_MODE_GMII || +		phy_mode == PHY_MODE_MII ||  		phy_mode == PHY_MODE_RGMII ||  		phy_mode == PHY_MODE_TBI ||  		phy_mode == PHY_MODE_RTBI; @@ -63,6 +65,8 @@ static inline const char *rgmii_mode_name(int mode)  		return "TBI";  	case PHY_MODE_GMII:  		return "GMII"; +	case PHY_MODE_MII: +		return "MII";  	case PHY_MODE_RTBI:  		return "RTBI";  	default: @@ -79,6 +83,8 @@ static inline u32 rgmii_mode_mask(int mode, int input)  		return RGMII_FER_TBI(input);  	case PHY_MODE_GMII:  		return RGMII_FER_GMII(input); +	case PHY_MODE_MII: +		return RGMII_FER_MII(input);  	case PHY_MODE_RTBI:  		return RGMII_FER_RTBI(input);  	default: diff --git a/drivers/net/irda/irda-usb.c b/drivers/net/irda/irda-usb.c index 6f50ed7b183..18b471cd144 100644 --- a/drivers/net/irda/irda-usb.c +++ b/drivers/net/irda/irda-usb.c @@ -1024,7 +1024,7 @@ static int irda_usb_is_receiving(struct irda_usb_cb *self)   *   Upload firmware code to SigmaTel 421X IRDA-USB dongle   */  static int stir421x_fw_upload(struct irda_usb_cb *self, -			     unsigned char *patch, +			     const unsigned char *patch,  			     const unsigned int patch_len)  {          int ret = -ENOMEM; @@ -1073,11 +1073,11 @@ static int stir421x_fw_upload(struct irda_usb_cb *self,    */  static int stir421x_patch_device(struct irda_usb_cb *self)  { -        unsigned int i; -        int ret; -        char stir421x_fw_name[11]; -        const struct firmware *fw; -        unsigned char *fw_version_ptr; /* pointer to version string */ +	unsigned int i; +	int ret; +	char stir421x_fw_name[11]; +	const struct firmware *fw; +	const unsigned char *fw_version_ptr; /* pointer to version string */  	unsigned long fw_version = 0;          /* diff --git a/drivers/net/irda/pxaficp_ir.c b/drivers/net/irda/pxaficp_ir.c index d5c2d27f3ea..f76b0b6c277 100644 --- a/drivers/net/irda/pxaficp_ir.c +++ b/drivers/net/irda/pxaficp_ir.c @@ -13,16 +13,8 @@   *   */  #include <linux/module.h> -#include <linux/types.h> -#include <linux/init.h> -#include <linux/errno.h>  #include <linux/netdevice.h> -#include <linux/slab.h> -#include <linux/rtnetlink.h> -#include <linux/interrupt.h> -#include <linux/dma-mapping.h>  #include <linux/platform_device.h> -#include <linux/pm.h>  #include <linux/clk.h>  #include <net/irda/irda.h> @@ -30,17 +22,9 @@  #include <net/irda/wrapper.h>  #include <net/irda/irda_device.h> -#include <asm/irq.h>  #include <asm/dma.h> -#include <asm/delay.h> -#include <asm/hardware.h>  #include <asm/arch/irda.h>  #include <asm/arch/pxa-regs.h> -#include <asm/arch/pxa2xx-gpio.h> - -#ifdef CONFIG_MACH_MAINSTONE -#include <asm/arch/mainstone.h> -#endif  #define IrSR_RXPL_NEG_IS_ZERO (1<<4)  #define IrSR_RXPL_POS_IS_ZERO 0x0 @@ -163,10 +147,6 @@ static int pxa_irda_set_speed(struct pxa_irda *si, int speed)  			/* set board transceiver to SIR mode */  			si->pdata->transceiver_mode(si->dev, IR_SIRMODE); -			/* configure GPIO46/47 */ -			pxa_gpio_mode(GPIO46_STRXD_MD); -			pxa_gpio_mode(GPIO47_STTXD_MD); -  			/* enable the STUART clock */  			pxa_irda_enable_sirclk(si);  		} @@ -201,10 +181,6 @@ static int pxa_irda_set_speed(struct pxa_irda *si, int speed)  		/* set board transceiver to FIR mode */  		si->pdata->transceiver_mode(si->dev, IR_FIRMODE); -		/* configure GPIO46/47 */ -		pxa_gpio_mode(GPIO46_ICPRXD_MD); -		pxa_gpio_mode(GPIO47_ICPTXD_MD); -  		/* enable the FICP clock */  		pxa_irda_enable_firclk(si); diff --git a/drivers/net/macb.c b/drivers/net/macb.c index 50688a52658..0496d16f9de 100644 --- a/drivers/net/macb.c +++ b/drivers/net/macb.c @@ -1281,8 +1281,45 @@ static int __exit macb_remove(struct platform_device *pdev)  	return 0;  } +#ifdef CONFIG_PM +static int macb_suspend(struct platform_device *pdev, pm_message_t state) +{ +	struct net_device *netdev = platform_get_drvdata(pdev); +	struct macb *bp = netdev_priv(netdev); + +	netif_device_detach(netdev); + +#ifndef CONFIG_ARCH_AT91 +	clk_disable(bp->hclk); +#endif +	clk_disable(bp->pclk); + +	return 0; +} + +static int macb_resume(struct platform_device *pdev) +{ +	struct net_device *netdev = platform_get_drvdata(pdev); +	struct macb *bp = netdev_priv(netdev); + +	clk_enable(bp->pclk); +#ifndef CONFIG_ARCH_AT91 +	clk_enable(bp->hclk); +#endif + +	netif_device_attach(netdev); + +	return 0; +} +#else +#define macb_suspend	NULL +#define macb_resume	NULL +#endif +  static struct platform_driver macb_driver = {  	.remove		= __exit_p(macb_remove), +	.suspend	= macb_suspend, +	.resume		= macb_resume,  	.driver		= {  		.name		= "macb",  		.owner	= THIS_MODULE, diff --git a/drivers/net/macvlan.c b/drivers/net/macvlan.c index 72745ce588c..efbc15567dd 100644 --- a/drivers/net/macvlan.c +++ b/drivers/net/macvlan.c @@ -20,7 +20,7 @@  #include <linux/errno.h>  #include <linux/slab.h>  #include <linux/string.h> -#include <linux/list.h> +#include <linux/rculist.h>  #include <linux/notifier.h>  #include <linux/netdevice.h>  #include <linux/etherdevice.h> diff --git a/drivers/net/mlx4/fw.c b/drivers/net/mlx4/fw.c index d82f2751d2c..2b5006b9be6 100644 --- a/drivers/net/mlx4/fw.c +++ b/drivers/net/mlx4/fw.c @@ -101,6 +101,34 @@ static void dump_dev_cap_flags(struct mlx4_dev *dev, u32 flags)  			mlx4_dbg(dev, "    %s\n", fname[i]);  } +int mlx4_MOD_STAT_CFG(struct mlx4_dev *dev, struct mlx4_mod_stat_cfg *cfg) +{ +	struct mlx4_cmd_mailbox *mailbox; +	u32 *inbox; +	int err = 0; + +#define MOD_STAT_CFG_IN_SIZE		0x100 + +#define MOD_STAT_CFG_PG_SZ_M_OFFSET	0x002 +#define MOD_STAT_CFG_PG_SZ_OFFSET	0x003 + +	mailbox = mlx4_alloc_cmd_mailbox(dev); +	if (IS_ERR(mailbox)) +		return PTR_ERR(mailbox); +	inbox = mailbox->buf; + +	memset(inbox, 0, MOD_STAT_CFG_IN_SIZE); + +	MLX4_PUT(inbox, cfg->log_pg_sz, MOD_STAT_CFG_PG_SZ_OFFSET); +	MLX4_PUT(inbox, cfg->log_pg_sz_m, MOD_STAT_CFG_PG_SZ_M_OFFSET); + +	err = mlx4_cmd(dev, mailbox->dma, 0, 0, MLX4_CMD_MOD_STAT_CFG, +			MLX4_CMD_TIME_CLASS_A); + +	mlx4_free_cmd_mailbox(dev, mailbox); +	return err; +} +  int mlx4_QUERY_DEV_CAP(struct mlx4_dev *dev, struct mlx4_dev_cap *dev_cap)  {  	struct mlx4_cmd_mailbox *mailbox; diff --git a/drivers/net/mlx4/fw.h b/drivers/net/mlx4/fw.h index 306cb9b0242..a0e046c149b 100644 --- a/drivers/net/mlx4/fw.h +++ b/drivers/net/mlx4/fw.h @@ -38,6 +38,11 @@  #include "mlx4.h"  #include "icm.h" +struct mlx4_mod_stat_cfg { +	u8 log_pg_sz; +	u8 log_pg_sz_m; +}; +  struct mlx4_dev_cap {  	int max_srq_sz;  	int max_qp_sz; @@ -162,5 +167,6 @@ int mlx4_SET_ICM_SIZE(struct mlx4_dev *dev, u64 icm_size, u64 *aux_pages);  int mlx4_MAP_ICM_AUX(struct mlx4_dev *dev, struct mlx4_icm *icm);  int mlx4_UNMAP_ICM_AUX(struct mlx4_dev *dev);  int mlx4_NOP(struct mlx4_dev *dev); +int mlx4_MOD_STAT_CFG(struct mlx4_dev *dev, struct mlx4_mod_stat_cfg *cfg);  #endif /* MLX4_FW_H */ diff --git a/drivers/net/mlx4/main.c b/drivers/net/mlx4/main.c index a6aa49fc1d6..d3736013fe9 100644 --- a/drivers/net/mlx4/main.c +++ b/drivers/net/mlx4/main.c @@ -485,6 +485,7 @@ static int mlx4_init_hca(struct mlx4_dev *dev)  	struct mlx4_priv	  *priv = mlx4_priv(dev);  	struct mlx4_adapter	   adapter;  	struct mlx4_dev_cap	   dev_cap; +	struct mlx4_mod_stat_cfg   mlx4_cfg;  	struct mlx4_profile	   profile;  	struct mlx4_init_hca_param init_hca;  	u64 icm_size; @@ -502,6 +503,12 @@ static int mlx4_init_hca(struct mlx4_dev *dev)  		return err;  	} +	mlx4_cfg.log_pg_sz_m = 1; +	mlx4_cfg.log_pg_sz = 0; +	err = mlx4_MOD_STAT_CFG(dev, &mlx4_cfg); +	if (err) +		mlx4_warn(dev, "Failed to override log_pg_sz parameter\n"); +  	err = mlx4_dev_cap(dev, &dev_cap);  	if (err) {  		mlx4_err(dev, "QUERY_DEV_CAP command failed, aborting.\n"); diff --git a/drivers/net/mlx4/mcg.c b/drivers/net/mlx4/mcg.c index 57f7f1f0d4e..b4b57870ddf 100644 --- a/drivers/net/mlx4/mcg.c +++ b/drivers/net/mlx4/mcg.c @@ -38,6 +38,9 @@  #include "mlx4.h" +#define MGM_QPN_MASK       0x00FFFFFF +#define MGM_BLCK_LB_BIT    30 +  struct mlx4_mgm {  	__be32			next_gid_index;  	__be32			members_count; @@ -153,7 +156,8 @@ static int find_mgm(struct mlx4_dev *dev,  	return err;  } -int mlx4_multicast_attach(struct mlx4_dev *dev, struct mlx4_qp *qp, u8 gid[16]) +int mlx4_multicast_attach(struct mlx4_dev *dev, struct mlx4_qp *qp, u8 gid[16], +			  int block_mcast_loopback)  {  	struct mlx4_priv *priv = mlx4_priv(dev);  	struct mlx4_cmd_mailbox *mailbox; @@ -202,13 +206,18 @@ int mlx4_multicast_attach(struct mlx4_dev *dev, struct mlx4_qp *qp, u8 gid[16])  	}  	for (i = 0; i < members_count; ++i) -		if (mgm->qp[i] == cpu_to_be32(qp->qpn)) { +		if ((be32_to_cpu(mgm->qp[i]) & MGM_QPN_MASK) == qp->qpn) {  			mlx4_dbg(dev, "QP %06x already a member of MGM\n", qp->qpn);  			err = 0;  			goto out;  		} -	mgm->qp[members_count++] = cpu_to_be32(qp->qpn); +	if (block_mcast_loopback) +		mgm->qp[members_count++] = cpu_to_be32((qp->qpn & MGM_QPN_MASK) | +						       (1 << MGM_BLCK_LB_BIT)); +	else +		mgm->qp[members_count++] = cpu_to_be32(qp->qpn & MGM_QPN_MASK); +  	mgm->members_count       = cpu_to_be32(members_count);  	err = mlx4_WRITE_MCG(dev, index, mailbox); @@ -283,7 +292,7 @@ int mlx4_multicast_detach(struct mlx4_dev *dev, struct mlx4_qp *qp, u8 gid[16])  	members_count = be32_to_cpu(mgm->members_count);  	for (loc = -1, i = 0; i < members_count; ++i) -		if (mgm->qp[i] == cpu_to_be32(qp->qpn)) +		if ((be32_to_cpu(mgm->qp[i]) & MGM_QPN_MASK) == qp->qpn)  			loc = i;  	if (loc == -1) { diff --git a/drivers/net/myri10ge/myri10ge.c b/drivers/net/myri10ge/myri10ge.c index 9a68d2ea5f3..b3981ed972b 100644 --- a/drivers/net/myri10ge/myri10ge.c +++ b/drivers/net/myri10ge/myri10ge.c @@ -556,6 +556,7 @@ static int myri10ge_load_hotplug_firmware(struct myri10ge_priv *mgp, u32 * size)  	unsigned crc, reread_crc;  	const struct firmware *fw;  	struct device *dev = &mgp->pdev->dev; +	unsigned char *fw_readback;  	struct mcp_gen_header *hdr;  	size_t hdr_offset;  	int status; @@ -598,9 +599,15 @@ static int myri10ge_load_hotplug_firmware(struct myri10ge_priv *mgp, u32 * size)  		mb();  		readb(mgp->sram);  	} +	fw_readback = vmalloc(fw->size); +	if (!fw_readback) { +		status = -ENOMEM; +		goto abort_with_fw; +	}  	/* corruption checking is good for parity recovery and buggy chipset */ -	memcpy_fromio(fw->data, mgp->sram + MYRI10GE_FW_OFFSET, fw->size); -	reread_crc = crc32(~0, fw->data, fw->size); +	memcpy_fromio(fw_readback, mgp->sram + MYRI10GE_FW_OFFSET, fw->size); +	reread_crc = crc32(~0, fw_readback, fw->size); +	vfree(fw_readback);  	if (crc != reread_crc) {  		dev_err(dev, "CRC failed(fw-len=%u), got 0x%x (expect 0x%x)\n",  			(unsigned)fw->size, reread_crc, crc); diff --git a/drivers/net/netconsole.c b/drivers/net/netconsole.c index 665341e4305..387a1339501 100644 --- a/drivers/net/netconsole.c +++ b/drivers/net/netconsole.c @@ -585,8 +585,9 @@ static struct config_item_type netconsole_target_type = {   * Group operations and type for netconsole_subsys.   */ -static struct config_item *make_netconsole_target(struct config_group *group, -						  const char *name) +static int make_netconsole_target(struct config_group *group, +				  const char *name, +				  struct config_item **new_item)  {  	unsigned long flags;  	struct netconsole_target *nt; @@ -598,7 +599,7 @@ static struct config_item *make_netconsole_target(struct config_group *group,  	nt = kzalloc(sizeof(*nt), GFP_KERNEL);  	if (!nt) {  		printk(KERN_ERR "netconsole: failed to allocate memory\n"); -		return NULL; +		return -ENOMEM;  	}  	nt->np.name = "netconsole"; @@ -615,7 +616,8 @@ static struct config_item *make_netconsole_target(struct config_group *group,  	list_add(&nt->list, &target_list);  	spin_unlock_irqrestore(&target_list_lock, flags); -	return &nt->item; +	*new_item = &nt->item; +	return 0;  }  static void drop_netconsole_target(struct config_group *group, diff --git a/drivers/net/ppp_generic.c b/drivers/net/ppp_generic.c index c926bf0b190..6b1d7a8edf1 100644 --- a/drivers/net/ppp_generic.c +++ b/drivers/net/ppp_generic.c @@ -39,6 +39,7 @@  #include <linux/if_arp.h>  #include <linux/ip.h>  #include <linux/tcp.h> +#include <linux/smp_lock.h>  #include <linux/spinlock.h>  #include <linux/rwsem.h>  #include <linux/stddef.h> @@ -353,6 +354,7 @@ static const int npindex_to_ethertype[NUM_NP] = {   */  static int ppp_open(struct inode *inode, struct file *file)  { +	cycle_kernel_lock();  	/*  	 * This could (should?) be enforced by the permissions on /dev/ppp.  	 */ diff --git a/drivers/net/tokenring/smctr.c b/drivers/net/tokenring/smctr.c index 5f1c5072b96..fa73e6eed6b 100644 --- a/drivers/net/tokenring/smctr.c +++ b/drivers/net/tokenring/smctr.c @@ -48,6 +48,7 @@  #include <linux/skbuff.h>  #include <linux/trdevice.h>  #include <linux/bitops.h> +#include <linux/firmware.h>  #include <asm/system.h>  #include <asm/io.h> @@ -59,7 +60,6 @@  #endif  #include "smctr.h"               /* Our Stuff */ -#include "smctr_firmware.h"      /* SMC adapter firmware */  static char version[] __initdata = KERN_INFO "smctr.c: v1.4 7/12/00 by jschlst@samba.org\n";  static const char cardname[] = "smctr"; @@ -103,7 +103,8 @@ static int smctr_clear_trc_reset(int ioaddr);  static int smctr_close(struct net_device *dev);  /* D */ -static int smctr_decode_firmware(struct net_device *dev); +static int smctr_decode_firmware(struct net_device *dev, +				 const struct firmware *fw);  static int smctr_disable_16bit(struct net_device *dev);  static int smctr_disable_adapter_ctrl_store(struct net_device *dev);  static int smctr_disable_bic_int(struct net_device *dev); @@ -748,7 +749,8 @@ static int smctr_close(struct net_device *dev)          return (0);  } -static int smctr_decode_firmware(struct net_device *dev) +static int smctr_decode_firmware(struct net_device *dev, +				 const struct firmware *fw)  {          struct net_local *tp = netdev_priv(dev);          short bit = 0x80, shift = 12; @@ -762,10 +764,10 @@ static int smctr_decode_firmware(struct net_device *dev)          if(smctr_debug > 10)                  printk(KERN_DEBUG "%s: smctr_decode_firmware\n", dev->name); -        weight  = *(long *)(tp->ptr_ucode + WEIGHT_OFFSET); -        tsize   = *(__u8 *)(tp->ptr_ucode + TREE_SIZE_OFFSET); -        tree    = (DECODE_TREE_NODE *)(tp->ptr_ucode + TREE_OFFSET); -        ucode   = (__u8 *)(tp->ptr_ucode + TREE_OFFSET +        weight  = *(long *)(fw->data + WEIGHT_OFFSET); +        tsize   = *(__u8 *)(fw->data + TREE_SIZE_OFFSET); +        tree    = (DECODE_TREE_NODE *)(fw->data + TREE_OFFSET); +        ucode   = (__u8 *)(fw->data + TREE_OFFSET                          + (tsize * sizeof(DECODE_TREE_NODE)));          mem     = (__u16 *)(tp->ram_access); @@ -2963,34 +2965,44 @@ static int smctr_link_tx_fcbs_to_bdbs(struct net_device *dev)  static int smctr_load_firmware(struct net_device *dev)  {          struct net_local *tp = netdev_priv(dev); +	const struct firmware *fw;          __u16 i, checksum = 0;          int err = 0;          if(smctr_debug > 10)                  printk(KERN_DEBUG "%s: smctr_load_firmware\n", dev->name); -        tp->ptr_ucode           = smctr_code; +	if (request_firmware(&fw, "tr_smctr.bin", &dev->dev)) { +		printk(KERN_ERR "%s: firmware not found\n", dev->name); +		return (UCODE_NOT_PRESENT); +	} +          tp->num_of_tx_buffs     = 4;          tp->mode_bits          |= UMAC;          tp->receive_mask        = 0;          tp->max_packet_size     = 4177;          /* Can only upload the firmware once per adapter reset. */ -        if(tp->microcode_version != 0) -                return (UCODE_PRESENT); +        if (tp->microcode_version != 0) { +		err = (UCODE_PRESENT); +		goto out; +	}          /* Verify the firmware exists and is there in the right amount. */ -        if (!tp->ptr_ucode -                || (*(tp->ptr_ucode + UCODE_VERSION_OFFSET) < UCODE_VERSION)) +        if (!fw->data +                || (*(fw->data + UCODE_VERSION_OFFSET) < UCODE_VERSION))          { -                return (UCODE_NOT_PRESENT); +                err = (UCODE_NOT_PRESENT); +		goto out;          }          /* UCODE_SIZE is not included in Checksum. */ -        for(i = 0; i < *((__u16 *)(tp->ptr_ucode + UCODE_SIZE_OFFSET)); i += 2) -                checksum += *((__u16 *)(tp->ptr_ucode + 2 + i)); -        if(checksum) -                return (UCODE_NOT_PRESENT); +        for(i = 0; i < *((__u16 *)(fw->data + UCODE_SIZE_OFFSET)); i += 2) +                checksum += *((__u16 *)(fw->data + 2 + i)); +        if (checksum) { +		err = (UCODE_NOT_PRESENT); +		goto out; +	}          /* At this point we have a valid firmware image, lets kick it on up. */          smctr_enable_adapter_ram(dev); @@ -2998,7 +3010,7 @@ static int smctr_load_firmware(struct net_device *dev)          smctr_set_page(dev, (__u8 *)tp->ram_access);          if((smctr_checksum_firmware(dev)) -                || (*(tp->ptr_ucode + UCODE_VERSION_OFFSET) +                || (*(fw->data + UCODE_VERSION_OFFSET)                  > tp->microcode_version))          {                  smctr_enable_adapter_ctrl_store(dev); @@ -3007,9 +3019,9 @@ static int smctr_load_firmware(struct net_device *dev)                  for(i = 0; i < CS_RAM_SIZE; i += 2)                          *((__u16 *)(tp->ram_access + i)) = 0; -                smctr_decode_firmware(dev); +                smctr_decode_firmware(dev, fw); -                tp->microcode_version = *(tp->ptr_ucode + UCODE_VERSION_OFFSET);                *((__u16 *)(tp->ram_access + CS_RAM_VERSION_OFFSET)) +                tp->microcode_version = *(fw->data + UCODE_VERSION_OFFSET);                *((__u16 *)(tp->ram_access + CS_RAM_VERSION_OFFSET))                          = (tp->microcode_version << 8);                  *((__u16 *)(tp->ram_access + CS_RAM_CHECKSUM_OFFSET))                          = ~(tp->microcode_version << 8) + 1; @@ -3023,7 +3035,8 @@ static int smctr_load_firmware(struct net_device *dev)                  err = UCODE_PRESENT;          smctr_disable_16bit(dev); - + out: +	release_firmware(fw);          return (err);  } @@ -5651,6 +5664,7 @@ static int io[SMCTR_MAX_ADAPTERS];  static int irq[SMCTR_MAX_ADAPTERS];  MODULE_LICENSE("GPL"); +MODULE_FIRMWARE("tr_smctr.bin");  module_param_array(io, int, NULL, 0);  module_param_array(irq, int, NULL, 0); diff --git a/drivers/net/tokenring/smctr.h b/drivers/net/tokenring/smctr.h index 88dfa2e01d6..52df7dd815c 100644 --- a/drivers/net/tokenring/smctr.h +++ b/drivers/net/tokenring/smctr.h @@ -1042,8 +1042,6 @@ typedef struct net_local {          __u16            functional_address[2];          __u16            bitwise_group_address[2]; -	const __u8       *ptr_ucode; -  	__u8		cleanup;  	struct sk_buff_head SendSkbQueue; diff --git a/drivers/net/tokenring/smctr_firmware.h b/drivers/net/tokenring/smctr_firmware.h deleted file mode 100644 index 292e50ddf01..00000000000 --- a/drivers/net/tokenring/smctr_firmware.h +++ /dev/null @@ -1,978 +0,0 @@ -/* - * The firmware this driver downloads into the tokenring card is a - * separate program and is not GPL'd source code, even though the Linux - * side driver and the routine that loads this data into the card are. - * - * This firmware is licensed to you strictly for use in conjunction - * with the use of SMC TokenRing adapters. There is no waranty - * expressed or implied about its fitness for any purpose. - */ - -/* smctr_firmware.h: SMC TokenRing driver firmware dump for Linux. - * - * Notes: - *  - This is an 8K binary image. (MCT.BIN v6.3C1 03/01/95) - * - * Authors: - *  - Jay Schulist <jschlst@samba.org> - */ - - -#if defined(CONFIG_SMCTR) || defined(CONFIG_SMCTR_MODULE) - -static const unsigned char smctr_code[] = { -	0x0BC, 0x01D, 0x012, 0x03B, 0x063, 0x0B4, 0x0E9, 0x000, -	0x000, 0x01F, 0x000, 0x001, 0x001, 0x000, 0x002, 0x005, -	0x001, 0x000, 0x006, 0x003, 0x001, 0x000, 0x004, 0x009, -	0x001, 0x000, 0x00A, 0x007, 0x001, 0x000, 0x008, 0x00B, -	0x001, 0x000, 0x00C, 0x000, 0x000, 0x000, 0x000, 0x00F, -	0x001, 0x000, 0x010, 0x00D, 0x001, 0x000, 0x00E, 0x013, -	0x001, 0x000, 0x014, 0x011, 0x001, 0x000, 0x012, 0x000, -	0x000, 0x005, 0x000, 0x015, 0x001, 0x000, 0x016, 0x019, -	0x001, 0x000, 0x01A, 0x017, 0x001, 0x000, 0x018, 0x000, -	0x000, 0x00E, 0x000, 0x000, 0x000, 0x001, 0x000, 0x000, -	0x000, 0x004, 0x000, 0x01B, 0x001, 0x000, 0x01C, 0x000, -	0x000, 0x007, 0x000, 0x000, 0x000, 0x00F, 0x000, 0x000, -	0x000, 0x00B, 0x000, 0x01D, 0x001, 0x000, 0x01E, 0x000, -	0x000, 0x008, 0x000, 0x000, 0x000, 0x002, 0x000, 0x000, -	0x000, 0x00C, 0x000, 0x000, 0x000, 0x006, 0x000, 0x000, -	0x000, 0x00D, 0x000, 0x000, 0x000, 0x003, 0x000, 0x000, -	0x000, 0x00A, 0x000, 0x000, 0x000, 0x009, 0x000, 0x004, -	0x078, 0x0C6, 0x0BC, 0x001, 0x094, 0x004, 0x093, 0x080, -	0x0C8, 0x040, 0x062, 0x0E9, 0x0DA, 0x01C, 0x02C, 0x015, -	0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x058, -	0x00B, 0x0E9, 0x0E5, 0x0D5, 0x095, 0x0C1, 0x09D, 0x077, -	0x0CE, 0x0BB, 0x0A0, 0x06E, 0x01C, 0x005, 0x0F6, 0x077, -	0x0C6, 0x002, 0x0FA, 0x096, 0x070, 0x0E8, 0x01D, 0x0C0, -	0x017, 0x00E, 0x002, 0x0FA, 0x058, 0x07D, 0x0C0, 0x05F, -	0x072, 0x0CE, 0x0EC, 0x0A4, 0x0C3, 0x084, 0x090, 0x07A, -	0x030, 0x0CD, 0x08D, 0x079, 0x019, 0x0E7, 0x06C, 0x024, -	0x027, 0x09C, 0x008, 0x039, 0x007, 0x038, 0x0A8, 0x04A, -	0x04C, 0x0EA, 0x04D, 0x098, 0x09B, 0x024, 0x04C, 0x0C0, -	0x026, 0x0D3, 0x0E7, 0x054, 0x05A, 0x04D, 0x0F2, 0x04C, -	0x00C, 0x013, 0x023, 0x049, 0x090, 0x032, 0x06E, 0x0A4, -	0x0DF, 0x093, 0x071, 0x013, 0x077, 0x026, 0x0E1, 0x026, -	0x0F8, 0x026, 0x00C, 0x04C, 0x012, 0x026, 0x008, 0x009, -	0x082, 0x082, 0x060, 0x0A9, 0x030, 0x079, 0x036, 0x0B0, -	0x0B2, 0x0A8, 0x0A7, 0x072, 0x064, 0x08F, 0x09B, 0x033, -	0x033, 0x0F9, 0x0B8, 0x039, 0x0D5, 0x011, 0x073, 0x0AA, -	0x075, 0x026, 0x05D, 0x026, 0x051, 0x093, 0x02A, 0x049, -	0x094, 0x0C9, 0x095, 0x089, 0x0BC, 0x04D, 0x0C8, 0x09B, -	0x080, 0x09B, 0x0A0, 0x099, 0x006, 0x04C, 0x086, 0x026, -	0x058, 0x09B, 0x0A4, 0x09B, 0x099, 0x037, 0x062, 0x06C, -	0x067, 0x09B, 0x033, 0x030, 0x0BF, 0x036, 0x066, 0x061, -	0x0BF, 0x036, 0x0EC, 0x0C5, 0x0BD, 0x066, 0x082, 0x05A, -	0x050, 0x031, 0x0D5, 0x09D, 0x098, 0x018, 0x029, 0x03C, -	0x098, 0x086, 0x04C, 0x017, 0x026, 0x03E, 0x02C, 0x0B8, -	0x069, 0x03B, 0x049, 0x02E, 0x0B4, 0x008, 0x043, 0x01A, -	0x0A4, 0x0F9, 0x0B3, 0x051, 0x0F1, 0x010, 0x0F3, 0x043, -	0x0CD, 0x008, 0x06F, 0x063, 0x079, 0x0B3, 0x033, 0x00E, -	0x013, 0x098, 0x049, 0x098, 0x004, 0x0DA, 0x07C, 0x0E0, -	0x052, 0x079, 0x031, 0x00C, 0x098, 0x02E, 0x04D, 0x0AC, -	0x02C, 0x084, 0x014, 0x0EE, 0x04C, 0x0FE, 0x067, 0x05E, -	0x0E4, 0x09A, 0x075, 0x029, 0x0D7, 0x0A9, 0x035, 0x03A, -	0x094, 0x05B, 0x0D5, 0x09B, 0x058, 0x0B4, 0x0AF, 0x075, -	0x066, 0x0AF, 0x014, 0x0A9, 0x0EF, 0x040, 0x095, 0x025, -	0x008, 0x0B9, 0x0AD, 0x042, 0x0FC, 0x0D8, 0x0D9, 0x08C, -	0x033, 0x00E, 0x013, 0x098, 0x066, 0x01E, 0x045, 0x0AC, -	0x0B0, 0x00C, 0x042, 0x0D3, 0x0CC, 0x0A6, 0x012, 0x062, -	0x0DE, 0x0B4, 0x0B1, 0x080, 0x049, 0x07D, 0x0A2, 0x0DE, -	0x0B4, 0x018, 0x0C0, 0x024, 0x084, 0x0E6, 0x054, 0x0F5, -	0x083, 0x046, 0x001, 0x068, 0x01A, 0x063, 0x00C, 0x0C6, -	0x012, 0x064, 0x0FA, 0x04C, 0x035, 0x01C, 0x02C, 0x00E, -	0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, -	0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AD, 0x0D7, 0x002, -	0x070, 0x0E0, 0x04C, 0x0F3, 0x0A1, 0x0C1, 0x0D5, 0x0C0, -	0x03C, 0x0B9, 0x069, 0x039, 0x060, 0x04E, 0x058, 0x077, -	0x002, 0x067, 0x093, 0x03C, 0x099, 0x0E4, 0x0CF, 0x038, -	0x01C, 0x097, 0x02E, 0x040, 0x01B, 0x090, 0x031, 0x046, -	0x0A3, 0x05E, 0x00E, 0x088, 0x034, 0x06A, 0x035, 0x0E0, -	0x0E8, 0x0AA, 0x035, 0x01A, 0x0A9, 0x0F5, 0x015, 0x046, -	0x0A3, 0x0EA, 0x07D, 0x04A, 0x0A3, 0x051, 0x0AA, 0x09F, -	0x070, 0x054, 0x0A6, 0x057, 0x02E, 0x0B4, 0x0CD, 0x0C8, -	0x0A3, 0x00C, 0x0C1, 0x0DA, 0x0C6, 0x0E1, 0x0CB, 0x07A, -	0x0D4, 0x01C, 0x068, 0x0FF, 0x0CF, 0x055, 0x0A8, 0x0C0, -	0x02D, 0x085, 0x011, 0x017, 0x044, 0x02A, 0x030, 0x00B, -	0x04A, 0x088, 0x0C2, 0x04D, 0x0B5, 0x020, 0x0D5, 0x026, -	0x001, 0x069, 0x051, 0x069, 0x052, 0x019, 0x052, 0x060, -	0x016, 0x095, 0x016, 0x082, 0x096, 0x054, 0x098, 0x005, -	0x0A5, 0x045, 0x0F3, 0x0DD, 0x06A, 0x0F9, 0x028, 0x018, -	0x0EF, 0x000, 0x030, 0x030, 0x051, 0x04E, 0x044, 0x05D, -	0x012, 0x0D1, 0x043, 0x0E6, 0x012, 0x06F, 0x09E, 0x0BA, -	0x0CC, 0x0DF, 0x025, 0x003, 0x01D, 0x0E0, 0x006, 0x006, -	0x00A, 0x030, 0x0CC, 0x0A9, 0x0EB, 0x02D, 0x000, 0x086, -	0x0A6, 0x012, 0x065, 0x04F, 0x056, 0x0D6, 0x065, 0x049, -	0x05F, 0x03D, 0x0E8, 0x037, 0x0C9, 0x040, 0x0C7, 0x078, -	0x001, 0x081, 0x082, 0x08C, 0x033, 0x018, 0x049, 0x080, -	0x0AE, 0x040, 0x0C5, 0x018, 0x005, 0x09C, 0x06D, 0x018, -	0x066, 0x00E, 0x0F3, 0x0A0, 0x0C6, 0x012, 0x062, 0x0DE, -	0x0F5, 0x004, 0x0B4, 0x0AC, 0x06B, 0x0C6, 0x019, 0x091, -	0x073, 0x005, 0x048, 0x02E, 0x072, 0x094, 0x080, 0x073, -	0x0A1, 0x0C8, 0x047, 0x036, 0x066, 0x064, 0x02F, 0x036, -	0x066, 0x064, 0x007, 0x099, 0x002, 0x091, 0x08E, 0x072, -	0x0D1, 0x00F, 0x09D, 0x006, 0x031, 0x073, 0x0A0, 0x0C3, -	0x051, 0x06A, 0x01A, 0x020, 0x0BF, 0x03A, 0x00C, 0x02C, -	0x073, 0x087, 0x043, 0x05E, 0x060, 0x002, 0x023, 0x0FC, -	0x0E0, 0x0D6, 0x035, 0x0EF, 0x09E, 0x0F5, 0x0EF, 0x092, -	0x081, 0x08E, 0x0F0, 0x003, 0x003, 0x005, 0x018, 0x066, -	0x045, 0x0CC, 0x00B, 0x048, 0x02E, 0x070, 0x00A, 0x040, -	0x039, 0x0D0, 0x0E4, 0x023, 0x09B, 0x033, 0x032, 0x017, -	0x09B, 0x033, 0x032, 0x003, 0x0CC, 0x085, 0x048, 0x0C7, -	0x038, 0x014, 0x0A5, 0x0CE, 0x029, 0x07E, 0x0D2, 0x080, -	0x0A1, 0x0A8, 0x0B4, 0x048, 0x088, 0x02F, 0x0CE, 0x083, -	0x00B, 0x01C, 0x0E1, 0x0D0, 0x0D7, 0x098, 0x004, 0x088, -	0x087, 0x0CE, 0x096, 0x031, 0x073, 0x0A5, 0x08F, 0x0F3, -	0x083, 0x058, 0x0D7, 0x0BE, 0x07B, 0x082, 0x0AF, 0x092, -	0x081, 0x08E, 0x0F0, 0x003, 0x003, 0x005, 0x018, 0x066, -	0x045, 0x0CC, 0x015, 0x020, 0x0B9, 0x0C8, 0x029, 0x000, -	0x0E7, 0x043, 0x090, 0x08E, 0x06C, 0x0CC, 0x0C8, 0x05E, -	0x06C, 0x0CC, 0x0C8, 0x00F, 0x032, 0x005, 0x023, 0x01C, -	0x0E4, 0x050, 0x0D4, 0x05A, 0x017, 0x088, 0x02F, 0x0CE, -	0x083, 0x010, 0x0F9, 0x0D0, 0x023, 0x017, 0x03A, 0x004, -	0x035, 0x0E6, 0x000, 0x022, 0x016, 0x039, 0x0C3, 0x0A3, -	0x0FC, 0x0E0, 0x0D6, 0x035, 0x0E0, 0x0BF, 0x0F4, 0x018, -	0x0F2, 0x02D, 0x04D, 0x043, 0x051, 0x06E, 0x05A, 0x022, -	0x01F, 0x030, 0x0D4, 0x017, 0x0E7, 0x041, 0x091, 0x073, -	0x005, 0x048, 0x02E, 0x077, 0x069, 0x000, 0x0E7, 0x043, -	0x090, 0x08E, 0x06C, 0x0CC, 0x0C8, 0x05E, 0x06C, 0x0CC, -	0x0C8, 0x00F, 0x032, 0x005, 0x023, 0x01C, 0x0EF, 0x04C, -	0x04E, 0x006, 0x004, 0x0C9, 0x09E, 0x00B, 0x0FF, 0x041, -	0x08F, 0x022, 0x0D4, 0x0D4, 0x035, 0x016, 0x0E5, 0x0A2, -	0x021, 0x0F3, 0x05A, 0x082, 0x0FC, 0x0E8, 0x032, 0x02E, -	0x060, 0x0A9, 0x005, 0x0CE, 0x013, 0x048, 0x007, 0x03A, -	0x01C, 0x084, 0x073, 0x066, 0x066, 0x042, 0x0F3, 0x066, -	0x066, 0x040, 0x079, 0x090, 0x029, 0x018, 0x0E7, 0x00A, -	0x098, 0x09C, 0x00A, 0x09E, 0x0B5, 0x012, 0x05C, 0x07C, -	0x0C3, 0x031, 0x08B, 0x098, 0x02A, 0x07C, 0x0D3, 0x0ED, -	0x038, 0x0E9, 0x0D3, 0x04E, 0x074, 0x0ED, 0x049, 0x09E, -	0x00B, 0x0FF, 0x041, 0x08F, 0x022, 0x0D4, 0x0D4, 0x035, -	0x016, 0x0E5, 0x0A2, 0x02D, 0x0EB, 0x045, 0x033, 0x08F, -	0x0FC, 0x0F7, 0x0A0, 0x05F, 0x025, 0x003, 0x01D, 0x0E4, -	0x00E, 0x006, 0x00A, 0x030, 0x0CC, 0x00C, 0x0F3, 0x0EB, -	0x040, 0x0DE, 0x061, 0x0A8, 0x070, 0x092, 0x00A, 0x000, -	0x0E1, 0x024, 0x01E, 0x000, 0x0E1, 0x024, 0x01E, 0x000, -	0x0E1, 0x024, 0x01E, 0x000, 0x0E1, 0x024, 0x01E, 0x000, -	0x0E1, 0x024, 0x01E, 0x001, 0x00F, 0x098, 0x02A, 0x00B, -	0x0F3, 0x0A0, 0x0C8, 0x0B9, 0x0A2, 0x0A4, 0x017, 0x03A, -	0x069, 0x000, 0x0E7, 0x043, 0x090, 0x08E, 0x075, 0x048, -	0x05E, 0x070, 0x069, 0x001, 0x0E6, 0x000, 0x052, 0x031, -	0x0CC, 0x018, 0x014, 0x0A5, 0x0CC, 0x009, 0x082, 0x094, -	0x073, 0x00C, 0x0A0, 0x091, 0x0F5, 0x025, 0x0CC, 0x007, -	0x006, 0x084, 0x084, 0x09F, 0x030, 0x0A2, 0x0A4, 0x07D, -	0x050, 0x075, 0x0A6, 0x065, 0x001, 0x04A, 0x08E, 0x0B4, -	0x0CC, 0x0C4, 0x035, 0x054, 0x075, 0x066, 0x0A4, 0x097, -	0x07A, 0x089, 0x050, 0x053, 0x013, 0x080, 0x019, 0x0E3, -	0x049, 0x05C, 0x06D, 0x0CE, 0x0A9, 0x040, 0x035, 0x006, -	0x078, 0x0D2, 0x057, 0x006, 0x0F1, 0x0B3, 0x02A, 0x08D, -	0x097, 0x023, 0x062, 0x092, 0x05D, 0x069, 0x099, 0x01C, -	0x06A, 0x036, 0x0E6, 0x0CD, 0x046, 0x012, 0x06F, 0x09E, -	0x0E1, 0x0AB, 0x0E4, 0x0A3, 0x00C, 0x0C0, 0x0DE, 0x0AC, -	0x0D4, 0x00D, 0x028, 0x01B, 0x0D0, 0x012, 0x0A5, 0x000, -	0x0F8, 0x04B, 0x0AD, 0x033, 0x028, 0x006, 0x0A0, 0x0DE, -	0x014, 0x097, 0x03A, 0x089, 0x05D, 0x0C0, 0x00D, 0x0E3, -	0x006, 0x090, 0x092, 0x05D, 0x069, 0x098, 0x066, 0x0B9, -	0x019, 0x095, 0x0E4, 0x0A8, 0x0CF, 0x09D, 0x033, 0x018, -	0x049, 0x0BE, 0x07B, 0x086, 0x0AF, 0x092, 0x08C, 0x033, -	0x024, 0x014, 0x00C, 0x0F4, 0x083, 0x024, 0x021, 0x0C2, -	0x070, 0x0BF, 0x0F4, 0x018, 0x0F2, 0x02D, 0x04D, 0x043, -	0x051, 0x06E, 0x05A, 0x022, 0x01F, 0x032, 0x0A8, 0x02F, -	0x0CE, 0x083, 0x022, 0x0E6, 0x005, 0x0A4, 0x017, 0x03A, -	0x069, 0x000, 0x0E7, 0x043, 0x090, 0x08E, 0x075, 0x048, -	0x05E, 0x070, 0x069, 0x001, 0x0E6, 0x042, 0x0A4, 0x063, -	0x098, 0x002, 0x029, 0x04B, 0x09A, 0x029, 0x078, 0x0E9, -	0x040, 0x053, 0x013, 0x081, 0x081, 0x032, 0x067, 0x082, -	0x0FF, 0x0D0, 0x063, 0x0C8, 0x0B5, 0x035, 0x00D, 0x045, -	0x0AE, 0x050, 0x008, 0x07C, 0x0E0, 0x0D0, 0x05F, 0x09D, -	0x006, 0x045, 0x0CC, 0x001, 0x0A4, 0x017, 0x03A, 0x069, -	0x000, 0x0E7, 0x043, 0x090, 0x08E, 0x075, 0x048, 0x05E, -	0x070, 0x069, 0x001, 0x0E6, 0x059, 0x0A4, 0x063, 0x098, -	0x01C, 0x052, 0x097, 0x03B, 0x030, 0x052, 0x08E, 0x07D, -	0x02A, 0x009, 0x01F, 0x051, 0x0EB, 0x0A4, 0x0A4, 0x00A, -	0x0B9, 0x094, 0x087, 0x0AE, 0x0C5, 0x031, 0x038, 0x002, -	0x0FF, 0x0D0, 0x063, 0x0C8, 0x0B5, 0x035, 0x00D, 0x045, -	0x0AE, 0x050, 0x008, 0x07C, 0x0EA, 0x020, 0x0BF, 0x03A, -	0x00C, 0x08B, 0x09A, 0x016, 0x090, 0x05C, 0x0E9, 0x0A4, -	0x003, 0x09D, 0x00E, 0x042, 0x039, 0x0D5, 0x021, 0x079, -	0x095, 0x048, 0x00F, 0x030, 0x00A, 0x091, 0x08E, 0x060, -	0x0EB, 0x029, 0x073, 0x000, 0x009, 0x054, 0x004, 0x0CA, -	0x082, 0x065, 0x052, 0x065, 0x0E4, 0x0CA, 0x022, 0x065, -	0x072, 0x065, 0x009, 0x032, 0x0E0, 0x099, 0x072, 0x04C, -	0x0C4, 0x0E0, 0x00B, 0x0FF, 0x041, 0x08F, 0x022, 0x0D4, -	0x0D4, 0x035, 0x016, 0x0B9, 0x040, 0x021, 0x0F3, 0x08A, -	0x082, 0x0FC, 0x0E8, 0x032, 0x02E, 0x060, 0x0A9, 0x005, -	0x0CE, 0x09A, 0x040, 0x039, 0x0D0, 0x0E4, 0x023, 0x09D, -	0x052, 0x017, 0x099, 0x054, 0x061, 0x099, 0x001, 0x0E6, -	0x040, 0x0A4, 0x063, 0x098, 0x004, 0x0B1, 0x084, 0x098, -	0x018, 0x0EF, 0x02D, 0x003, 0x005, 0x031, 0x038, 0x002, -	0x0FF, 0x0D0, 0x063, 0x0C8, 0x0B5, 0x035, 0x00D, 0x045, -	0x0B9, 0x068, 0x088, 0x07C, 0x0E0, 0x050, 0x05F, 0x09D, -	0x006, 0x045, 0x0CC, 0x081, 0x048, 0x02E, 0x071, 0x034, -	0x08F, 0x048, 0x001, 0x048, 0x015, 0x021, 0x005, 0x021, -	0x0E9, 0x00A, 0x052, 0x003, 0x0CE, 0x05A, 0x046, 0x039, -	0x0CF, 0x047, 0x08E, 0x060, 0x0AB, 0x01A, 0x0F3, 0x053, -	0x043, 0x0EB, 0x035, 0x024, 0x0B8, 0x01B, 0x030, 0x007, -	0x009, 0x08A, 0x074, 0x02F, 0x07E, 0x041, 0x074, 0x01E, -	0x01D, 0x00D, 0x087, 0x046, 0x049, 0x0D5, 0x095, 0x0D1, -	0x0D5, 0x0D5, 0x0BB, 0x0A9, 0x04E, 0x082, 0x09D, 0x005, -	0x03A, 0x00A, 0x074, 0x014, 0x0E8, 0x029, 0x0D0, 0x042, -	0x074, 0x05B, 0x0CE, 0x050, 0x0C4, 0x007, 0x045, 0x0BC, -	0x0E2, 0x00C, 0x040, 0x074, 0x05B, 0x0CE, 0x083, 0x004, -	0x0F9, 0x095, 0x04D, 0x013, 0x063, 0x05E, 0x06F, 0x031, -	0x03B, 0x0A0, 0x08B, 0x0A2, 0x0C5, 0x039, 0x08D, 0x078, -	0x03A, 0x022, 0x0A0, 0x000, 0x06B, 0x0C1, 0x0D1, 0x054, -	0x060, 0x016, 0x0D9, 0x091, 0x0A2, 0x0E7, 0x043, 0x08C, -	0x024, 0x0DC, 0x01C, 0x0E0, 0x051, 0x017, 0x039, 0x06B, -	0x03B, 0x0CC, 0x04B, 0x042, 0x02E, 0x06B, 0x050, 0x0BF, -	0x036, 0x036, 0x065, 0x04F, 0x07A, 0x018, 0x055, 0x025, -	0x078, 0x098, 0x023, 0x0E7, 0x050, 0x03E, 0x0F3, 0x081, -	0x04C, 0x002, 0x06D, 0x03E, 0x071, 0x053, 0x0AF, 0x078, -	0x0A9, 0x0D4, 0x0A6, 0x029, 0x0B1, 0x0BC, 0x0D9, 0x099, -	0x0B2, 0x08E, 0x062, 0x08F, 0x022, 0x02E, 0x075, 0x016, -	0x0B0, 0x0B2, 0x0AB, 0x023, 0x028, 0x016, 0x054, 0x052, -	0x031, 0x0BC, 0x0D9, 0x099, 0x0B2, 0x08E, 0x066, 0x019, -	0x002, 0x02E, 0x075, 0x016, 0x050, 0x02C, 0x0A9, 0x0C8, -	0x0C6, 0x0F5, 0x020, 0x0D3, 0x0E4, 0x07F, 0x04F, 0x09C, -	0x00A, 0x0D6, 0x016, 0x07F, 0x090, 0x0EE, 0x04C, 0x0EB, -	0x0CF, 0x0E2, 0x088, 0x0BA, 0x02F, 0x042, 0x086, 0x0AE, -	0x0BD, 0x0E5, 0x0A7, 0x052, 0x09F, 0x093, 0x063, 0x079, -	0x0EB, 0x033, 0x008, 0x0F9, 0x094, 0x052, 0x047, 0x0CD, -	0x099, 0x025, 0x06F, 0x03A, 0x00C, 0x013, 0x0E6, 0x055, -	0x034, 0x04C, 0x05A, 0x04D, 0x0B5, 0x023, 0x095, 0x0A5, -	0x048, 0x011, 0x05A, 0x00A, 0x043, 0x095, 0x0AC, 0x02C, -	0x0BA, 0x024, 0x005, 0x049, 0x0B1, 0x0BC, 0x0CA, 0x0A7, -	0x072, 0x06C, 0x06B, 0x0C5, 0x0BD, 0x0E8, 0x031, 0x069, -	0x052, 0x05D, 0x006, 0x012, 0x065, 0x03E, 0x0B1, 0x050, -	0x04C, 0x07D, 0x04F, 0x0AC, 0x00A, 0x030, 0x00B, 0x036, -	0x064, 0x011, 0x073, 0x08A, 0x083, 0x08E, 0x075, 0x012, -	0x09F, 0x07B, 0x0D2, 0x099, 0x058, 0x0EE, 0x082, 0x02E, -	0x077, 0x0A0, 0x0E3, 0x09D, 0x05D, 0x04F, 0x0BC, 0x02A, -	0x053, 0x029, 0x053, 0x0DE, 0x093, 0x024, 0x0BA, 0x0B3, -	0x036, 0x0AA, 0x04A, 0x0C6, 0x079, 0x0D4, 0x0B9, 0x0DE, -	0x062, 0x05A, 0x011, 0x073, 0x050, 0x050, 0x0BF, 0x037, -	0x036, 0x06F, 0x013, 0x023, 0x0BA, 0x00C, 0x024, 0x0CE, -	0x0BD, 0x0E2, 0x0A7, 0x052, 0x0B2, 0x08E, 0x06B, 0x060, -	0x062, 0x02E, 0x075, 0x013, 0x030, 0x0AC, 0x0A0, 0x059, -	0x0CA, 0x064, 0x063, 0x079, 0x0B3, 0x033, 0x065, 0x01C, -	0x0CC, 0x032, 0x004, 0x05C, 0x0EA, 0x02C, 0x0A0, 0x059, -	0x0DF, 0x023, 0x01B, 0x0D4, 0x083, 0x052, 0x047, 0x0DD, -	0x079, 0x096, 0x0D4, 0x09E, 0x0B3, 0x052, 0x04B, 0x0A2, -	0x05A, 0x01A, 0x08D, 0x05D, 0x07B, 0x082, 0x0A7, 0x052, -	0x0B2, 0x08E, 0x066, 0x019, 0x002, 0x02E, 0x075, 0x016, -	0x050, 0x02C, 0x08C, 0x032, 0x01D, 0x07B, 0x08E, 0x0A7, -	0x052, 0x0B1, 0x0BC, 0x0D9, 0x099, 0x098, 0x004, 0x0DA, -	0x07C, 0x0E2, 0x0AC, 0x0FE, 0x066, 0x019, 0x002, 0x02E, -	0x065, 0x050, 0x0BF, 0x033, 0x066, 0x064, 0x0FE, 0x074, -	0x018, 0x086, 0x04C, 0x017, 0x026, 0x0D6, 0x016, 0x052, -	0x039, 0x018, 0x0DE, 0x07A, 0x0CC, 0x0C2, 0x03E, 0x065, -	0x014, 0x091, 0x0F3, 0x066, 0x049, 0x008, 0x06E, 0x083, -	0x009, 0x033, 0x0AF, 0x031, 0x0ED, 0x00D, 0x09D, 0x006, -	0x012, 0x062, 0x02A, 0x031, 0x08D, 0x06D, 0x0E7, 0x041, -	0x082, 0x07C, 0x0CA, 0x0A6, 0x089, 0x087, 0x009, 0x02E, -	0x029, 0x0B1, 0x0AF, 0x010, 0x039, 0x0D6, 0x064, 0x097, -	0x030, 0x01D, 0x042, 0x075, 0x093, 0x044, 0x002, 0x08C, -	0x024, 0x0D2, 0x07A, 0x0B3, 0x050, 0x0F6, 0x089, 0x005, -	0x043, 0x05E, 0x061, 0x098, 0x0C0, 0x02C, 0x092, 0x025, -	0x03C, 0x08B, 0x024, 0x089, 0x049, 0x005, 0x049, 0x0E7, -	0x00C, 0x0B9, 0x084, 0x098, 0x0B7, 0x0AD, 0x033, 0x044, -	0x0AE, 0x05A, 0x051, 0x086, 0x060, 0x09F, 0x038, 0x0A9, -	0x0A2, 0x06C, 0x06B, 0x0C4, 0x08E, 0x0F4, 0x05E, 0x049, -	0x046, 0x012, 0x062, 0x0DE, 0x0B4, 0x0CD, 0x021, 0x05C, -	0x0B4, 0x0A3, 0x00C, 0x0C1, 0x03E, 0x072, 0x029, 0x0A2, -	0x06C, 0x06B, 0x0C6, 0x012, 0x062, 0x047, 0x0F0, 0x0E8, -	0x0C3, 0x032, 0x004, 0x035, 0x040, 0x092, 0x0A4, 0x082, -	0x088, 0x010, 0x092, 0x07C, 0x0CB, 0x0D4, 0x02F, 0x0A4, -	0x002, 0x011, 0x084, 0x098, 0x0B7, 0x0AD, 0x033, 0x044, -	0x0AE, 0x05A, 0x051, 0x086, 0x060, 0x09F, 0x038, 0x0A9, -	0x0A2, 0x06C, 0x06B, 0x0C4, 0x08E, 0x0F4, 0x05E, 0x049, -	0x044, 0x008, 0x049, 0x03E, 0x065, 0x0EA, 0x017, 0x0D2, -	0x001, 0x008, 0x0C2, 0x04C, 0x05B, 0x0D6, 0x099, 0x0A4, -	0x02B, 0x096, 0x094, 0x061, 0x098, 0x027, 0x0CE, 0x045, -	0x034, 0x04D, 0x08D, 0x078, 0x081, 0x009, 0x027, 0x0CC, -	0x0BD, 0x012, 0x028, 0x06C, 0x058, 0x0AF, 0x0B6, 0x0F3, -	0x0A0, 0x0C1, 0x03E, 0x065, 0x053, 0x044, 0x0D8, 0x0D7, -	0x092, 0x08E, 0x07D, 0x04B, 0x0C2, 0x0FA, 0x061, 0x026, -	0x006, 0x03A, 0x0B3, 0x06B, 0x003, 0x005, 0x049, 0x0E7, -	0x00C, 0x0B9, 0x06F, 0x05A, 0x066, 0x095, 0x05C, 0x0B4, -	0x0A3, 0x00C, 0x0C1, 0x03E, 0x070, 0x029, 0x0A2, 0x06E, -	0x0A4, 0x0DF, 0x093, 0x071, 0x013, 0x077, 0x026, 0x0E1, -	0x026, 0x0F8, 0x026, 0x0C6, 0x0BC, 0x094, 0x073, 0x0F9, -	0x02F, 0x00B, 0x0E9, 0x084, 0x098, 0x018, 0x0EA, 0x0CC, -	0x0EC, 0x00C, 0x015, 0x027, 0x09C, 0x032, 0x0FF, 0x03D, -	0x056, 0x0AF, 0x092, 0x08B, 0x07A, 0x0D3, 0x035, 0x0D5, -	0x0CB, 0x04A, 0x030, 0x0CC, 0x013, 0x0E7, 0x002, 0x09A, -	0x026, 0x0C6, 0x0BC, 0x094, 0x073, 0x041, 0x097, 0x091, -	0x0F4, 0x083, 0x0CE, 0x004, 0x020, 0x062, 0x08B, 0x005, -	0x016, 0x049, 0x08C, 0x024, 0x0C0, 0x0C7, 0x056, 0x090, -	0x0C0, 0x0C1, 0x052, 0x079, 0x0C3, 0x02E, 0x05B, 0x0D5, -	0x0A6, 0x072, 0x0D2, 0x094, 0x0FA, 0x0AD, 0x058, 0x0C8, -	0x0FA, 0x09F, 0x054, 0x0B3, 0x032, 0x04B, 0x0B9, 0x054, -	0x0A6, 0x051, 0x086, 0x06B, 0x079, 0x0D0, 0x060, 0x09F, -	0x032, 0x005, 0x034, 0x04D, 0x08D, 0x07A, 0x04D, 0x01E, -	0x07A, 0x0B3, 0x051, 0x000, 0x0A9, 0x03D, 0x059, 0x0A8, -	0x07B, 0x044, 0x082, 0x0A1, 0x0AF, 0x04A, 0x08D, 0x052, -	0x0A9, 0x052, 0x041, 0x049, 0x04F, 0x03A, 0x02E, 0x040, -	0x0A4, 0x099, 0x050, 0x0BE, 0x090, 0x008, 0x052, 0x079, -	0x0C3, 0x02E, 0x061, 0x026, 0x02D, 0x0EB, 0x04C, 0x0D0, -	0x015, 0x0CB, 0x04A, 0x030, 0x0CC, 0x013, 0x0E7, 0x002, -	0x09A, 0x026, 0x0C6, 0x0BC, 0x048, 0x0FE, 0x01D, 0x025, -	0x046, 0x0A9, 0x054, 0x0A9, 0x020, 0x0A4, 0x0A7, 0x09D, -	0x017, 0x020, 0x052, 0x04C, 0x0A8, 0x05F, 0x048, 0x004, -	0x023, 0x009, 0x031, 0x06F, 0x05A, 0x066, 0x080, 0x0AE, -	0x05A, 0x051, 0x086, 0x060, 0x09F, 0x038, 0x014, 0x0D1, -	0x036, 0x035, 0x0E4, 0x0A7, 0x09D, 0x017, 0x020, 0x052, -	0x04C, 0x0A2, 0x045, 0x00D, 0x08B, 0x015, 0x0F4, 0x091, -	0x0DE, 0x08B, 0x0C9, 0x028, 0x0C2, 0x04C, 0x05B, 0x0D6, -	0x099, 0x0A9, 0x05C, 0x0B4, 0x0A3, 0x00C, 0x0D6, 0x0F3, -	0x0A0, 0x0C1, 0x03E, 0x064, 0x00A, 0x068, 0x09B, 0x01A, -	0x0F1, 0x06D, 0x04C, 0x0AA, 0x092, 0x0E0, 0x036, 0x094, -	0x070, 0x09B, 0x029, 0x078, 0x013, 0x0AE, 0x0B3, 0x0AA, -	0x085, 0x0D4, 0x043, 0x075, 0x009, 0x03A, 0x0C9, 0x0EB, -	0x035, 0x024, 0x0B8, 0x01B, 0x032, 0x08E, 0x013, 0x048, -	0x07E, 0x04E, 0x0FD, 0x040, 0x0FD, 0x040, 0x0FD, 0x040, -	0x0FD, 0x040, 0x0FD, 0x040, 0x0FC, 0x013, 0x0F4, 0x021, -	0x0F9, 0x017, 0x045, 0x08A, 0x030, 0x00B, 0x033, 0x05F, -	0x083, 0x0A2, 0x02A, 0x030, 0x00B, 0x033, 0x05F, 0x083, -	0x0A2, 0x0A8, 0x0C0, 0x02D, 0x0B3, 0x020, 0x070, 0x092, -	0x013, 0x09A, 0x0DE, 0x074, 0x018, 0x027, 0x0CC, 0x0AA, -	0x068, 0x09B, 0x01A, 0x0F7, 0x007, 0x045, 0x051, 0x080, -	0x05B, 0x066, 0x047, 0x007, 0x038, 0x0A8, 0x023, 0x0E7, -	0x051, 0x011, 0x03F, 0x0E0, 0x0E8, 0x085, 0x046, 0x001, -	0x06D, 0x099, 0x006, 0x012, 0x065, 0x04F, 0x07A, 0x020, -	0x024, 0x0BA, 0x0B3, 0x032, 0x015, 0x025, 0x07B, 0x0AD, -	0x033, 0x078, 0x0AE, 0x00E, 0x073, 0x0D0, 0x047, 0x0CE, -	0x0A7, 0x030, 0x0CC, 0x044, 0x0FF, 0x083, 0x0A2, 0x0A8, -	0x0C0, 0x02C, 0x0D9, 0x091, 0x0C1, 0x0D1, 0x015, 0x018, -	0x005, 0x09B, 0x032, 0x008, 0x0BA, 0x02C, 0x051, 0x080, -	0x059, 0x0B3, 0x020, 0x070, 0x092, 0x0E2, 0x098, 0x089, -	0x0FD, 0x0BC, 0x0EE, 0x018, 0x090, 0x0FC, 0x08B, 0x0A2, -	0x0C5, 0x02B, 0x00D, 0x078, 0x03A, 0x022, 0x0A5, 0x061, -	0x0AF, 0x007, 0x045, 0x051, 0x080, 0x05B, 0x066, 0x044, -	0x09E, 0x0B3, 0x052, 0x04B, 0x083, 0x0AD, 0x0C7, 0x009, -	0x0BE, 0x01F, 0x09F, 0x074, 0x065, 0x05D, 0x00A, 0x017, -	0x07C, 0x0AB, 0x0A0, 0x0C2, 0x04C, 0x038, 0x049, 0x012, -	0x02E, 0x038, 0x049, 0x007, 0x0A3, 0x00C, 0x0C1, 0x03E, -	0x065, 0x053, 0x044, 0x0D8, 0x0D7, 0x0AD, 0x0E7, 0x000, -	0x032, 0x04B, 0x09B, 0x033, 0x034, 0x04A, 0x003, 0x000, -	0x09D, 0x025, 0x0CE, 0x083, 0x024, 0x0B8, 0x019, 0x099, -	0x08C, 0x002, 0x012, 0x04B, 0x0A1, 0x099, 0x0D8, 0x0C0, -	0x027, 0x049, 0x073, 0x0CF, 0x0F9, 0x03C, 0x0F4, 0x07C, -	0x0E7, 0x098, 0x004, 0x0E9, 0x02E, 0x07F, 0x039, 0x0E3, -	0x04F, 0x046, 0x053, 0x0C0, 0x060, 0x013, 0x0A4, 0x0B9, -	0x0E5, 0x03C, 0x003, 0x0DE, 0x08F, 0x09C, 0x0F3, 0x000, -	0x09C, 0x06F, 0x0CF, 0x03E, 0x085, 0x0F9, 0x0A3, 0x036, -	0x002, 0x01E, 0x060, 0x038, 0x092, 0x03E, 0x063, 0x01A, -	0x010, 0x09F, 0x0CF, 0x018, 0x010, 0x092, 0x0BC, 0x0D0, -	0x0A4, 0x00C, 0x0DC, 0x0C0, 0x00F, 0x09C, 0x097, 0x034, -	0x062, 0x0B6, 0x0E7, 0x0F3, 0x0F3, 0x0A5, 0x0CF, 0x018, -	0x042, 0x034, 0x01C, 0x0C2, 0x0CA, 0x0FA, 0x08E, 0x068, -	0x052, 0x006, 0x0AF, 0x03C, 0x0A3, 0x00D, 0x0BF, 0x09E, -	0x050, 0x0E1, 0x0D1, 0x073, 0x0CA, 0x0E0, 0x03A, 0x0FC, -	0x0C1, 0x009, 0x01A, 0x01E, 0x06A, 0x05C, 0x05B, 0x08E, -	0x063, 0x04E, 0x077, 0x073, 0x0CC, 0x061, 0x067, 0x0DD, -	0x0E6, 0x06C, 0x048, 0x0D1, 0x0F3, 0x01B, 0x024, 0x069, -	0x051, 0x008, 0x0D4, 0x042, 0x01B, 0x0F4, 0x067, 0x0D1, -	0x080, 0x04E, 0x02F, 0x0D0, 0x08C, 0x0D8, 0x030, 0x009, -	0x0C2, 0x01E, 0x080, 0x01C, 0x046, 0x001, 0x03A, 0x047, -	0x0D0, 0x031, 0x0A1, 0x006, 0x001, 0x03A, 0x07F, 0x046, -	0x030, 0x021, 0x018, 0x004, 0x0E9, 0x05E, 0x084, 0x029, -	0x000, 0x0C0, 0x027, 0x0CD, 0x0D0, 0x000, 0x07C, 0x098, -	0x004, 0x0F9, 0x02E, 0x084, 0x062, 0x08C, 0x002, 0x07D, -	0x0BA, 0x03E, 0x07E, 0x04C, 0x002, 0x07D, 0x02E, 0x08C, -	0x061, 0x008, 0x030, 0x009, 0x0F4, 0x01D, 0x001, 0x065, -	0x073, 0x000, 0x09F, 0x051, 0x0D0, 0x085, 0x020, 0x018, -	0x004, 0x0FA, 0x0BD, 0x019, 0x046, 0x018, 0x0C0, 0x027, -	0x0DF, 0x0D1, 0x094, 0x038, 0x04C, 0x002, 0x07D, 0x017, -	0x046, 0x057, 0x001, 0x030, 0x009, 0x0F5, 0x0FA, 0x001, -	0x009, 0x006, 0x001, 0x03E, 0x087, 0x0A1, 0x04B, 0x088, -	0x0C0, 0x027, 0x0DC, 0x074, 0x00D, 0x039, 0x0D3, 0x000, -	0x09F, 0x073, 0x0D0, 0x030, 0x0B3, 0x098, 0x004, 0x0FB, -	0x0BD, 0x006, 0x0C4, 0x083, 0x000, 0x09F, 0x047, 0x0D0, -	0x036, 0x048, 0x0CC, 0x002, 0x071, 0x0BF, 0x03F, 0x09A, -	0x017, 0x0E6, 0x03F, 0x008, 0x021, 0x0E6, 0x092, 0x0A4, -	0x08F, 0x09A, 0x010, 0x031, 0x0A7, 0x0F3, 0x010, 0x0B1, -	0x084, 0x0AF, 0x03A, 0x0AC, 0x0DC, 0x0F7, 0x073, 0x0F2, -	0x05C, 0x0C6, 0x02A, 0x0DB, 0x09E, 0x07E, 0x07E, 0x097, -	0x031, 0x008, 0x063, 0x0D0, 0x073, 0x07B, 0x043, 0x0A8, -	0x0E6, 0x03D, 0x034, 0x0EA, 0x0F3, 0x0E3, 0x015, 0x0BF, -	0x09F, 0x018, 0x05F, 0x045, 0x0CF, 0x0E8, 0x09F, 0x05F, -	0x09A, 0x05B, 0x003, 0x0D0, 0x0F3, 0x0D3, 0x0CE, 0x037, -	0x01C, 0x0D0, 0x00F, 0x0BB, 0x09E, 0x068, 0x078, 0x03B, -	0x0BC, 0x0CA, 0x031, 0x0E8, 0x0F9, 0x0A2, 0x002, 0x012, -	0x0A2, 0x073, 0x051, 0x008, 0x06F, 0x0D1, 0x0F3, 0x046, -	0x001, 0x038, 0x0BF, 0x040, 0x0FC, 0x023, 0x000, 0x09C, -	0x021, 0x0E8, 0x049, 0x051, 0x080, 0x04E, 0x091, 0x0F4, -	0x021, 0x003, 0x019, 0x080, 0x04E, 0x09F, 0x0D0, 0x021, -	0x063, 0x006, 0x001, 0x03A, 0x056, 0x08C, 0x002, 0x074, -	0x0FE, 0x075, 0x049, 0x05E, 0x063, 0x0D3, 0x04A, 0x054, -	0x042, 0x035, 0x013, 0x0A7, 0x0D1, 0x080, 0x04E, 0x095, -	0x0E8, 0x01E, 0x09A, 0x04C, 0x002, 0x07C, 0x0DD, 0x01B, -	0x0B9, 0x0E6, 0x001, 0x03E, 0x04B, 0x0A0, 0x062, 0x0A3, -	0x000, 0x09F, 0x06E, 0x08C, 0x0FC, 0x0F3, 0x000, 0x09F, -	0x04B, 0x0A0, 0x042, 0x018, 0x0CC, 0x002, 0x07D, 0x007, -	0x043, 0x0DA, 0x013, 0x000, 0x09F, 0x051, 0x0D0, 0x03D, -	0x034, 0x098, 0x004, 0x0FA, 0x0BD, 0x01C, 0x062, 0x08C, -	0x002, 0x07D, 0x0FD, 0x01C, 0x061, 0x073, 0x000, 0x09F, -	0x045, 0x0D1, 0x0F4, 0x04E, 0x060, 0x013, 0x0EB, 0x0F4, -	0x025, 0x0B0, 0x033, 0x000, 0x09F, 0x043, 0x0D1, 0x0A7, -	0x09C, 0x018, 0x004, 0x0FB, 0x08E, 0x084, 0x003, 0x0E9, -	0x080, 0x04F, 0x0B9, 0x0E8, 0x043, 0x0C1, 0x030, 0x009, -	0x0F7, 0x07A, 0x00A, 0x031, 0x098, 0x004, 0x0FA, 0x03E, -	0x084, 0x040, 0x041, 0x080, 0x04E, 0x082, 0x0E7, 0x041, -	0x087, 0x009, 0x023, 0x004, 0x023, 0x000, 0x09D, 0x005, -	0x0CE, 0x096, 0x01C, 0x024, 0x08C, 0x010, 0x08C, 0x002, -	0x074, 0x017, 0x03A, 0x004, 0x038, 0x049, 0x018, 0x021, -	0x018, 0x004, 0x0E8, 0x02E, 0x074, 0x050, 0x0E1, 0x024, -	0x060, 0x084, 0x060, 0x013, 0x0A0, 0x0B9, 0x0D4, 0x011, -	0x0C2, 0x048, 0x0C1, 0x008, 0x0C0, 0x027, 0x041, 0x073, -	0x0A8, 0x023, 0x084, 0x091, 0x082, 0x011, 0x080, 0x04E, -	0x082, 0x0E7, 0x052, 0x08E, 0x012, 0x046, 0x008, 0x046, -	0x001, 0x03A, 0x00B, 0x09D, 0x040, 0x01C, 0x024, 0x08C, -	0x010, 0x08C, 0x002, 0x074, 0x017, 0x03A, 0x009, 0x00E, -	0x012, 0x046, 0x008, 0x046, 0x001, 0x03A, 0x00B, 0x098, -	0x06A, 0x01C, 0x024, 0x0B0, 0x0E1, 0x018, 0x004, 0x0E8, -	0x02E, 0x06B, 0x050, 0x0E1, 0x025, 0x087, 0x008, 0x0C0, -	0x027, 0x041, 0x073, 0x005, 0x043, 0x084, 0x096, 0x01C, -	0x023, 0x000, 0x09D, 0x005, 0x0CC, 0x0AA, 0x01C, 0x024, -	0x0B0, 0x0E1, 0x018, 0x004, 0x0E8, 0x02E, 0x070, 0x068, -	0x070, 0x092, 0x0C3, 0x084, 0x060, 0x013, 0x0E5, 0x044, -	0x0F9, 0x040, 0x09D, 0x005, 0x0CE, 0x05A, 0x01C, 0x024, -	0x0B0, 0x0E1, 0x018, 0x004, 0x0F9, 0x0D1, 0x03E, 0x070, -	0x027, 0x0CF, 0x013, 0x0E5, 0x044, 0x02C, 0x0A0, 0x042, -	0x0CB, 0x089, 0x0F2, 0x021, 0x03A, 0x00B, 0x09C, 0x00A, -	0x01C, 0x024, 0x0B0, 0x0E1, 0x018, 0x004, 0x0F9, 0x0D1, -	0x00B, 0x038, 0x010, 0x0B3, 0x0C4, 0x021, 0x039, 0x036, -	0x05C, 0x042, 0x0C8, 0x084, 0x02B, 0x079, 0x0D0, 0x061, -	0x0C2, 0x074, 0x015, 0x024, 0x0BA, 0x0D3, 0x031, 0x0E5, -	0x059, 0x008, 0x029, 0x008, 0x0E0, 0x066, 0x063, 0x042, -	0x095, 0x012, 0x081, 0x000, 0x029, 0x00B, 0x0C1, 0x051, -	0x024, 0x0B8, 0x019, 0x099, 0x090, 0x022, 0x090, 0x0B4, -	0x018, 0x0A0, 0x091, 0x041, 0x001, 0x041, 0x041, 0x041, -	0x052, 0x083, 0x0CA, 0x040, 0x028, 0x068, 0x029, 0x008, -	0x0BA, 0x016, 0x010, 0x09C, 0x099, 0x00B, 0x056, 0x094, -	0x090, 0x052, 0x015, 0x074, 0x0C0, 0x027, 0x01A, 0x02A, -	0x0D2, 0x090, 0x025, 0x0D3, 0x000, 0x09D, 0x028, 0x0AB, -	0x04A, 0x042, 0x017, 0x04C, 0x002, 0x070, 0x0D4, 0x084, -	0x02E, 0x098, 0x004, 0x0E1, 0x02A, 0x042, 0x017, 0x04C, -	0x002, 0x070, 0x082, 0x090, 0x04B, 0x0A6, 0x001, 0x038, -	0x051, 0x048, 0x042, 0x0E9, 0x080, 0x04E, 0x015, 0x0A4, -	0x021, 0x074, 0x0C0, 0x027, 0x00F, 0x0A4, 0x012, 0x0E9, -	0x080, 0x04E, 0x082, 0x0AC, 0x080, 0x0AC, 0x0A0, 0x0AC, -	0x0A9, 0x059, 0x0E5, 0x064, 0x045, 0x065, 0x0CA, 0x0C8, -	0x04A, 0x0CE, 0x00A, 0x0CE, 0x04A, 0x0CE, 0x095, 0x091, -	0x095, 0x094, 0x095, 0x093, 0x029, 0x025, 0x0C0, 0x0CC, -	0x0CC, 0x088, 0x0A4, 0x097, 0x056, 0x036, 0x064, 0x072, -	0x090, 0x054, 0x08A, 0x09C, 0x045, 0x008, 0x0B9, 0x0B7, -	0x066, 0x012, 0x093, 0x009, 0x0C9, 0x0B2, 0x074, 0x08E, -	0x0BA, 0x060, 0x013, 0x0E5, 0x034, 0x08E, 0x0BA, 0x060, -	0x013, 0x0E4, 0x074, 0x08E, 0x0BA, 0x060, 0x013, 0x0E5, -	0x069, 0x01D, 0x074, 0x0C0, 0x027, 0x0CA, 0x029, 0x01D, -	0x074, 0x0C0, 0x027, 0x0CE, 0x0D2, 0x025, 0x0D3, 0x000, -	0x09F, 0x038, 0x0A4, 0x04B, 0x0A6, 0x001, 0x03E, 0x05E, -	0x091, 0x02E, 0x098, 0x004, 0x0F9, 0x015, 0x022, 0x05D, -	0x030, 0x009, 0x0F3, 0x0E9, 0x012, 0x0E9, 0x080, 0x04F, -	0x090, 0x052, 0x025, 0x0D3, 0x000, 0x09D, 0x0C5, 0x048, -	0x025, 0x0D3, 0x000, 0x09C, 0x045, 0x0CE, 0x0CD, 0x009, -	0x0C9, 0x0B2, 0x01A, 0x044, 0x0BA, 0x060, 0x013, 0x0E7, -	0x034, 0x089, 0x074, 0x0C0, 0x027, 0x01C, 0x027, 0x0B7, -	0x09C, 0x080, 0x0C2, 0x0D7, 0x076, 0x059, 0x09B, 0x093, -	0x00C, 0x064, 0x0C3, 0x01D, 0x01B, 0x0F4, 0x045, 0x04B, -	0x0C7, 0x0C6, 0x03A, 0x037, 0x0E8, 0x081, 0x04B, 0x0C7, -	0x0C6, 0x03A, 0x037, 0x0E8, 0x091, 0x04B, 0x0C7, 0x0C6, -	0x032, 0x061, 0x08E, 0x0B3, 0x0BC, 0x0C3, 0x04A, 0x022, -	0x0E6, 0x0B5, 0x024, 0x097, 0x071, 0x0C9, 0x087, 0x0B4, -	0x031, 0x0AE, 0x073, 0x0A2, 0x0CF, 0x039, 0x0D2, 0x05D, -	0x004, 0x044, 0x042, 0x0C0, 0x0D6, 0x0DE, 0x071, 0x006, -	0x016, 0x0BB, 0x0DB, 0x0CE, 0x083, 0x00C, 0x064, 0x0C3, -	0x01D, 0x031, 0x013, 0x004, 0x0F9, 0x095, 0x04D, 0x013, -	0x032, 0x093, 0x063, 0x05E, 0x066, 0x014, 0x0CC, 0x029, -	0x02A, 0x053, 0x030, 0x0A6, 0x061, 0x04C, 0x0C2, 0x099, -	0x085, 0x03A, 0x072, 0x0CC, 0x0C2, 0x099, 0x085, 0x006, -	0x01B, 0x0B3, 0x00A, 0x066, 0x014, 0x014, 0x024, 0x099, -	0x085, 0x033, 0x00A, 0x008, 0x0B1, 0x086, 0x061, 0x04C, -	0x0C2, 0x084, 0x021, 0x068, 0x073, 0x03B, 0x030, 0x0A6, -	0x061, 0x041, 0x04E, 0x0A5, 0x098, 0x053, 0x030, 0x0AC, -	0x059, 0x076, 0x061, 0x04C, 0x0C2, 0x0B0, 0x08D, 0x0D6, -	0x061, 0x04C, 0x0C2, 0x0B0, 0x02C, 0x0F6, 0x061, 0x04C, -	0x0C2, 0x0B1, 0x08C, 0x0A5, 0x098, 0x053, 0x030, 0x0AC, -	0x00F, 0x024, 0x0CC, 0x029, 0x098, 0x056, 0x00F, 0x028, -	0x066, 0x015, 0x092, 0x01A, 0x019, 0x085, 0x033, 0x00A, -	0x0CA, 0x085, 0x00C, 0x0C2, 0x099, 0x085, 0x065, 0x0C3, -	0x0D9, 0x085, 0x033, 0x00A, 0x0CE, 0x070, 0x086, 0x061, -	0x04C, 0x0C2, 0x0B3, 0x097, 0x071, 0x00C, 0x099, 0x03B, -	0x0CC, 0x083, 0x058, 0x00B, 0x0EA, 0x077, 0x09D, 0x006, -	0x04A, 0x0BE, 0x004, 0x074, 0x060, 0x0E0, 0x0D1, 0x04E, -	0x038, 0x04C, 0x03E, 0x0EE, 0x03E, 0x0EE, 0x03E, 0x0EE, -	0x03E, 0x0EE, 0x030, 0x0BB, 0x0CA, 0x0E1, 0x01F, 0x077, -	0x01F, 0x077, 0x01F, 0x077, 0x01F, 0x077, 0x027, 0x070, -	0x08F, 0x0BB, 0x080, 0x00E, 0x011, 0x0F7, 0x071, 0x0F7, -	0x07C, 0x06F, 0x03C, 0x0B3, 0x036, 0x002, 0x0FB, 0x08D, -	0x0E6, 0x055, 0x070, 0x07F, 0x02D, 0x024, 0x069, 0x055, -	0x04F, 0x058, 0x0A9, 0x023, 0x01F, 0x054, 0x0F7, 0x08A, -	0x095, 0x025, 0x02B, 0x075, 0x00C, 0x0CC, 0x0AC, 0x056, -	0x051, 0x0CC, 0x051, 0x0E4, 0x045, 0x0CE, 0x0A2, 0x012, -	0x039, 0x0C0, 0x0A0, 0x0AF, 0x056, 0x06A, 0x049, 0x07F, -	0x002, 0x08C, 0x009, 0x0F8, 0x00B, 0x0EB, 0x0AF, 0x056, -	0x076, 0x067, 0x052, 0x0B2, 0x08E, 0x069, 0x0A7, 0x011, -	0x073, 0x0A8, 0x0B1, 0x0BC, 0x0CA, 0x0A0, 0x0A9, 0x036, -	0x050, 0x02C, 0x098, 0x0E7, 0x00A, 0x0F5, 0x066, 0x0A4, -	0x097, 0x0E2, 0x05A, 0x030, 0x027, 0x0BA, 0x0F7, 0x083, -	0x04E, 0x0A5, 0x033, 0x00A, 0x066, 0x015, 0x08D, 0x0E6, -	0x055, 0x039, 0x0D2, 0x0A7, 0x0AC, 0x054, 0x060, 0x016, -	0x070, 0x01B, 0x072, 0x08E, 0x062, 0x08F, 0x022, 0x02E, -	0x075, 0x016, 0x002, 0x0FB, 0x08D, 0x0E6, 0x00A, 0x095, -	0x03D, 0x062, 0x0A3, 0x000, 0x0B7, 0x001, 0x0B5, 0x053, -	0x0DE, 0x02A, 0x054, 0x094, 0x0AD, 0x0D4, 0x033, 0x032, -	0x0B1, 0x059, 0x047, 0x031, 0x047, 0x091, 0x017, 0x03A, -	0x088, 0x048, 0x0E7, 0x002, 0x0B0, 0x017, 0x0DC, 0x067, -	0x09D, 0x04B, 0x08D, 0x0E7, 0x052, 0x0AA, 0x07B, 0x0D4, -	0x0AA, 0x092, 0x0BD, 0x0D6, 0x099, 0x0BC, 0x056, 0x002, -	0x0FB, 0x08C, 0x0F3, 0x066, 0x066, 0x0C6, 0x0F3, 0x066, -	0x066, 0x062, 0x099, 0x02A, 0x0F8, 0x018, 0x068, 0x070, -	0x0B0, 0x08A, 0x00D, 0x055, 0x055, 0x055, 0x055, 0x052, -	0x032, 0x0E1, 0x040, 0x05C, 0x038, 0x00B, 0x0EA, 0x09B, -	0x087, 0x001, 0x07D, 0x0C0, 0x05F, 0x070, 0x017, 0x0DC, -	0x005, 0x0F5, 0x0DC, 0x09B, 0x001, 0x07D, 0x061, 0x04D, -	0x080, 0x0BE, 0x0A7, 0x079, 0x082, 0x0A2, 0x01F, 0x050, -	0x015, 0x02A, 0x08F, 0x08B, 0x01C, 0x0E5, 0x0A5, 0x013, -	0x084, 0x058, 0x0E7, 0x002, 0x091, 0x054, 0x005, 0x002, -	0x04B, 0x0BD, 0x022, 0x01A, 0x094, 0x07F, 0x09C, 0x01A, -	0x0C0, 0x05F, 0x042, 0x01A, 0x021, 0x0D1, 0x080, 0x059, -	0x0C0, 0x06D, 0x01C, 0x02C, 0x00A, 0x083, 0x055, 0x055, -	0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, -	0x055, 0x054, 0x01C, 0x0B8, 0x05C, 0x06E, 0x017, 0x09C, -	0x02F, 0x038, 0x05E, 0x070, 0x0E7, 0x0B8, 0x05E, 0x070, -	0x0BC, 0x0E1, 0x079, 0x0C2, 0x0F3, 0x085, 0x0E7, 0x00B, -	0x0CE, 0x017, 0x09C, 0x029, 0x09C, 0x029, 0x09C, 0x029, -	0x09C, 0x023, 0x00F, 0x058, 0x014, 0x0EE, 0x035, 0x077, -	0x026, 0x021, 0x093, 0x005, 0x0C9, 0x0B0, 0x017, 0x0D2, -	0x01D, 0x018, 0x08A, 0x021, 0x093, 0x005, 0x0C9, 0x0B0, -	0x017, 0x0D1, 0x087, 0x0AC, 0x00A, 0x074, 0x00F, 0x0AE, -	0x0F5, 0x05A, 0x082, 0x0A3, 0x0E4, 0x03A, 0x031, 0x014, -	0x0BB, 0x0D7, 0x059, 0x099, 0x074, 0x0A2, 0x019, 0x030, -	0x05C, 0x09B, 0x001, 0x07D, 0x018, 0x07A, 0x0C0, 0x0A7, -	0x040, 0x0F8, 0x043, 0x0D4, 0x063, 0x089, 0x025, 0x0D0, -	0x010, 0x0D6, 0x01C, 0x06A, 0x010, 0x0F5, 0x055, 0x089, -	0x025, 0x0D1, 0x051, 0x066, 0x01F, 0x051, 0x0F5, 0x091, -	0x049, 0x02E, 0x089, 0x015, 0x098, 0x06A, 0x0A3, 0x0E0, -	0x08A, 0x094, 0x065, 0x064, 0x00E, 0x013, 0x017, 0x038, -	0x0A8, 0x086, 0x04C, 0x017, 0x026, 0x0C0, 0x05F, 0x046, -	0x01E, 0x0B0, 0x028, 0x063, 0x01F, 0x008, 0x07A, 0x08C, -	0x071, 0x024, 0x0BA, 0x002, 0x01A, 0x0D0, 0x00D, 0x042, -	0x01E, 0x0AA, 0x0B1, 0x024, 0x0BA, 0x02A, 0x02D, 0x031, -	0x0F5, 0x01F, 0x058, 0x074, 0x092, 0x0E8, 0x087, 0x05A, -	0x063, 0x052, 0x0DE, 0x0F4, 0x051, 0x069, 0x04A, 0x03E, -	0x009, 0x069, 0x046, 0x050, 0x0F0, 0x0E1, 0x031, 0x073, -	0x005, 0x045, 0x0BD, 0x059, 0x08D, 0x08B, 0x04A, 0x07C, -	0x0D3, 0x0ED, 0x038, 0x0E9, 0x0D3, 0x04E, 0x074, 0x0ED, -	0x044, 0x032, 0x060, 0x0B9, 0x036, 0x002, 0x0FA, 0x05B, -	0x0DE, 0x08A, 0x02D, 0x029, 0x0D0, 0x0E1, 0x021, 0x0F5, -	0x0A3, 0x092, 0x021, 0x0F2, 0x019, 0x030, 0x05C, 0x09B, -	0x001, 0x07D, 0x021, 0x0F5, 0x0A0, 0x0C6, 0x001, 0x067, -	0x001, 0x0B4, 0x045, 0x0CE, 0x0A5, 0x012, 0x039, 0x0D4, -	0x01C, 0x005, 0x0F4, 0x040, 0x0A1, 0x0C2, 0x0C3, 0x050, -	0x06A, 0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, -	0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x0AA, 0x081, 0x0AF, -	0x086, 0x09F, 0x019, 0x01B, 0x0E7, 0x081, 0x0F3, 0x065, -	0x0F2, 0x080, 0x0BE, 0x070, 0x017, 0x0DF, 0x0DF, 0x038, -	0x00B, 0x0EB, 0x00D, 0x0C3, 0x080, 0x0BE, 0x0A7, 0x00F, -	0x095, 0x04F, 0x05A, 0x094, 0x0C0, 0x02C, 0x0D8, 0x0B1, -	0x0A7, 0x0CE, 0x05A, 0x011, 0x073, 0x0A8, 0x03A, 0x0C2, -	0x0CC, 0x0B6, 0x030, 0x017, 0x0DC, 0x06F, 0x035, 0x0A9, -	0x080, 0x04D, 0x0A7, 0x0CE, 0x02A, 0x018, 0x079, 0x0C5, -	0x049, 0x0DE, 0x061, 0x0A8, 0x022, 0x0E7, 0x050, 0x033, -	0x0F9, 0x098, 0x064, 0x008, 0x0B9, 0x095, 0x042, 0x0FC, -	0x0CC, 0x0D9, 0x095, 0x03D, 0x062, 0x0A2, 0x048, 0x0D4, -	0x048, 0x0E7, 0x002, 0x088, 0x0B9, 0x0C1, 0x0A0, 0x0E3, -	0x09D, 0x04E, 0x062, 0x0E6, 0x0CC, 0x0C6, 0x06B, 0x0CE, -	0x083, 0x010, 0x0C9, 0x082, 0x0E4, 0x0DA, 0x0C2, 0x0C8, -	0x01E, 0x0C3, 0x0B9, 0x036, 0x002, 0x0FA, 0x0A9, 0x0EB, -	0x04E, 0x030, 0x030, 0x0FA, 0x00D, 0x0F0, 0x0A9, 0x0EB, -	0x040, 0x0B9, 0x00F, 0x0AA, 0x07A, 0x0D2, 0x0C2, 0x0C8, -	0x0FA, 0x0A7, 0x0AD, 0x041, 0x00A, 0x047, 0x0D5, 0x03D, -	0x068, 0x0AC, 0x0F1, 0x0F5, 0x04F, 0x05A, 0x097, 0x054, -	0x07D, 0x04F, 0x0A8, 0x0AA, 0x055, 0x01F, 0x011, 0x073, -	0x05A, 0x0B0, 0x017, 0x0DE, 0x05D, 0x059, 0x0A9, 0x025, -	0x0D0, 0x055, 0x02A, 0x046, 0x0BC, 0x0B8, 0x022, 0x0AE, -	0x045, 0x029, 0x03E, 0x014, 0x0FA, 0x0E1, 0x099, 0x094, -	0x0CA, 0x04A, 0x0BE, 0x03D, 0x0D6, 0x099, 0x092, 0x05D, -	0x015, 0x017, 0x0C8, 0x0D7, 0x0DC, 0x015, 0x017, 0x08A, -	0x040, 0x01F, 0x00A, 0x09E, 0x0AC, 0x0C9, 0x065, 0x049, -	0x05C, 0x01D, 0x010, 0x068, 0x04A, 0x03E, 0x05B, 0x0DE, -	0x083, 0x016, 0x095, 0x080, 0x0BE, 0x091, 0x074, 0x058, -	0x0A4, 0x000, 0x07C, 0x038, 0x0E7, 0x056, 0x030, 0x017, -	0x0DF, 0x075, 0x0A6, 0x064, 0x097, 0x045, 0x020, 0x09D, -	0x003, 0x05F, 0x070, 0x054, 0x05E, 0x029, 0x01D, 0x0F0, -	0x0A9, 0x0EA, 0x0CC, 0x086, 0x054, 0x095, 0x0C1, 0x0D1, -	0x006, 0x083, 0x00F, 0x0AA, 0x07B, 0x0D0, 0x065, 0x049, -	0x045, 0x0BD, 0x0E9, 0x062, 0x0D2, 0x091, 0x0DF, 0x004, -	0x05D, 0x016, 0x029, 0x01C, 0x07D, 0x04F, 0x0AC, 0x01A, -	0x047, 0x01A, 0x0A9, 0x0F5, 0x067, 0x066, 0x053, 0x028, -	0x0B7, 0x0BD, 0x02C, 0x05A, 0x052, 0x03B, 0x0E3, 0x0DD, -	0x059, 0x0A9, 0x025, 0x0D1, 0x0A8, 0x0AC, 0x008, 0x06B, -	0x0EE, 0x008, 0x0AB, 0x0C5, 0x020, 0x02F, 0x085, 0x04F, -	0x056, 0x066, 0x075, 0x049, 0x05C, 0x01C, 0x018, 0x01D, -	0x081, 0x0C2, 0x064, 0x005, 0x0F0, 0x080, 0x0BE, 0x035, -	0x05C, 0x0D0, 0x017, 0x0C2, 0x055, 0x0F0, 0x095, 0x07C, -	0x025, 0x05F, 0x008, 0x00B, 0x0E1, 0x001, 0x07C, 0x07B, -	0x0AB, 0x035, 0x024, 0x0BA, 0x010, 0x055, 0x093, 0x01A, -	0x0FB, 0x082, 0x02A, 0x0F1, 0x048, 0x0D7, 0x0C2, 0x0A7, -	0x0AB, 0x031, 0x0B2, 0x0A4, 0x0AC, 0x063, 0x09D, 0x04A, -	0x08D, 0x07C, 0x07B, 0x0AB, 0x035, 0x024, 0x0BA, 0x010, -	0x054, 0x030, 0x08D, 0x07D, 0x0C1, 0x015, 0x078, 0x0AC, -	0x06F, 0x05A, 0x094, 0x060, 0x01A, 0x0E3, 0x079, 0x0D4, -	0x0AA, 0x04F, 0x085, 0x04F, 0x056, 0x066, 0x0D5, 0x049, -	0x058, 0x0C7, 0x03A, 0x095, 0x049, 0x0F0, 0x045, 0x0D1, -	0x062, 0x094, 0x086, 0x0BC, 0x01D, 0x013, 0x0D2, 0x090, -	0x0FF, 0x0CF, 0x07A, 0x083, 0x0F2, 0x050, 0x031, 0x0DE, -	0x000, 0x060, 0x060, 0x0A1, 0x017, 0x035, 0x0A8, 0x05F, -	0x09B, 0x01B, 0x037, 0x007, 0x044, 0x01A, 0x030, 0x00B, -	0x038, 0x00D, 0x0BC, 0x01C, 0x0E0, 0x0D0, 0x047, 0x0CE, -	0x0A0, 0x0AA, 0x07A, 0x0A1, 0x098, 0x06A, 0x092, 0x095, -	0x03D, 0x068, 0x031, 0x080, 0x05B, 0x080, 0x0DA, 0x0A9, -	0x0EF, 0x041, 0x095, 0x025, 0x016, 0x0F7, 0x0A5, 0x08B, -	0x04A, 0x0C6, 0x079, 0x0B3, 0x033, 0x060, 0x02F, 0x0AA, -	0x09E, 0x0B1, 0x051, 0x080, 0x059, 0x09E, 0x0CA, 0x0A7, -	0x0AC, 0x00A, 0x030, 0x00B, 0x067, 0x0B2, 0x0AD, 0x0D5, -	0x0DA, 0x092, 0x05D, 0x017, 0x0A3, 0x000, 0x0B3, 0x02D, -	0x095, 0x06E, 0x008, 0x0A9, 0x058, 0x0A1, 0x017, 0x03A, -	0x08B, 0x001, 0x07D, 0x054, 0x0F7, 0x08E, 0x095, 0x025, -	0x008, 0x01C, 0x0E0, 0x056, 0x002, 0x0FB, 0x0C1, 0x0D1, -	0x015, 0x018, 0x005, 0x092, 0x06B, 0x03C, 0x01D, 0x012, -	0x028, 0x0C0, 0x02C, 0x0A5, 0x06C, 0x011, 0x070, 0x017, -	0x0B2, 0x038, 0x04D, 0x080, 0x0BE, 0x0E0, 0x02F, 0x0B4, -	0x0EC, 0x04A, 0x0ED, 0x0B3, 0x09E, 0x002, 0x0FB, 0x080, -	0x0BE, 0x0E0, 0x02F, 0x0B1, 0x039, 0x093, 0x03E, 0x06D, -	0x0E7, 0x010, 0x060, 0x09F, 0x032, 0x0A9, 0x0A2, 0x06C, -	0x005, 0x0F4, 0x040, 0x0E6, 0x00A, 0x095, 0x03D, 0x06A, -	0x023, 0x000, 0x0B3, 0x080, 0x0DA, 0x0A7, 0x0D6, 0x02A, -	0x003, 0x00D, 0x070, 0x017, 0x0D2, 0x02E, 0x076, 0x029, -	0x04F, 0x0BC, 0x054, 0x0A6, 0x051, 0x06F, 0x07A, 0x058, -	0x0B4, 0x0AC, 0x005, 0x0F4, 0x08B, 0x0A2, 0x0F4, 0x00E, -	0x035, 0x00D, 0x049, 0x02E, 0x0B4, 0x0CC, 0x018, 0x0A5, -	0x0C8, 0x0F8, 0x04A, 0x097, 0x023, 0x0E1, 0x005, 0x02E, -	0x047, 0x0C2, 0x08A, 0x05C, 0x08F, 0x085, 0x069, 0x072, -	0x03E, 0x01F, 0x04A, 0x0C3, 0x055, 0x01F, 0x056, 0x043, -	0x032, 0x08C, 0x0A3, 0x05E, 0x060, 0x0A8, 0x045, 0x0CE, -	0x00D, 0x060, 0x02F, 0x0A3, 0x084, 0x09D, 0x0D8, 0x0F0, -	0x017, 0x0D2, 0x02E, 0x00E, 0x01B, 0x023, 0x084, 0x0D8, -	0x00B, 0x0EB, 0x089, 0x0F3, 0x080, 0x0BE, 0x0E0, 0x02F, -	0x0BB, 0x039, 0x085, 0x0DF, 0x022, 0x003, 0x0E7, 0x001, -	0x07D, 0x0C0, 0x05F, 0x070, 0x017, 0x0D1, 0x017, 0x038, -	0x014, 0x05B, 0x0D6, 0x0A2, 0x074, 0x00D, 0x04B, 0x07A, -	0x0B3, 0x031, 0x096, 0x094, 0x06B, 0x0CC, 0x035, 0x023, -	0x0D7, 0x049, 0x048, 0x015, 0x073, 0x029, 0x00F, 0x05D, -	0x08A, 0x0C0, 0x05F, 0x04D, 0x079, 0x084, 0x035, 0x080, -	0x0BE, 0x088, 0x01C, 0x0C3, 0x052, 0x09F, 0x059, 0x068, -	0x0C0, 0x02C, 0x0E0, 0x036, 0x0AA, 0x07B, 0x0CD, 0x04A, -	0x092, 0x0BE, 0x0F3, 0x081, 0x04A, 0x07D, 0x05B, 0x059, -	0x094, 0x0CA, 0x01C, 0x024, 0x0EE, 0x0C7, 0x080, 0x0BE, -	0x088, 0x01C, 0x0C3, 0x052, 0x09F, 0x059, 0x068, 0x0C0, -	0x02C, 0x0E0, 0x036, 0x0AA, 0x07B, 0x0CD, 0x04A, 0x092, -	0x0BE, 0x0F3, 0x081, 0x043, 0x084, 0x09C, 0x07B, 0x038, -	0x00B, 0x0EB, 0x0AF, 0x070, 0x0D4, 0x0EA, 0x053, 0x000, -	0x09B, 0x04F, 0x09C, 0x054, 0x030, 0x0F3, 0x08A, 0x094, -	0x0FA, 0x0B6, 0x0B3, 0x029, 0x094, 0x022, 0x0E6, 0x01A, -	0x085, 0x0F9, 0x0B0, 0x059, 0x093, 0x0F9, 0x0D2, 0x0C4, -	0x032, 0x060, 0x0B9, 0x036, 0x0B0, 0x0B3, 0x090, 0x0D9, -	0x077, 0x026, 0x01C, 0x027, 0x022, 0x0E8, 0x096, 0x0B4, -	0x023, 0x0EA, 0x09E, 0x0B5, 0x011, 0x080, 0x059, 0x065, -	0x086, 0x020, 0x073, 0x096, 0x08D, 0x079, 0x0AD, 0x058, -	0x00B, 0x0E9, 0x017, 0x044, 0x08A, 0x04A, 0x007, 0x0D7, -	0x07A, 0x082, 0x0A1, 0x090, 0x0FA, 0x0EF, 0x001, 0x054, -	0x0BA, 0x050, 0x0D4, 0x059, 0x01E, 0x02C, 0x0E9, 0x0F3, -	0x08A, 0x099, 0x085, 0x06B, 0x00B, 0x023, 0x015, 0x097, -	0x072, 0x061, 0x017, 0x030, 0x0D4, 0x02C, 0x073, 0x087, -	0x048, 0x0AA, 0x002, 0x081, 0x025, 0x0DE, 0x091, 0x00D, -	0x04A, 0x0C0, 0x05F, 0x07E, 0x0D2, 0x080, 0x0A5, 0x03E, -	0x0B2, 0x0D0, 0x0C8, 0x06B, 0x080, 0x0BE, 0x088, 0x01C, -	0x0EA, 0x009, 0x017, 0x044, 0x01A, 0x037, 0x01A, 0x091, -	0x074, 0x058, 0x0A3, 0x071, 0x0AF, 0x007, 0x044, 0x054, -	0x06E, 0x035, 0x0E0, 0x0E8, 0x0AA, 0x064, 0x00F, 0x090, -	0x0FA, 0x0D0, 0x063, 0x000, 0x0B3, 0x080, 0x0DA, 0x02C, -	0x073, 0x087, 0x048, 0x0AA, 0x002, 0x081, 0x025, 0x0DE, -	0x091, 0x00D, 0x04A, 0x0C0, 0x05F, 0x048, 0x0BA, 0x027, -	0x0A3, 0x000, 0x0B7, 0x001, 0x0B7, 0x04F, 0x09C, 0x0B4, -	0x06B, 0x0CC, 0x035, 0x016, 0x0F5, 0x066, 0x063, 0x02D, -	0x029, 0x01E, 0x0BA, 0x04A, 0x040, 0x0AB, 0x099, 0x048, -	0x07A, 0x0EC, 0x050, 0x08B, 0x09C, 0x008, 0x022, 0x0FC, -	0x0F9, 0x0B2, 0x055, 0x03D, 0x062, 0x0A9, 0x023, 0x051, -	0x023, 0x09C, 0x00A, 0x03C, 0x073, 0x00D, 0x044, 0x05C, -	0x0E1, 0x050, 0x071, 0x0CE, 0x0A1, 0x01F, 0x0E7, 0x015, -	0x06B, 0x00B, 0x025, 0x0ED, 0x00B, 0x093, 0x060, 0x02F, -	0x0AA, 0x09E, 0x0AC, 0x036, 0x065, 0x049, 0x05F, 0x07A, -	0x020, 0x050, 0x008, 0x07F, 0x0EF, 0x039, 0x014, 0x049, -	0x001, 0x011, 0x081, 0x004, 0x060, 0x040, 0x0CC, 0x059, -	0x0C0, 0x0AD, 0x023, 0x0EB, 0x041, 0x0B0, 0x081, 0x0F2, -	0x03A, 0x041, 0x0AA, 0x050, 0x043, 0x0E4, 0x0D4, 0x086, -	0x054, 0x0A0, 0x087, 0x0C1, 0x052, 0x0CA, 0x093, 0x001, -	0x032, 0x054, 0x09D, 0x024, 0x002, 0x000, 0x000, 0x052, -	0x0AF, 0x016, 0x046, 0x0A7, 0x091, 0x067, 0x008, 0x0B4, -	0x004, 0x051, 0x0F1, 0x065, 0x019, 0x0B4, 0x06E, 0x02D, -	0x0C0, 0x0AD, 0x049, 0x000, 0x092, 0x057, 0x01B, 0x074, -	0x045, 0x05F, 0x023, 0x051, 0x0B7, 0x044, 0x00A, 0x010, -	0x006, 0x0A3, 0x06E, 0x08B, 0x06B, 0x008, 0x01F, 0x019, -	0x0D1, 0x0E6, 0x080, 0x082, 0x080, 0x054, 0x004, 0x02A, -	0x045, 0x091, 0x0A9, 0x0E4, 0x059, 0x0C2, 0x02D, 0x001, -	0x014, 0x004, 0x050, 0x0D3, 0x0FC, 0x055, 0x084, 0x061, -	0x0D9, 0x080, 0x051, 0x02F, 0x0E2, 0x01F, 0x046, 0x05F, -	0x040, 0x0E0, 0x020, 0x015, 0x04A, 0x0BC, 0x059, 0x01A, -	0x09E, 0x045, 0x09C, 0x022, 0x0D0, 0x011, 0x048, 0x0CB, -	0x0E8, 0x014, 0x008, 0x001, 0x054, 0x015, 0x0E2, 0x0C8, -	0x0D4, 0x0F2, 0x02C, 0x0E1, 0x016, 0x080, 0x08A, 0x046, -	0x05F, 0x052, 0x07C, 0x0D9, 0x0A8, 0x0F8, 0x088, 0x0D0, -	0x05A, 0x03C, 0x0D2, 0x05C, 0x05B, 0x080, 0x0DA, 0x0A7, -	0x0D6, 0x05A, 0x008, 0x086, 0x0A4, 0x05D, 0x017, 0x0A0, -	0x0C3, 0x052, 0x02E, 0x088, 0x0A8, 0x022, 0x01F, 0x053, -	0x0EA, 0x0DA, 0x0CC, 0x0A6, 0x050, 0x0E1, 0x027, 0x076, -	0x03C, 0x005, 0x0F5, 0x04F, 0x0AB, 0x06B, 0x032, 0x099, -	0x043, 0x084, 0x09C, 0x07B, 0x038, 0x00B, 0x0E9, 0x027, -	0x0AC, 0x0D4, 0x092, 0x0E0, 0x00E, 0x0DA, 0x038, 0x04D, -	0x080, 0x0BE, 0x0E6, 0x07D, 0x050, 0x0BA, 0x051, 0x0AE, -	0x066, 0x0EF, 0x0BC, 0x0DC, 0x07B, 0x087, 0x01E, 0x002, -	0x0FA, 0x093, 0x0E6, 0x0CD, 0x047, 0x0C4, 0x043, 0x0CD, -	0x00F, 0x034, 0x09D, 0x0A3, 0x000, 0x0B0, 0x055, 0x001, -	0x0AE, 0x003, 0x084, 0x004, 0x0CE, 0x001, 0x0D0, 0x0E1, -	0x070, 0x002, 0x080, 0x00E, 0x089, 0x0E9, 0x022, 0x01F, -	0x0E0, 0x0E8, 0x096, 0x0B0, 0x011, 0x0F4, 0x0C2, 0x0CE, -	0x003, 0x06A, 0x044, 0x02D, 0x0C0, 0x06D, 0x048, 0x005, -	0x0B8, 0x00D, 0x0A3, 0x000, 0x0B7, 0x076, 0x0D5, 0x0DE, -	0x0B1, 0x050, 0x0DC, 0x07D, 0x077, 0x0BC, 0x054, 0x0BA, -	0x052, 0x07F, 0x058, 0x014, 0x034, 0x00F, 0x09A, 0x0F3, -	0x081, 0x058, 0x00B, 0x0EA, 0x0EF, 0x058, 0x014, 0x060, -	0x016, 0x0A5, 0x06C, 0x02E, 0x0F7, 0x081, 0x04B, 0x0A5, -	0x06F, 0x07D, 0x05D, 0x0EE, 0x0B5, 0x02E, 0x095, 0x080, -	0x0BE, 0x0F0, 0x073, 0x0BD, 0x004, 0x07C, 0x0EA, 0x0FE, -	0x0EB, 0x04C, 0x0DE, 0x029, 0x053, 0x0DD, 0x06A, 0x054, -	0x094, 0x0A9, 0x0EA, 0x00A, 0x08C, 0x002, 0x0D6, 0x04C, -	0x03C, 0x005, 0x0F4, 0x000, 0x0EA, 0x0CD, 0x056, 0x0AF, -	0x0C0, 0x047, 0x0D2, 0x09C, 0x08D, 0x029, 0x0CA, 0x0E0, -	0x02F, 0x0AE, 0x0BD, 0x075, 0x099, 0x09D, 0x04A, 0x0F9, -	0x0EF, 0x051, 0x07C, 0x094, 0x00C, 0x077, 0x080, 0x018, -	0x018, 0x029, 0x02A, 0x0F8, 0x0E0, 0x0E8, 0x0AA, 0x030, -	0x00B, 0x02A, 0x098, 0x07C, 0x01D, 0x011, 0x051, 0x080, -	0x059, 0x054, 0x0C3, 0x051, 0x0F5, 0x01B, 0x033, 0x024, -	0x0BB, 0x082, 0x0A5, 0x019, 0x05C, 0x01D, 0x010, 0x028, -	0x0C0, 0x02C, 0x09A, 0x0C7, 0x0C1, 0x0D1, 0x022, 0x08C, -	0x002, 0x0C9, 0x094, 0x064, 0x05C, 0x00C, 0x0D6, 0x08E, -	0x013, 0x060, 0x02F, 0x0B8, 0x00B, 0x0EA, 0x030, 0x0E3, -	0x0C0, 0x05F, 0x048, 0x0DC, 0x078, 0x00B, 0x0E8, 0x000, -	0x0E3, 0x0C0, 0x05F, 0x06C, 0x038, 0x0D5, 0x02E, 0x035, -	0x04F, 0x05A, 0x08A, 0x061, 0x0AA, 0x09F, 0x056, 0x01B, -	0x032, 0x099, 0x046, 0x042, 0x0C8, 0x001, 0x00C, 0x045, -	0x0CE, 0x0A5, 0x017, 0x0E6, 0x0C6, 0x0CE, 0x0A9, 0x0EB, -	0x015, 0x016, 0x046, 0x0A2, 0x047, 0x038, 0x014, 0x043, -	0x026, 0x022, 0x0E7, 0x03D, 0x060, 0x02F, 0x0AA, 0x09E, -	0x0B5, 0x012, 0x0E0, 0x07F, 0x001, 0x07D, 0x0E3, 0x0E7, -	0x002, 0x093, 0x0F9, 0x095, 0x044, 0x05C, 0x0E5, 0x0A0, -	0x0E3, 0x09D, 0x04A, 0x07F, 0x09C, 0x054, 0x0A9, 0x0EB, -	0x051, 0x005, 0x046, 0x0B9, 0x0FC, 0x0C0, 0x01B, 0x022, -	0x02E, 0x064, 0x054, 0x02F, 0x0CD, 0x046, 0x0CC, 0x0A7, -	0x0D5, 0x086, 0x0CC, 0x0A6, 0x050, 0x055, 0x0C6, 0x045, -	0x0CE, 0x05A, 0x00E, 0x039, 0x0D4, 0x0A7, 0x0F9, 0x0C5, -	0x04A, 0x09E, 0x0B5, 0x011, 0x080, 0x059, 0x0C0, 0x06D, -	0x0CF, 0x0E6, 0x000, 0x0D9, 0x011, 0x073, 0x022, 0x0A1, -	0x07E, 0x06A, 0x036, 0x065, 0x03E, 0x0AC, 0x036, 0x065, -	0x032, 0x0B0, 0x017, 0x0DD, 0x03E, 0x072, 0x0D2, 0x079, -	0x031, 0x00C, 0x098, 0x02E, 0x04C, 0x020, 0x073, 0x02A, -	0x08F, 0x0F3, 0x08A, 0x0AD, 0x0E7, 0x041, 0x082, 0x07C, -	0x0CA, 0x0A6, 0x089, 0x0B5, 0x085, 0x09F, 0x0B0, 0x0F0, -	0x017, 0x0D5, 0x01F, 0x054, 0x054, 0x025, 0x01A, 0x0A8, -	0x0FF, 0x02A, 0x094, 0x065, 0x011, 0x0D7, 0x049, 0x044, -	0x0D5, 0x0CC, 0x0A0, 0x055, 0x0D8, 0x0AE, 0x00E, 0x088, -	0x014, 0x060, 0x016, 0x04D, 0x063, 0x022, 0x0E0, 0x072, -	0x086, 0x038, 0x04D, 0x080, 0x0BE, 0x0E0, 0x02F, 0x0B8, -	0x00B, 0x0EE, 0x002, 0x0FB, 0x081, 0x038, 0x0F0, 0x017, -	0x0D7, 0x0D7, 0x01E, 0x002, 0x0FA, 0x0FA, 0x0E3, 0x0C0, -	0x05F, 0x04C, 0x085, 0x090, 0x002, 0x018, 0x0C8, 0x05B, -	0x080, 0x0DA, 0x030, 0x00B, 0x070, 0x01B, 0x04C, 0x022, -	0x0D3, 0x04C, 0x033, 0x003, 0x08C, 0x02E, 0x04C, 0x043, -	0x026, 0x0D0, 0x0F5, 0x063, 0x066, 0x0D0, 0x095, 0x0A7, -	0x0CE, 0x045, 0x033, 0x00A, 0x0D6, 0x016, 0x042, 0x038, -	0x06E, 0x0E4, 0x0CE, 0x0BD, 0x059, 0x02C, 0x0D2, 0x0AB, -	0x0BA, 0x094, 0x09D, 0x0E6, 0x01A, 0x0B0, 0x017, 0x0D5, -	0x04F, 0x05A, 0x08B, 0x009, 0x01A, 0x088, 0x0B9, 0x0C5, -	0x042, 0x047, 0x030, 0x0D4, 0x032, 0x016, 0x072, 0x088, -	0x065, 0x0BD, 0x059, 0x099, 0x025, 0x0A5, 0x060, 0x02F, -	0x0B8, 0x060, 0x0F3, 0x008, 0x0B7, 0x04A, 0x01A, 0x08F, -	0x0AB, 0x00D, 0x099, 0x046, 0x051, 0x0AF, 0x038, 0x0A8, -	0x08E, 0x090, 0x065, 0x013, 0x052, 0x018, 0x0A0, 0x054, -	0x0B1, 0x042, 0x02E, 0x061, 0x0A8, 0x048, 0x0E7, 0x02D, -	0x016, 0x0F7, 0x0A8, 0x005, 0x0A5, 0x060, 0x02F, 0x0A4, -	0x075, 0x0D2, 0x051, 0x035, 0x073, 0x028, 0x015, 0x076, -	0x02B, 0x083, 0x0A2, 0x005, 0x018, 0x005, 0x093, 0x058, -	0x0C8, 0x0B8, 0x006, 0x028, 0x063, 0x084, 0x0D8, 0x00B, -	0x0EE, 0x002, 0x0FB, 0x080, 0x0BE, 0x0E0, 0x02F, 0x0A0, -	0x043, 0x0A7, 0x001, 0x07D, 0x04C, 0x0E3, 0x0C0, 0x05F, -	0x070, 0x017, 0x0DC, 0x005, 0x0F4, 0x064, 0x02D, 0x0C0, -	0x06D, 0x018, 0x005, 0x0B8, 0x00D, 0x0A5, 0x0BD, 0x06A, -	0x023, 0x086, 0x0AA, 0x09E, 0x0B5, 0x011, 0x0A4, 0x06A, -	0x0A3, 0x0EA, 0x08A, 0x08D, 0x023, 0x0E1, 0x017, 0x038, -	0x034, 0x069, 0x071, 0x098, 0x045, 0x0A6, 0x098, 0x06A, -	0x03E, 0x0AC, 0x036, 0x065, 0x019, 0x046, 0x0BC, 0x0E2, -	0x0A2, 0x03A, 0x041, 0x094, 0x04D, 0x048, 0x062, 0x081, -	0x052, 0x0C5, 0x016, 0x0F7, 0x0A8, 0x08B, 0x04A, 0x054, -	0x0F5, 0x0A8, 0x08C, 0x002, 0x0DC, 0x006, 0x0D1, 0x003, -	0x09C, 0x0B4, 0x0A9, 0x0EE, 0x00A, 0x095, 0x025, 0x02A, -	0x07A, 0x0AD, 0x046, 0x001, 0x067, 0x001, 0x0B5, 0x0D7, -	0x0AC, 0x00A, 0x030, 0x00B, 0x06C, 0x049, 0x035, 0x0E6, -	0x0B5, 0x067, 0x0F3, 0x000, 0x06C, 0x088, 0x0B9, 0x091, -	0x050, 0x0BF, 0x031, 0x01B, 0x032, 0x0A7, 0x0B8, 0x068, -	0x095, 0x025, 0x07B, 0x0AD, 0x033, 0x078, 0x0A7, 0x0CD, -	0x03E, 0x0D3, 0x08E, 0x09D, 0x034, 0x0E7, 0x04E, 0x0D4, -	0x022, 0x0E7, 0x006, 0x084, 0x08E, 0x060, 0x0A8, 0x0FF, -	0x038, 0x0AB, 0x083, 0x09C, 0x02A, 0x008, 0x0F9, 0x0D4, -	0x020, 0x063, 0x0BC, 0x01A, 0x006, 0x00A, 0x0C0, 0x05F, -	0x046, 0x042, 0x0DC, 0x006, 0x0D1, 0x080, 0x05B, 0x080, -	0x0DA, 0x022, 0x0E6, 0x01A, 0x084, 0x08E, 0x072, 0x0D1, -	0x06F, 0x05A, 0x080, 0x087, 0x01A, 0x0AA, 0x07A, 0x0D4, -	0x048, 0x0C8, 0x0D5, 0x047, 0x0D5, 0x015, 0x023, 0x023, -	0x0E1, 0x017, 0x038, 0x034, 0x08C, 0x0BA, 0x04B, 0x07B, -	0x0D4, 0x002, 0x0D2, 0x08C, 0x022, 0x0DC, 0x006, 0x0D5, -	0x01F, 0x056, 0x01B, 0x032, 0x08C, 0x0A3, 0x05E, 0x071, -	0x051, 0x01D, 0x020, 0x0CA, 0x026, 0x0A4, 0x031, 0x040, -	0x0A9, 0x062, 0x0B0, 0x017, 0x0DF, 0x09E, 0x0F4, 0x0B7, -	0x0C9, 0x040, 0x0C7, 0x078, 0x001, 0x081, 0x082, 0x0B8, -	0x038, 0x039, 0x049, 0x01C, 0x026, 0x0C0, 0x05F, 0x070, -	0x017, 0x0D4, 0x0AB, 0x0E1, 0x02A, 0x0F8, 0x04A, 0x0BE, -	0x012, 0x0AF, 0x08F, 0x097, 0x04F, 0x0CB, 0x0A7, 0x001, -	0x07D, 0x0DA, 0x080, 0x0AA, 0x091, 0x064, 0x07F, 0x04A, -	0x081, 0x0D5, 0x022, 0x0C8, 0x0FE, 0x082, 0x080, 0x025, -	0x048, 0x0B2, 0x03E, 0x0BB, 0x0DC, 0x035, 0x02E, 0x094, -	0x007, 0x0E8, 0x08A, 0x09C, 0x003, 0x0E2, 0x04B, 0x0A5, -	0x077, 0x0AB, 0x0B3, 0x032, 0x0E9, 0x04B, 0x0BD, 0x059, -	0x086, 0x084, 0x097, 0x07A, 0x004, 0x0BA, 0x053, 0x0E1, -	0x032, 0x0EF, 0x050, 0x0D4, 0x0E6, 0x035, 0x053, 0x0EB, -	0x002, 0x09C, 0x0C7, 0x0D7, 0x07A, 0x0B3, 0x030, 0x0D2, -	0x05D, 0x0EA, 0x002, 0x0E9, 0x044, 0x05D, 0x016, 0x028, -	0x0C0, 0x02C, 0x0E0, 0x036, 0x091, 0x074, 0x045, 0x059, -	0x018, 0x0D5, 0x04F, 0x0AC, 0x00A, 0x0C4, 0x035, 0x030, -	0x08B, 0x038, 0x069, 0x02B, 0x0BD, 0x059, 0x098, 0x069, -	0x02E, 0x0F5, 0x012, 0x0E9, 0x058, 0x067, 0x04A, 0x0EF, -	0x050, 0x0D5, 0x08E, 0x03E, 0x01C, 0x0A4, 0x0B0, 0x0CE, -	0x093, 0x021, 0x06E, 0x01A, 0x048, 0x01F, 0x0A2, 0x02A, -	0x0C3, 0x00D, 0x057, 0x07A, 0x0B3, 0x00D, 0x009, 0x02E, -	0x0F4, 0x043, 0x05D, 0x028, 0x08B, 0x083, 0x020, 0x092, -	0x038, 0x04D, 0x080, 0x0BE, 0x0E0, 0x02F, 0x0AC, 0x017, -	0x049, 0x0B3, 0x0A5, 0x082, 0x0E9, 0x03E, 0x0E9, 0x036, -	0x074, 0x0E0, 0x02F, 0x0A6, 0x0CE, 0x09C, 0x005, 0x0F4, -	0x0C2, 0x02C, 0x08C, 0x052, 0x057, 0x07A, 0x0D4, 0x08D, -	0x048, 0x0FA, 0x0EF, 0x050, 0x0D5, 0x0AE, 0x035, 0x053, -	0x0EB, 0x002, 0x086, 0x021, 0x0AA, 0x0EF, 0x056, 0x066, -	0x01A, 0x04B, 0x0BD, 0x044, 0x0BA, 0x050, 0x0C4, 0x0E9, -	0x053, 0x0EB, 0x002, 0x086, 0x081, 0x0F5, 0x0DE, 0x0A1, -	0x0A8, 0x062, 0x01F, 0x05D, 0x0FE, 0x0A2, 0x05D, 0x029, -	0x077, 0x0A8, 0x06A, 0x061, 0x08D, 0x040, 0x0FD, 0x011, -	0x053, 0x00C, 0x06A, 0x0A7, 0x0D6, 0x005, 0x030, 0x0C7, -	0x0D7, 0x07F, 0x0A9, 0x057, 0x04A, 0x05D, 0x0EB, 0x048, -	0x01B, 0x00C, 0x07C, 0x08B, 0x09D, 0x08A, 0x053, 0x0EF, -	0x066, 0x094, 0x0CA, 0x054, 0x0F5, 0x0A0, 0x0C6, 0x001, -	0x06E, 0x003, 0x06A, 0x09F, 0x056, 0x076, 0x065, 0x032, -	0x08B, 0x07B, 0x0D2, 0x0C5, 0x0A5, 0x060, 0x02F, 0x0AA, -	0x07D, 0x065, 0x0A3, 0x000, 0x0B7, 0x001, 0x0B4, 0x0C8, -	0x05A, 0x007, 0x08F, 0x0ED, 0x001, 0x0D5, 0x027, 0x091, -	0x067, 0x001, 0x0B4, 0x08B, 0x09C, 0x054, 0x01C, 0x073, -	0x0A8, 0x084, 0x05C, 0x0C1, 0x050, 0x0BF, 0x036, 0x056, -	0x060, 0x0AB, 0x08C, 0x08B, 0x09C, 0x054, 0x01C, 0x073, -	0x0A8, 0x084, 0x05C, 0x0C1, 0x050, 0x0BF, 0x036, 0x056, -	0x06C, 0x005, 0x0F5, 0x053, 0x0D6, 0x0A2, 0x030, 0x00B, -	0x029, 0x05B, 0x019, 0x0FC, 0x0F6, 0x094, 0x045, 0x0CF, -	0x015, 0x00B, 0x0F3, 0x03C, 0x0B3, 0x02A, 0x07A, 0x0C5, -	0x046, 0x001, 0x064, 0x08A, 0x031, 0x023, 0x09C, 0x00A, -	0x05D, 0x0EA, 0x034, 0x033, 0x02E, 0x095, 0x0C7, 0x0CE, -	0x02A, 0x04F, 0x0E6, 0x050, 0x020, 0x0B9, 0x031, 0x00C, -	0x09B, 0x0EF, 0x039, 0x014, 0x045, 0x0CE, 0x045, 0x007, -	0x01C, 0x0EA, 0x046, 0x087, 0x0AB, 0x01B, 0x036, 0x084, -	0x0A7, 0x05E, 0x0AC, 0x096, 0x067, 0x052, 0x0B0, 0x017, -	0x0DC, 0x0FE, 0x07B, 0x04A, 0x022, 0x0E7, 0x08A, 0x085, -	0x0F9, 0x09E, 0x059, 0x097, 0x07A, 0x08D, 0x00C, 0x0CB, -	0x0A5, 0x027, 0x0F3, 0x0A0, 0x044, 0x032, 0x060, 0x0B9, -	0x037, 0x0DE, 0x072, 0x028, 0x08B, 0x09C, 0x08A, 0x00E, -	0x039, 0x0D4, 0x08C, 0x005, 0x0F7, 0x0E7, 0x0B8, 0x02A, -	0x0F9, 0x028, 0x018, 0x0EF, 0x000, 0x030, 0x030, 0x057, -	0x007, 0x044, 0x00A, 0x050, 0x08F, 0x0F0, 0x073, 0x091, -	0x041, 0x01F, 0x03A, 0x090, 0x045, 0x0C0, 0x0BB, 0x018, -	0x0E1, 0x036, 0x002, 0x0FB, 0x0FB, 0x09E, 0x002, 0x0FA, -	0x0EE, 0x0E7, 0x0F5, 0x0CF, 0x001, 0x07D, 0x010, 0x05C, -	0x0F0, 0x017, 0x0D1, 0x005, 0x0CF, 0x001, 0x07D, 0x053, -	0x0EB, 0x02D, 0x018, 0x005, 0x0B8, 0x00D, 0x0A6, 0x042, -	0x0DC, 0x006, 0x0D3, 0x017, 0x035, 0x0A8, 0x08B, 0x09C, -	0x00A, 0x00E, 0x039, 0x0D4, 0x00C, 0x0FE, 0x07B, 0x04A, -	0x022, 0x0E6, 0x055, 0x00B, 0x0F3, 0x031, 0x0B3, 0x060, -	0x02F, 0x0BC, 0x07C, 0x0E2, 0x0A4, 0x0FE, 0x065, 0x051, -	0x017, 0x038, 0x014, 0x01C, 0x073, 0x0A8, 0x019, 0x0FC, -	0x0F6, 0x094, 0x045, 0x0CC, 0x0AA, 0x017, 0x0E6, 0x063, -	0x066, 0x00A, 0x0B8, 0x0CC, 0x085, 0x0A1, 0x058, 0x0F6, -	0x0A2, 0x035, 0x048, 0x048, 0x07F, 0x04A, 0x089, 0x095, -	0x021, 0x021, 0x0FD, 0x005, 0x002, 0x054, 0x09E, 0x045, -	0x091, 0x00E, 0x03C, 0x005, 0x0F5, 0x007, 0x040, 0x055, -	0x048, 0x052, 0x03E, 0x086, 0x0A0, 0x075, 0x048, 0x052, -	0x03E, 0x0B5, 0x000, 0x04A, 0x09C, 0x000, 0x06B, 0x0C7, -	0x0CE, 0x045, 0x027, 0x0F3, 0x02A, 0x084, 0x037, 0x035, -	0x0DE, 0x0A0, 0x0AB, 0x023, 0x01A, 0x0AE, 0x0F5, 0x083, -	0x059, 0x018, 0x0D7, 0x043, 0x0DE, 0x02A, 0x0D0, 0x094, -	0x0EB, 0x0DE, 0x005, 0x03A, 0x095, 0x09F, 0x0CC, 0x0C3, -	0x020, 0x045, 0x0CC, 0x0AA, 0x017, 0x0E6, 0x066, 0x0CC, -	0x043, 0x026, 0x04F, 0x0E7, 0x041, 0x022, 0x02E, 0x070, -	0x068, 0x038, 0x0E7, 0x053, 0x0E0, 0x02F, 0x0AB, 0x0BC, -	0x012, 0x0D2, 0x0E9, 0x058, 0x00B, 0x0EA, 0x0A7, 0x0AD, -	0x045, 0x0A1, 0x01F, 0x0C0, 0x05F, 0x078, 0x039, 0x0C8, -	0x0A0, 0x08F, 0x09D, 0x048, 0x01C, 0x024, 0x0EE, 0x0C7, -	0x080, 0x0BE, 0x0BA, 0x0F5, 0x06D, 0x066, 0x049, 0x077, -	0x00D, 0x04E, 0x0A5, 0x030, 0x009, 0x0B4, 0x0F9, 0x0C5, -	0x043, 0x00F, 0x038, 0x0A9, 0x03F, 0x09D, 0x002, 0x0FB, -	0x0CE, 0x045, 0x011, 0x073, 0x091, 0x041, 0x0C7, 0x03A, -	0x091, 0x09F, 0x0CF, 0x069, 0x044, 0x05C, 0x0F1, 0x050, -	0x0BF, 0x033, 0x0CB, 0x032, 0x0A7, 0x0AC, 0x054, 0x090, -	0x08D, 0x044, 0x08E, 0x070, 0x029, 0x077, 0x0A8, 0x0D0, -	0x0CC, 0x0BA, 0x056, 0x0B0, 0x0B2, 0x09D, 0x08C, 0x086, -	0x04C, 0x017, 0x026, 0x077, 0x026, 0x01C, 0x027, 0x01C, -	0x024, 0x09E, 0x023, 0x061, 0x0BE, 0x08E, 0x012, 0x04F, -	0x011, 0x087, 0x01C, 0x0EA, 0x05C, 0x005, 0x0F5, 0x0D7, -	0x0B8, 0x06A, 0x075, 0x029, 0x077, 0x0AB, 0x00D, 0x099, -	0x074, 0x0A5, 0x04F, 0x072, 0x0A0, 0x0AA, 0x04A, 0x0C6, -	0x0F3, 0x066, 0x066, 0x0C6, 0x039, 0x082, 0x0AF, 0x075, -	0x0A6, 0x06F, 0x014, 0x06B, 0x0CE, 0x005, 0x070, 0x073, -	0x096, 0x082, 0x03E, 0x075, 0x028, 0x0E1, 0x03A, 0x0A7, -	0x0AD, 0x044, 0x060, 0x016, 0x052, 0x0B6, 0x01D, 0x07A, -	0x0B6, 0x0B3, 0x024, 0x0BB, 0x086, 0x0A7, 0x052, 0x098, -	0x004, 0x0DA, 0x07C, 0x0E2, 0x0A1, 0x087, 0x09C, 0x055, -	0x0F7, 0x09C, 0x0B5, 0x0AC, 0x02C, 0x095, 0x033, 0x0B9, -	0x031, 0x005, 0x0D9, 0x053, 0x0D6, 0x0A2, 0x030, 0x00B, -	0x029, 0x05B, 0x002, 0x02E, 0x061, 0x05A, 0x017, 0x0E6, -	0x09C, 0x0B3, 0x02A, 0x07A, 0x0C5, 0x040, 0x021, 0x0A8, -	0x091, 0x0CE, 0x005, 0x027, 0x0F3, 0x0A5, 0x088, 0x064, -	0x0C1, 0x072, 0x065, 0x04F, 0x058, 0x014, 0x00C, 0x08D, -	0x07E, 0x0F3, 0x081, 0x044, 0x05C, 0x0EF, 0x041, 0x0C7, -	0x03A, 0x0BE, 0x002, 0x0FA, 0x0A9, 0x0EA, 0x0CE, 0x0CC, -	0x0A9, 0x029, 0x053, 0x0D6, 0x0A2, 0x046, 0x047, 0x0DD, -	0x07A, 0x0C0, 0x0A3, 0x000, 0x086, 0x0E2, 0x09B, 0x029, -	0x078, 0x08B, 0x081, 0x009, 0x098, 0x070, 0x09B, 0x029, -	0x079, 0x05D, 0x0D9, 0x072, 0x0ED, 0x094, 0x0BC, 0x0B9, -	0x076, 0x013, 0x03B, 0x02A, 0x05D, 0x0B2, 0x097, 0x095, -	0x02E, 0x0D9, 0x04B, 0x0CA, 0x07D, 0x05B, 0x059, 0x094, -	0x0CA, 0x01C, 0x024, 0x0EE, 0x0C7, 0x094, 0x0BC, 0x0C0, -	0x026, 0x0D3, 0x0E7, 0x015, 0x00C, 0x03C, 0x0E2, 0x0AC, -	0x0FE, 0x07B, 0x04A, 0x022, 0x0E7, 0x08A, 0x085, 0x0F9, -	0x09E, 0x059, 0x097, 0x07A, 0x08D, 0x00C, 0x0CB, 0x0A5, -	0x027, 0x0F3, 0x0A0, 0x041, 0x072, 0x062, 0x019, 0x037, -	0x0DE, 0x070, 0x028, 0x08B, 0x09C, 0x08A, 0x00E, 0x039, -	0x0D4, 0x08D, 0x00F, 0x056, 0x036, 0x06D, 0x009, 0x04E, -	0x0BD, 0x059, 0x02C, 0x0CE, 0x0A5, 0x06B, 0x00B, 0x022, -	0x0D9, 0x09D, 0x0C9, 0x0B2, 0x097, 0x0BE, 0x0F3, 0x081, -	0x04A, 0x07D, 0x065, 0x0A3, 0x000, 0x093, 0x08F, 0x067, -	0x029, 0x078, 0x0C2, 0x04D, 0x0C1, 0x0D1, 0x006, 0x082, -	0x031, 0x0AF, 0x007, 0x038, 0x034, 0x011, 0x0F3, 0x0A8, -	0x02A, 0x09E, 0x0A8, 0x066, 0x01A, 0x0A4, 0x0A5, 0x04F, -	0x05A, 0x00C, 0x011, 0x08F, 0x0AA, 0x07B, 0x0D0, 0x065, -	0x049, 0x045, 0x0BD, 0x0E9, 0x062, 0x0D2, 0x0B1, 0x09E, -	0x06C, 0x0CC, 0x0C6, 0x019, 0x087, 0x009, 0x0C3, 0x08E, -	0x075, 0x041, 0x01F, 0x03A, 0x0A5, 0x013, 0x0D5, 0x055, -	0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, -	0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, -	0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, -	0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, -	0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, 0x055, -	0x055, 0x055, 0x055, 0x05A, 0x0CC, 0x090 - }; - -#endif	/* defined(CONFIG_SMCTR) || defined(CONFIG_SMCTR_MODULE) */ diff --git a/drivers/net/tun.c b/drivers/net/tun.c index 901551c8ca0..a82b32b4013 100644 --- a/drivers/net/tun.c +++ b/drivers/net/tun.c @@ -44,6 +44,7 @@  #include <linux/kernel.h>  #include <linux/major.h>  #include <linux/slab.h> +#include <linux/smp_lock.h>  #include <linux/poll.h>  #include <linux/fcntl.h>  #include <linux/init.h> @@ -938,22 +939,26 @@ static int tun_chr_fasync(int fd, struct file *file, int on)  	DBG(KERN_INFO "%s: tun_chr_fasync %d\n", tun->dev->name, on); +	lock_kernel();  	if ((ret = fasync_helper(fd, file, on, &tun->fasync)) < 0) -		return ret; +		goto out;  	if (on) {  		ret = __f_setown(file, task_pid(current), PIDTYPE_PID, 0);  		if (ret) -			return ret; +			goto out;  		tun->flags |= TUN_FASYNC;  	} else  		tun->flags &= ~TUN_FASYNC; - -	return 0; +	ret = 0; +out: +	unlock_kernel(); +	return ret;  }  static int tun_chr_open(struct inode *inode, struct file * file)  { +	cycle_kernel_lock();  	DBG1(KERN_INFO "tunX: tun_chr_open\n");  	file->private_data = NULL;  	return 0; diff --git a/drivers/net/ucc_geth.c b/drivers/net/ucc_geth.c index c1b55bc7eab..756ba10b79d 100644 --- a/drivers/net/ucc_geth.c +++ b/drivers/net/ucc_geth.c @@ -28,8 +28,8 @@  #include <linux/mii.h>  #include <linux/phy.h>  #include <linux/workqueue.h> +#include <linux/of_platform.h> -#include <asm/of_platform.h>  #include <asm/uaccess.h>  #include <asm/irq.h>  #include <asm/io.h> diff --git a/drivers/net/ucc_geth_mii.c b/drivers/net/ucc_geth_mii.c index 94047473692..6d9e7ad9fda 100644 --- a/drivers/net/ucc_geth_mii.c +++ b/drivers/net/ucc_geth_mii.c @@ -36,8 +36,8 @@  #include <linux/mii.h>  #include <linux/phy.h>  #include <linux/fsl_devices.h> +#include <linux/of_platform.h> -#include <asm/of_platform.h>  #include <asm/io.h>  #include <asm/irq.h>  #include <asm/uaccess.h> diff --git a/drivers/net/usb/kaweth.c b/drivers/net/usb/kaweth.c index 7c66b052f55..d6829db51b4 100644 --- a/drivers/net/usb/kaweth.c +++ b/drivers/net/usb/kaweth.c @@ -57,13 +57,12 @@  #include <linux/ethtool.h>  #include <linux/dma-mapping.h>  #include <linux/wait.h> +#include <linux/firmware.h>  #include <asm/uaccess.h>  #include <asm/byteorder.h>  #undef DEBUG -#include "kawethfw.h" -  #define KAWETH_MTU			1514  #define KAWETH_BUF_SIZE			1664  #define KAWETH_TX_TIMEOUT		(5 * HZ) @@ -108,6 +107,10 @@  MODULE_AUTHOR("Michael Zappe <zapman@interlan.net>, Stephane Alnet <stephane@u-picardie.fr>, Brad Hards <bhards@bigpond.net.au> and Oliver Neukum <oliver@neukum.org>");  MODULE_DESCRIPTION("KL5USB101 USB Ethernet driver");  MODULE_LICENSE("GPL"); +MODULE_FIRMWARE("kaweth/new_code.bin"); +MODULE_FIRMWARE("kaweth/new_code_fix.bin"); +MODULE_FIRMWARE("kaweth/trigger_code.bin"); +MODULE_FIRMWARE("kaweth/trigger_code_fix.bin");  static const char driver_name[] = "kaweth"; @@ -385,17 +388,28 @@ static int kaweth_set_receive_filter(struct kaweth_device *kaweth,   *     kaweth_download_firmware   ****************************************************************/  static int kaweth_download_firmware(struct kaweth_device *kaweth, -				    __u8 *data, -				    __u16 data_len, +				    const char *fwname,  				    __u8 interrupt,  				    __u8 type)  { -	if(data_len > KAWETH_FIRMWARE_BUF_SIZE)	{ -		err("Firmware too big: %d", data_len); +	const struct firmware *fw; +	int data_len; +	int ret; + +	ret = request_firmware(&fw, fwname, &kaweth->dev->dev); +	if (ret) { +		err("Firmware request failed\n"); +		return ret; +	} + +	if (fw->size > KAWETH_FIRMWARE_BUF_SIZE) { +		err("Firmware too big: %zu", fw->size);  		return -ENOSPC;  	} +	data_len = fw->size; +	memcpy(kaweth->firmware_buf, fw->data, fw->size); -	memcpy(kaweth->firmware_buf, data, data_len); +	release_firmware(fw);  	kaweth->firmware_buf[2] = (data_len & 0xFF) - 7;  	kaweth->firmware_buf[3] = data_len >> 8; @@ -406,8 +420,7 @@ static int kaweth_download_firmware(struct kaweth_device *kaweth,  		   kaweth->firmware_buf[2]);  	dbg("Downloading firmware at %p to kaweth device at %p", -	    data, -	    kaweth); +	    fw->data, kaweth);  	dbg("Firmware length: %d", data_len);  	return kaweth_control(kaweth, @@ -1009,8 +1022,7 @@ static int kaweth_probe(  		info("Downloading firmware...");  		kaweth->firmware_buf = (__u8 *)__get_free_page(GFP_KERNEL);  		if ((result = kaweth_download_firmware(kaweth, -						      kaweth_new_code, -						      len_kaweth_new_code, +						      "kaweth/new_code.bin",  						      100,  						      2)) < 0) {  			err("Error downloading firmware (%d)", result); @@ -1018,8 +1030,7 @@ static int kaweth_probe(  		}  		if ((result = kaweth_download_firmware(kaweth, -						      kaweth_new_code_fix, -						      len_kaweth_new_code_fix, +						      "kaweth/new_code_fix.bin",  						      100,  						      3)) < 0) {  			err("Error downloading firmware fix (%d)", result); @@ -1027,8 +1038,7 @@ static int kaweth_probe(  		}  		if ((result = kaweth_download_firmware(kaweth, -						      kaweth_trigger_code, -						      len_kaweth_trigger_code, +						      "kaweth/trigger_code.bin",  						      126,  						      2)) < 0) {  			err("Error downloading trigger code (%d)", result); @@ -1037,8 +1047,7 @@ static int kaweth_probe(  		}  		if ((result = kaweth_download_firmware(kaweth, -						      kaweth_trigger_code_fix, -						      len_kaweth_trigger_code_fix, +						      "kaweth/trigger_code_fix.bin",  						      126,  						      3)) < 0) {  			err("Error downloading trigger code fix (%d)", result); diff --git a/drivers/net/usb/kawethfw.h b/drivers/net/usb/kawethfw.h deleted file mode 100644 index cf85fcb0d1a..00000000000 --- a/drivers/net/usb/kawethfw.h +++ /dev/null @@ -1,557 +0,0 @@ -/******************************************/ -/* NOTE: B6/C3 is data header signature   */ -/*       0xAA/0xBB is data length = total */ -/*       bytes - 7, 0xCC is type, 0xDD is */ -/*       interrupt to use.                */ -/******************************************/ - -/**************************************************************** - *     kaweth_trigger_code - ****************************************************************/ -static __u8 kaweth_trigger_code[] =  -{ -    0xB6, 0xC3, 0xAA, 0xBB, 0xCC, 0xDD, -    0xc8, 0x07, 0xa0, 0x00, 0xf0, 0x07, 0x5e, 0x00, -    0x06, 0x00, 0xf0, 0x07, 0x0a, 0x00, 0x08, 0x00, -    0xf0, 0x09, 0x00, 0x00, 0x02, 0x00, 0xe7, 0x07, -    0x36, 0x00, 0x00, 0x00, 0xf0, 0x07, 0x00, 0x00, -    0x04, 0x00, 0xe7, 0x07, 0x50, 0xc3, 0x10, 0xc0, -    0xf0, 0x09, 0x0e, 0xc0, 0x00, 0x00, 0xe7, 0x87, -    0x01, 0x00, 0x0e, 0xc0, 0x97, 0xcf, 0xd7, 0x09, -    0x00, 0xc0, 0x17, 0x02, 0xc8, 0x07, 0xa0, 0x00, -    0xe7, 0x17, 0x50, 0xc3, 0x10, 0xc0, 0x30, 0xd8, -    0x04, 0x00, 0x30, 0x5c, 0x08, 0x00, 0x04, 0x00, -    0xb0, 0xc0, 0x06, 0x00, 0xc8, 0x05, 0xe7, 0x05, -    0x00, 0xc0, 0xc0, 0xdf, 0x97, 0xcf, 0x49, 0xaf, -    0xc0, 0x07, 0x00, 0x00, 0x60, 0xaf, 0x4a, 0xaf, -    0x00, 0x0c, 0x0c, 0x00, 0x40, 0xd2, 0x00, 0x1c, -    0x0c, 0x00, 0x40, 0xd2, 0x30, 0x00, 0x08, 0x00, -    0xf0, 0x07, 0x00, 0x00, 0x04, 0x00, 0xf0, 0x07, -    0x86, 0x00, 0x06, 0x00, 0x67, 0xcf, 0x27, 0x0c, -    0x02, 0x00, 0x00, 0x00, 0x27, 0x0c, 0x00, 0x00, -    0x0e, 0xc0, 0x49, 0xaf, 0x64, 0xaf, 0xc0, 0x07, -    0x00, 0x00, 0x4b, 0xaf, 0x4a, 0xaf, 0x5a, 0xcf, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x94, 0x00, 0x05, 0x00, -    0x00, 0x00 -}; -/**************************************************************** - *     kaweth_trigger_code_fix - ****************************************************************/ -static __u8 kaweth_trigger_code_fix[] =  -{ -    0xB6, 0xC3, 0xAA, 0xBB, 0xCC, 0xDD, -    0x02, 0x00, 0x06, 0x00, 0x18, 0x00, 0x3e, 0x00, -    0x80, 0x00, 0x98, 0x00, 0xaa, 0x00, -    0x00, 0x00 -}; - -/**************************************************************** - *     kaweth_new_code - ****************************************************************/ -static __u8 kaweth_new_code[] =  -{ -    0xB6, 0xC3, 0xAA, 0xBB, 0xCC, 0xDD, -    0x9f, 0xcf, 0xde, 0x06, 0xe7, 0x57, 0x00, 0x00, -    0xc4, 0x06, 0x97, 0xc1, 0xe7, 0x67, 0xff, 0x1f, -    0x28, 0xc0, 0xe7, 0x87, 0x00, 0x04, 0x24, 0xc0, -    0xe7, 0x67, 0xff, 0xf9, 0x22, 0xc0, 0x97, 0xcf, -    0xd7, 0x09, 0x00, 0xc0, 0xe7, 0x09, 0xa2, 0xc0, -    0xbe, 0x06, 0x9f, 0xaf, 0x36, 0x00, 0xe7, 0x05, -    0x00, 0xc0, 0xa7, 0xcf, 0xbc, 0x06, 0x97, 0xcf, -    0xe7, 0x57, 0x00, 0x00, 0xb8, 0x06, 0xa7, 0xa1, -    0xb8, 0x06, 0x97, 0xcf, 0xe7, 0x57, 0x00, 0x00, -    0x14, 0x08, 0x0a, 0xc0, 0xe7, 0x57, 0x00, 0x00, -    0xa4, 0xc0, 0xa7, 0xc0, 0x7a, 0x06, 0x9f, 0xaf, -    0x92, 0x07, 0xe7, 0x07, 0x00, 0x00, 0x14, 0x08, -    0xe7, 0x57, 0xff, 0xff, 0xba, 0x06, 0x9f, 0xa0, -    0x38, 0x00, 0xe7, 0x59, 0xba, 0x06, 0xbe, 0x06, -    0x9f, 0xa0, 0x38, 0x00, 0xc8, 0x09, 0xca, 0x06, -    0x08, 0x62, 0x9f, 0xa1, 0x36, 0x08, 0xc0, 0x09, -    0x76, 0x06, 0x00, 0x60, 0xa7, 0xc0, 0x7a, 0x06, -    0x9f, 0xaf, 0xcc, 0x02, 0xe7, 0x57, 0x00, 0x00, -    0xb8, 0x06, 0xa7, 0xc1, 0x7a, 0x06, 0x9f, 0xaf, -    0x04, 0x00, 0xe7, 0x57, 0x00, 0x00, 0x8e, 0x06, -    0x0a, 0xc1, 0xe7, 0x09, 0x20, 0xc0, 0x10, 0x08, -    0xe7, 0xd0, 0x10, 0x08, 0xe7, 0x67, 0x40, 0x00, -    0x10, 0x08, 0x9f, 0xaf, 0x92, 0x0c, 0xc0, 0x09, -    0xd0, 0x06, 0x00, 0x60, 0x05, 0xc4, 0xc0, 0x59, -    0xbe, 0x06, 0x02, 0xc0, 0x9f, 0xaf, 0xec, 0x00, -    0x9f, 0xaf, 0x34, 0x02, 0xe7, 0x57, 0x00, 0x00, -    0xa6, 0x06, 0x9f, 0xa0, 0x7a, 0x02, 0xa7, 0xcf, -    0x7a, 0x06, 0x48, 0x02, 0xe7, 0x09, 0xbe, 0x06, -    0xd0, 0x06, 0xc8, 0x37, 0x04, 0x00, 0x9f, 0xaf, -    0x08, 0x03, 0x97, 0xcf, 0xe7, 0x57, 0x00, 0x00, -    0xce, 0x06, 0x97, 0xc0, 0xd7, 0x09, 0x00, 0xc0, -    0xc1, 0xdf, 0xc8, 0x09, 0xc6, 0x06, 0x08, 0x62, -    0x14, 0xc0, 0x27, 0x04, 0xc6, 0x06, 0x10, 0x94, -    0xf0, 0x07, 0x10, 0x08, 0x02, 0x00, 0xc1, 0x07, -    0x01, 0x00, 0x70, 0x00, 0x04, 0x00, 0xf0, 0x07, -    0x30, 0x01, 0x06, 0x00, 0x50, 0xaf, 0xe7, 0x07, -    0xff, 0xff, 0xd0, 0x06, 0xe7, 0x07, 0x00, 0x00, -    0xce, 0x06, 0xe7, 0x05, 0x00, 0xc0, 0x97, 0xcf, -    0xd7, 0x09, 0x00, 0xc0, 0xc1, 0xdf, 0x48, 0x02, -    0xd0, 0x09, 0xc6, 0x06, 0x27, 0x02, 0xc6, 0x06, -    0xe7, 0x05, 0x00, 0xc0, 0x97, 0xcf, 0x48, 0x02, -    0xc8, 0x37, 0x04, 0x00, 0x00, 0x0c, 0x0c, 0x00, -    0x00, 0x60, 0x21, 0xc0, 0xc0, 0x37, 0x3e, 0x00, -    0x23, 0xc9, 0xc0, 0x57, 0xb4, 0x05, 0x1b, 0xc8, -    0xc0, 0x17, 0x3f, 0x00, 0xc0, 0x67, 0xc0, 0xff, -    0x30, 0x00, 0x08, 0x00, 0xf0, 0x07, 0x00, 0x00, -    0x04, 0x00, 0x00, 0x02, 0xc0, 0x17, 0x4c, 0x00, -    0x30, 0x00, 0x06, 0x00, 0xf0, 0x07, 0xa0, 0x01, -    0x0a, 0x00, 0x48, 0x02, 0xc1, 0x07, 0x02, 0x00, -    0xd7, 0x09, 0x00, 0xc0, 0xc1, 0xdf, 0x51, 0xaf, -    0xe7, 0x05, 0x00, 0xc0, 0x97, 0xcf, 0x9f, 0xaf, -    0x08, 0x03, 0x9f, 0xaf, 0x7a, 0x02, 0x97, 0xcf, -    0x9f, 0xaf, 0x7a, 0x02, 0xc9, 0x37, 0x04, 0x00, -    0xc1, 0xdf, 0xc8, 0x09, 0xa2, 0x06, 0x50, 0x02, -    0x67, 0x02, 0xa2, 0x06, 0xd1, 0x07, 0x00, 0x00, -    0x27, 0xd8, 0xaa, 0x06, 0xc0, 0xdf, 0x9f, 0xaf, -    0xc4, 0x01, 0x97, 0xcf, 0xe7, 0x57, 0x00, 0x00, -    0xd2, 0x06, 0x97, 0xc1, 0xe7, 0x57, 0x01, 0x00, -    0xa8, 0x06, 0x97, 0xc0, 0xc8, 0x09, 0xa0, 0x06, -    0x08, 0x62, 0x97, 0xc0, 0x00, 0x02, 0xc0, 0x17, -    0x0e, 0x00, 0x27, 0x00, 0x34, 0x01, 0x27, 0x0c, -    0x0c, 0x00, 0x36, 0x01, 0xe7, 0x07, 0x50, 0xc3, -    0x12, 0xc0, 0xe7, 0x07, 0xcc, 0x0b, 0x02, 0x00, -    0xe7, 0x07, 0x01, 0x00, 0xa8, 0x06, 0xe7, 0x07, -    0x05, 0x00, 0x90, 0xc0, 0x97, 0xcf, 0xc8, 0x09, -    0xa4, 0x06, 0x08, 0x62, 0x02, 0xc0, 0x10, 0x64, -    0x07, 0xc1, 0xe7, 0x07, 0x00, 0x00, 0x9e, 0x06, -    0xe7, 0x07, 0x72, 0x04, 0x24, 0x00, 0x97, 0xcf, -    0x27, 0x04, 0xa4, 0x06, 0xc8, 0x17, 0x0e, 0x00, -    0x27, 0x02, 0x9e, 0x06, 0xe7, 0x07, 0x80, 0x04, -    0x24, 0x00, 0x97, 0xcf, 0xd7, 0x09, 0x00, 0xc0, -    0xc1, 0xdf, 0xe7, 0x57, 0x00, 0x00, 0x90, 0x06, -    0x13, 0xc1, 0x9f, 0xaf, 0x06, 0x02, 0xe7, 0x57, -    0x00, 0x00, 0x9e, 0x06, 0x13, 0xc0, 0xe7, 0x09, -    0x9e, 0x06, 0x30, 0x01, 0xe7, 0x07, 0xf2, 0x05, -    0x32, 0x01, 0xe7, 0x07, 0x10, 0x00, 0x96, 0xc0, -    0xe7, 0x09, 0x9e, 0x06, 0x90, 0x06, 0x04, 0xcf, -    0xe7, 0x57, 0x00, 0x00, 0x9e, 0x06, 0x02, 0xc1, -    0x9f, 0xaf, 0x06, 0x02, 0xe7, 0x05, 0x00, 0xc0, -    0x97, 0xcf, 0xd7, 0x09, 0x00, 0xc0, 0xc1, 0xdf, -    0x08, 0x92, 0xe7, 0x57, 0x02, 0x00, 0xaa, 0x06, -    0x02, 0xc3, 0xc8, 0x09, 0xa4, 0x06, 0x27, 0x02, -    0xa6, 0x06, 0x08, 0x62, 0x03, 0xc1, 0xe7, 0x05, -    0x00, 0xc0, 0x97, 0xcf, 0x27, 0x04, 0xa4, 0x06, -    0xe7, 0x05, 0x00, 0xc0, 0xf0, 0x07, 0x40, 0x00, -    0x08, 0x00, 0xf0, 0x07, 0x00, 0x00, 0x04, 0x00, -    0x00, 0x02, 0xc0, 0x17, 0x0c, 0x00, 0x30, 0x00, -    0x06, 0x00, 0xf0, 0x07, 0x46, 0x01, 0x0a, 0x00, -    0xc8, 0x17, 0x04, 0x00, 0xc1, 0x07, 0x02, 0x00, -    0x51, 0xaf, 0x97, 0xcf, 0xe7, 0x57, 0x00, 0x00, -    0x96, 0x06, 0x97, 0xc0, 0xc1, 0xdf, 0xc8, 0x09, -    0x96, 0x06, 0x27, 0x04, 0x96, 0x06, 0x27, 0x52, -    0x98, 0x06, 0x03, 0xc1, 0xe7, 0x07, 0x96, 0x06, -    0x98, 0x06, 0xc0, 0xdf, 0x17, 0x02, 0xc8, 0x17, -    0x0e, 0x00, 0x9f, 0xaf, 0xba, 0x03, 0xc8, 0x05, -    0x00, 0x60, 0x03, 0xc0, 0x9f, 0xaf, 0x24, 0x03, -    0x97, 0xcf, 0x9f, 0xaf, 0x08, 0x03, 0x97, 0xcf, -    0x57, 0x02, 0xc9, 0x07, 0xa4, 0x06, 0xd7, 0x09, -    0x00, 0xc0, 0xc1, 0xdf, 0x08, 0x62, 0x1b, 0xc0, -    0x50, 0x04, 0x11, 0x02, 0xe7, 0x05, 0x00, 0xc0, -    0xc9, 0x05, 0x97, 0xcf, 0x97, 0x02, 0xca, 0x09, -    0xd6, 0x06, 0xf2, 0x17, 0x01, 0x00, 0x04, 0x00, -    0xf2, 0x27, 0x00, 0x00, 0x06, 0x00, 0xca, 0x17, -    0x2c, 0x00, 0xf8, 0x77, 0x01, 0x00, 0x0e, 0x00, -    0x06, 0xc0, 0xca, 0xd9, 0xf8, 0x57, 0xff, 0x00, -    0x0e, 0x00, 0x01, 0xc1, 0xca, 0xd9, 0x22, 0x1c, -    0x0c, 0x00, 0xe2, 0x27, 0x00, 0x00, 0xe2, 0x17, -    0x01, 0x00, 0xe2, 0x27, 0x00, 0x00, 0xca, 0x05, -    0x00, 0x0c, 0x0c, 0x00, 0xc0, 0x17, 0x41, 0x00, -    0xc0, 0x67, 0xc0, 0xff, 0x30, 0x00, 0x08, 0x00, -    0x00, 0x02, 0xc0, 0x17, 0x0c, 0x00, 0x30, 0x00, -    0x06, 0x00, 0xf0, 0x07, 0xda, 0x00, 0x0a, 0x00, -    0xf0, 0x07, 0x00, 0x00, 0x04, 0x00, 0x00, 0x0c, -    0x08, 0x00, 0x40, 0xd1, 0x01, 0x00, 0xc0, 0x19, -    0xce, 0x06, 0xc0, 0x59, 0xc2, 0x06, 0x04, 0xc9, -    0x49, 0xaf, 0x9f, 0xaf, 0xec, 0x00, 0x4a, 0xaf, -    0x67, 0x10, 0xce, 0x06, 0xc8, 0x17, 0x04, 0x00, -    0xc1, 0x07, 0x01, 0x00, 0xd7, 0x09, 0x00, 0xc0, -    0xc1, 0xdf, 0x50, 0xaf, 0xe7, 0x05, 0x00, 0xc0, -    0x97, 0xcf, 0xc0, 0x07, 0x01, 0x00, 0xc1, 0x09, -    0xac, 0x06, 0xc1, 0x77, 0x01, 0x00, 0x97, 0xc1, -    0xd8, 0x77, 0x01, 0x00, 0x12, 0xc0, 0xc9, 0x07, -    0x6a, 0x06, 0x9f, 0xaf, 0x08, 0x04, 0x04, 0xc1, -    0xc1, 0x77, 0x08, 0x00, 0x13, 0xc0, 0x97, 0xcf, -    0xc1, 0x77, 0x02, 0x00, 0x97, 0xc1, 0xc1, 0x77, -    0x10, 0x00, 0x0c, 0xc0, 0x9f, 0xaf, 0x2c, 0x04, -    0x97, 0xcf, 0xc1, 0x77, 0x04, 0x00, 0x06, 0xc0, -    0xc9, 0x07, 0x70, 0x06, 0x9f, 0xaf, 0x08, 0x04, -    0x97, 0xc0, 0x00, 0xcf, 0x00, 0x90, 0x97, 0xcf, -    0x50, 0x54, 0x97, 0xc1, 0x70, 0x5c, 0x02, 0x00, -    0x02, 0x00, 0x97, 0xc1, 0x70, 0x5c, 0x04, 0x00, -    0x04, 0x00, 0x97, 0xcf, 0x80, 0x01, 0xc0, 0x00, -    0x60, 0x00, 0x30, 0x00, 0x18, 0x00, 0x0c, 0x00, -    0x06, 0x00, 0x00, 0x00, 0xcb, 0x09, 0xb2, 0x06, -    0xcc, 0x09, 0xb4, 0x06, 0x0b, 0x53, 0x11, 0xc0, -    0xc9, 0x02, 0xca, 0x07, 0x1c, 0x04, 0x9f, 0xaf, -    0x08, 0x04, 0x97, 0xc0, 0x0a, 0xc8, 0x82, 0x08, -    0x0a, 0xcf, 0x82, 0x08, 0x9f, 0xaf, 0x08, 0x04, -    0x97, 0xc0, 0x05, 0xc2, 0x89, 0x30, 0x82, 0x60, -    0x78, 0xc1, 0x00, 0x90, 0x97, 0xcf, 0x89, 0x10, -    0x09, 0x53, 0x79, 0xc2, 0x89, 0x30, 0x82, 0x08, -    0x7a, 0xcf, 0xc0, 0xdf, 0x97, 0xcf, 0xc0, 0xdf, -    0x97, 0xcf, 0xe7, 0x09, 0x96, 0xc0, 0x92, 0x06, -    0xe7, 0x09, 0x98, 0xc0, 0x94, 0x06, 0x0f, 0xcf, -    0xe7, 0x09, 0x96, 0xc0, 0x92, 0x06, 0xe7, 0x09, -    0x98, 0xc0, 0x94, 0x06, 0xe7, 0x09, 0x9e, 0x06, -    0x30, 0x01, 0xe7, 0x07, 0xf2, 0x05, 0x32, 0x01, -    0xe7, 0x07, 0x10, 0x00, 0x96, 0xc0, 0xd7, 0x09, -    0x00, 0xc0, 0x17, 0x02, 0xc8, 0x09, 0x90, 0x06, -    0xc8, 0x37, 0x0e, 0x00, 0xe7, 0x77, 0x2a, 0x00, -    0x92, 0x06, 0x30, 0xc0, 0x97, 0x02, 0xca, 0x09, -    0xd6, 0x06, 0xe7, 0x77, 0x20, 0x00, 0x92, 0x06, -    0x0e, 0xc0, 0xf2, 0x17, 0x01, 0x00, 0x10, 0x00, -    0xf2, 0x27, 0x00, 0x00, 0x12, 0x00, 0xe7, 0x77, -    0x0a, 0x00, 0x92, 0x06, 0xca, 0x05, 0x1e, 0xc0, -    0x97, 0x02, 0xca, 0x09, 0xd6, 0x06, 0xf2, 0x17, -    0x01, 0x00, 0x0c, 0x00, 0xf2, 0x27, 0x00, 0x00, -    0x0e, 0x00, 0xe7, 0x77, 0x02, 0x00, 0x92, 0x06, -    0x07, 0xc0, 0xf2, 0x17, 0x01, 0x00, 0x44, 0x00, -    0xf2, 0x27, 0x00, 0x00, 0x46, 0x00, 0x06, 0xcf, -    0xf2, 0x17, 0x01, 0x00, 0x60, 0x00, 0xf2, 0x27, -    0x00, 0x00, 0x62, 0x00, 0xca, 0x05, 0x9f, 0xaf, -    0x08, 0x03, 0x0f, 0xcf, 0x57, 0x02, 0x09, 0x02, -    0xf1, 0x09, 0x94, 0x06, 0x0c, 0x00, 0xf1, 0xda, -    0x0c, 0x00, 0xc8, 0x09, 0x98, 0x06, 0x50, 0x02, -    0x67, 0x02, 0x98, 0x06, 0xd1, 0x07, 0x00, 0x00, -    0xc9, 0x05, 0xe7, 0x09, 0x9e, 0x06, 0x90, 0x06, -    0xe7, 0x57, 0x00, 0x00, 0x90, 0x06, 0x02, 0xc0, -    0x9f, 0xaf, 0x06, 0x02, 0xc8, 0x05, 0xe7, 0x05, -    0x00, 0xc0, 0xc0, 0xdf, 0x97, 0xcf, 0xd7, 0x09, -    0x00, 0xc0, 0x17, 0x00, 0x17, 0x02, 0x97, 0x02, -    0xc0, 0x09, 0x92, 0xc0, 0xe7, 0x07, 0x04, 0x00, -    0x90, 0xc0, 0xca, 0x09, 0xd6, 0x06, 0xe7, 0x07, -    0x00, 0x00, 0xa8, 0x06, 0xe7, 0x07, 0x6a, 0x04, -    0x02, 0x00, 0xc0, 0x77, 0x02, 0x00, 0x08, 0xc0, -    0xf2, 0x17, 0x01, 0x00, 0x50, 0x00, 0xf2, 0x27, -    0x00, 0x00, 0x52, 0x00, 0x9f, 0xcf, 0x24, 0x06, -    0xc0, 0x77, 0x10, 0x00, 0x06, 0xc0, 0xf2, 0x17, -    0x01, 0x00, 0x58, 0x00, 0xf2, 0x27, 0x00, 0x00, -    0x5a, 0x00, 0xc0, 0x77, 0x80, 0x00, 0x06, 0xc0, -    0xf2, 0x17, 0x01, 0x00, 0x70, 0x00, 0xf2, 0x27, -    0x00, 0x00, 0x72, 0x00, 0xc0, 0x77, 0x08, 0x00, -    0x1d, 0xc1, 0xf2, 0x17, 0x01, 0x00, 0x08, 0x00, -    0xf2, 0x27, 0x00, 0x00, 0x0a, 0x00, 0xc0, 0x77, -    0x00, 0x02, 0x06, 0xc0, 0xf2, 0x17, 0x01, 0x00, -    0x64, 0x00, 0xf2, 0x27, 0x00, 0x00, 0x66, 0x00, -    0xc0, 0x77, 0x40, 0x00, 0x06, 0xc0, 0xf2, 0x17, -    0x01, 0x00, 0x5c, 0x00, 0xf2, 0x27, 0x00, 0x00, -    0x5e, 0x00, 0xc0, 0x77, 0x01, 0x00, 0x01, 0xc0, -    0x1b, 0xcf, 0x1a, 0xcf, 0xf2, 0x17, 0x01, 0x00, -    0x00, 0x00, 0xf2, 0x27, 0x00, 0x00, 0x02, 0x00, -    0xc8, 0x09, 0x34, 0x01, 0xca, 0x17, 0x14, 0x00, -    0xd8, 0x77, 0x01, 0x00, 0x05, 0xc0, 0xca, 0xd9, -    0xd8, 0x57, 0xff, 0x00, 0x01, 0xc0, 0xca, 0xd9, -    0xe2, 0x19, 0x94, 0xc0, 0xe2, 0x27, 0x00, 0x00, -    0xe2, 0x17, 0x01, 0x00, 0xe2, 0x27, 0x00, 0x00, -    0x9f, 0xaf, 0x40, 0x06, 0x9f, 0xaf, 0xc4, 0x01, -    0xe7, 0x57, 0x00, 0x00, 0xd2, 0x06, 0x9f, 0xa1, -    0x0e, 0x0a, 0xca, 0x05, 0xc8, 0x05, 0xc0, 0x05, -    0xe7, 0x05, 0x00, 0xc0, 0xc0, 0xdf, 0x97, 0xcf, -    0xc8, 0x09, 0xa0, 0x06, 0x08, 0x62, 0x97, 0xc0, -    0x27, 0x04, 0xa0, 0x06, 0x27, 0x52, 0xa2, 0x06, -    0x03, 0xc1, 0xe7, 0x07, 0xa0, 0x06, 0xa2, 0x06, -    0x9f, 0xaf, 0x08, 0x03, 0xe7, 0x57, 0x00, 0x00, -    0xaa, 0x06, 0x02, 0xc0, 0x27, 0xda, 0xaa, 0x06, -    0x97, 0xcf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x3f, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, -    0xff, 0xff, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, -    0x00, 0x00, 0xff, 0xff, 0xfb, 0x13, 0xe7, 0x57, -    0x00, 0x80, 0xb2, 0x00, 0x06, 0xc2, 0xe7, 0x07, -    0xee, 0x0b, 0x12, 0x00, 0xe7, 0x07, 0x34, 0x0c, -    0xb2, 0x00, 0xe7, 0x07, 0xc6, 0x07, 0xf2, 0x02, -    0xc8, 0x09, 0xb4, 0x00, 0xf8, 0x07, 0x02, 0x00, -    0x0d, 0x00, 0xd7, 0x09, 0x0e, 0xc0, 0xe7, 0x07, -    0x00, 0x00, 0x0e, 0xc0, 0xc8, 0x09, 0xde, 0x00, -    0xc8, 0x17, 0x09, 0x00, 0xc9, 0x07, 0xda, 0x06, -    0xc0, 0x07, 0x04, 0x00, 0x68, 0x0a, 0x00, 0xda, -    0x7d, 0xc1, 0xe7, 0x09, 0xc0, 0x00, 0x7c, 0x06, -    0xe7, 0x09, 0xbe, 0x00, 0x78, 0x06, 0xe7, 0x09, -    0x10, 0x00, 0xbc, 0x06, 0xc8, 0x07, 0xd6, 0x07, -    0x9f, 0xaf, 0xae, 0x07, 0x9f, 0xaf, 0x00, 0x0a, -    0xc8, 0x09, 0xde, 0x00, 0x00, 0x0e, 0x0f, 0x00, -    0x41, 0x90, 0x9f, 0xde, 0x06, 0x00, 0x44, 0xaf, -    0x27, 0x00, 0xb2, 0x06, 0x27, 0x00, 0xb4, 0x06, -    0x27, 0x00, 0xb6, 0x06, 0xc0, 0x07, 0x74, 0x00, -    0x44, 0xaf, 0x27, 0x00, 0xd6, 0x06, 0x08, 0x00, -    0x00, 0x90, 0xc1, 0x07, 0x3a, 0x00, 0x20, 0x00, -    0x01, 0xda, 0x7d, 0xc1, 0x9f, 0xaf, 0xba, 0x09, -    0xc0, 0x07, 0x44, 0x00, 0x48, 0xaf, 0x27, 0x00, -    0x7a, 0x06, 0x9f, 0xaf, 0x96, 0x0a, 0xe7, 0x07, -    0x01, 0x00, 0xc0, 0x06, 0xe7, 0x05, 0x0e, 0xc0, -    0x97, 0xcf, 0x49, 0xaf, 0xe7, 0x87, 0x43, 0x00, -    0x0e, 0xc0, 0xe7, 0x07, 0xff, 0xff, 0xbe, 0x06, -    0x9f, 0xaf, 0xae, 0x0a, 0xc0, 0x07, 0x01, 0x00, -    0x60, 0xaf, 0x4a, 0xaf, 0x97, 0xcf, 0x00, 0x08, -    0x09, 0x08, 0x11, 0x08, 0x00, 0xda, 0x7c, 0xc1, -    0x97, 0xcf, 0x67, 0x04, 0xcc, 0x02, 0xc0, 0xdf, -    0x51, 0x94, 0xb1, 0xaf, 0x06, 0x00, 0xc1, 0xdf, -    0xc9, 0x09, 0xcc, 0x02, 0x49, 0x62, 0x75, 0xc1, -    0xc0, 0xdf, 0xa7, 0xcf, 0xd6, 0x02, 0x0e, 0x00, -    0x24, 0x00, 0x80, 0x04, 0x22, 0x00, 0x4e, 0x05, -    0xd0, 0x00, 0x0e, 0x0a, 0xaa, 0x00, 0x30, 0x08, -    0xbe, 0x00, 0x4a, 0x0a, 0x10, 0x00, 0x20, 0x00, -    0x04, 0x00, 0x6e, 0x04, 0x02, 0x00, 0x6a, 0x04, -    0x06, 0x00, 0x00, 0x00, 0x24, 0xc0, 0x04, 0x04, -    0x28, 0xc0, 0xfe, 0xfb, 0x1e, 0xc0, 0x00, 0x04, -    0x22, 0xc0, 0xff, 0xf4, 0xc0, 0x00, 0x90, 0x09, -    0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0x56, 0x08, -    0x60, 0x08, 0xd0, 0x08, 0xda, 0x08, 0x00, 0x09, -    0x04, 0x09, 0x08, 0x09, 0x32, 0x09, 0x42, 0x09, -    0x50, 0x09, 0x52, 0x09, 0x5a, 0x09, 0x5a, 0x09, -    0x27, 0x02, 0xca, 0x06, 0x97, 0xcf, 0xe7, 0x07, -    0x00, 0x00, 0xca, 0x06, 0x0a, 0x0e, 0x01, 0x00, -    0xca, 0x57, 0x0e, 0x00, 0x9f, 0xc3, 0x5a, 0x09, -    0xca, 0x37, 0x00, 0x00, 0x9f, 0xc2, 0x5a, 0x09, -    0x0a, 0xd2, 0xb2, 0xcf, 0x16, 0x08, 0xc8, 0x09, -    0xde, 0x00, 0x07, 0x06, 0x9f, 0xcf, 0x6c, 0x09, -    0x17, 0x02, 0xc8, 0x09, 0xde, 0x00, 0x00, 0x0e, -    0x0f, 0x00, 0x41, 0x90, 0x9f, 0xde, 0x06, 0x00, -    0xc8, 0x05, 0x30, 0x50, 0x06, 0x00, 0x9f, 0xc8, -    0x5a, 0x09, 0x27, 0x0c, 0x02, 0x00, 0xb0, 0x06, -    0xc0, 0x09, 0xb2, 0x06, 0x27, 0x00, 0xb4, 0x06, -    0xe7, 0x07, 0x00, 0x00, 0xae, 0x06, 0x27, 0x00, -    0x80, 0x06, 0x00, 0x1c, 0x06, 0x00, 0x27, 0x00, -    0xb6, 0x06, 0x41, 0x90, 0x67, 0x50, 0xb0, 0x06, -    0x0d, 0xc0, 0x67, 0x00, 0x7e, 0x06, 0x27, 0x0c, -    0x06, 0x00, 0x82, 0x06, 0xe7, 0x07, 0xbc, 0x08, -    0x84, 0x06, 0xc8, 0x07, 0x7e, 0x06, 0x41, 0x90, -    0x51, 0xaf, 0x97, 0xcf, 0x9f, 0xaf, 0x48, 0x0c, -    0xe7, 0x09, 0xb6, 0x06, 0xb4, 0x06, 0xe7, 0x09, -    0xb0, 0x06, 0xae, 0x06, 0x59, 0xaf, 0x97, 0xcf, -    0x27, 0x0c, 0x02, 0x00, 0xac, 0x06, 0x59, 0xaf, -    0x97, 0xcf, 0x09, 0x0c, 0x02, 0x00, 0x09, 0xda, -    0x49, 0xd2, 0xc9, 0x19, 0xd6, 0x06, 0xc8, 0x07, -    0x7e, 0x06, 0xe0, 0x07, 0x00, 0x00, 0x60, 0x02, -    0xe0, 0x07, 0x04, 0x00, 0xd0, 0x07, 0xcc, 0x08, -    0x48, 0xdb, 0x41, 0x90, 0x50, 0xaf, 0x97, 0xcf, -    0x59, 0xaf, 0x97, 0xcf, 0x59, 0xaf, 0x97, 0xcf, -    0xf0, 0x57, 0x06, 0x00, 0x06, 0x00, 0x25, 0xc1, -    0xe7, 0x07, 0x70, 0x06, 0x80, 0x06, 0x41, 0x90, -    0x67, 0x00, 0x7e, 0x06, 0x27, 0x0c, 0x06, 0x00, -    0x82, 0x06, 0xe7, 0x07, 0x8c, 0x09, 0x84, 0x06, -    0xc8, 0x07, 0x7e, 0x06, 0x41, 0x90, 0x51, 0xaf, -    0x97, 0xcf, 0x07, 0x0c, 0x06, 0x00, 0xc7, 0x57, -    0x06, 0x00, 0x0f, 0xc1, 0xc8, 0x07, 0x70, 0x06, -    0x15, 0xcf, 0x00, 0x0c, 0x02, 0x00, 0x00, 0xda, -    0x40, 0xd1, 0x27, 0x00, 0xc2, 0x06, 0x1e, 0xcf, -    0x1d, 0xcf, 0x27, 0x0c, 0x02, 0x00, 0xcc, 0x06, -    0x19, 0xcf, 0x27, 0x02, 0x20, 0x01, 0xe7, 0x07, -    0x08, 0x00, 0x22, 0x01, 0xe7, 0x07, 0x13, 0x00, -    0xb0, 0xc0, 0x97, 0xcf, 0x41, 0x90, 0x67, 0x00, -    0x7e, 0x06, 0xe7, 0x01, 0x82, 0x06, 0x27, 0x02, -    0x80, 0x06, 0xe7, 0x07, 0x8c, 0x09, 0x84, 0x06, -    0xc8, 0x07, 0x7e, 0x06, 0xc1, 0x07, 0x00, 0x80, -    0x50, 0xaf, 0x97, 0xcf, 0x59, 0xaf, 0x97, 0xcf, -    0x00, 0x60, 0x05, 0xc0, 0xe7, 0x07, 0x00, 0x00, -    0xc4, 0x06, 0xa7, 0xcf, 0x7c, 0x06, 0x9f, 0xaf, -    0x00, 0x0a, 0xe7, 0x07, 0x01, 0x00, 0xc4, 0x06, -    0x49, 0xaf, 0xd7, 0x09, 0x00, 0xc0, 0x07, 0xaf, -    0xe7, 0x05, 0x00, 0xc0, 0x4a, 0xaf, 0xa7, 0xcf, -    0x7c, 0x06, 0xc0, 0x07, 0xfe, 0x7f, 0x44, 0xaf, -    0x40, 0x00, 0xc0, 0x37, 0x00, 0x01, 0x41, 0x90, -    0xc0, 0x37, 0x08, 0x00, 0xdf, 0xde, 0x50, 0x06, -    0xc0, 0x57, 0x10, 0x00, 0x02, 0xc2, 0xc0, 0x07, -    0x10, 0x00, 0x27, 0x00, 0x9a, 0x06, 0x41, 0x90, -    0x9f, 0xde, 0x40, 0x06, 0x44, 0xaf, 0x27, 0x00, -    0x9c, 0x06, 0xc0, 0x09, 0x9a, 0x06, 0x41, 0x90, -    0x00, 0xd2, 0x00, 0xd8, 0x9f, 0xde, 0x08, 0x00, -    0x44, 0xaf, 0x27, 0x00, 0xc8, 0x06, 0x97, 0xcf, -    0xe7, 0x87, 0x00, 0x84, 0x28, 0xc0, 0xe7, 0x67, -    0xff, 0xfb, 0x24, 0xc0, 0x97, 0xcf, 0xe7, 0x87, -    0x01, 0x00, 0xd2, 0x06, 0xe7, 0x57, 0x00, 0x00, -    0xa8, 0x06, 0x97, 0xc1, 0x9f, 0xaf, 0x00, 0x0a, -    0xe7, 0x87, 0x00, 0x06, 0x22, 0xc0, 0xe7, 0x07, -    0x00, 0x00, 0x90, 0xc0, 0xe7, 0x67, 0xfe, 0xff, -    0x3e, 0xc0, 0xe7, 0x07, 0x26, 0x00, 0x0a, 0xc0, -    0xe7, 0x87, 0x01, 0x00, 0x3e, 0xc0, 0xe7, 0x07, -    0xff, 0xff, 0xbe, 0x06, 0x9f, 0xaf, 0x10, 0x0b, -    0x97, 0xcf, 0x17, 0x00, 0xa7, 0xaf, 0x78, 0x06, -    0xc0, 0x05, 0x27, 0x00, 0x76, 0x06, 0xe7, 0x87, -    0x01, 0x00, 0xd2, 0x06, 0x9f, 0xaf, 0x00, 0x0a, -    0xe7, 0x07, 0x0c, 0x00, 0x40, 0xc0, 0x9f, 0xaf, -    0x10, 0x0b, 0x00, 0x90, 0x27, 0x00, 0xa6, 0x06, -    0x27, 0x00, 0xaa, 0x06, 0xe7, 0x09, 0xb2, 0x06, -    0xb4, 0x06, 0x27, 0x00, 0xae, 0x06, 0x27, 0x00, -    0xac, 0x06, 0x9f, 0xaf, 0xae, 0x0a, 0xc0, 0x07, -    0x00, 0x00, 0x27, 0x00, 0xb2, 0x02, 0x27, 0x00, -    0xb4, 0x02, 0x27, 0x00, 0x8e, 0x06, 0xc0, 0x07, -    0x06, 0x00, 0xc8, 0x09, 0xde, 0x00, 0xc8, 0x17, -    0x03, 0x00, 0xc9, 0x07, 0x70, 0x06, 0x29, 0x0a, -    0x00, 0xda, 0x7d, 0xc1, 0x97, 0xcf, 0xd7, 0x09, -    0x00, 0xc0, 0xc1, 0xdf, 0x00, 0x90, 0x27, 0x00, -    0x96, 0x06, 0xe7, 0x07, 0x96, 0x06, 0x98, 0x06, -    0x27, 0x00, 0xa0, 0x06, 0xe7, 0x07, 0xa0, 0x06, -    0xa2, 0x06, 0x27, 0x00, 0xa6, 0x06, 0x27, 0x00, -    0x90, 0x06, 0x27, 0x00, 0x9e, 0x06, 0xc8, 0x09, -    0x9c, 0x06, 0xc1, 0x09, 0x9a, 0x06, 0xc9, 0x07, -    0xa4, 0x06, 0x11, 0x02, 0x09, 0x02, 0xc8, 0x17, -    0x40, 0x06, 0x01, 0xda, 0x7a, 0xc1, 0x51, 0x94, -    0xc8, 0x09, 0xc8, 0x06, 0xc9, 0x07, 0xc6, 0x06, -    0xc1, 0x09, 0x9a, 0x06, 0x11, 0x02, 0x09, 0x02, -    0xc8, 0x17, 0x08, 0x00, 0x01, 0xda, 0x7a, 0xc1, -    0x51, 0x94, 0xe7, 0x05, 0x00, 0xc0, 0x97, 0xcf, -    0xe7, 0x57, 0x00, 0x00, 0x76, 0x06, 0x97, 0xc0, -    0x9f, 0xaf, 0x04, 0x00, 0xe7, 0x09, 0xbe, 0x06, -    0xba, 0x06, 0xe7, 0x57, 0xff, 0xff, 0xba, 0x06, -    0x04, 0xc1, 0xe7, 0x07, 0x10, 0x0b, 0xb8, 0x06, -    0x97, 0xcf, 0xe7, 0x17, 0x32, 0x00, 0xba, 0x06, -    0xe7, 0x67, 0xff, 0x07, 0xba, 0x06, 0xe7, 0x07, -    0x46, 0x0b, 0xb8, 0x06, 0x97, 0xcf, 0xe7, 0x57, -    0x00, 0x00, 0xc0, 0x06, 0x23, 0xc0, 0xe7, 0x07, -    0x04, 0x00, 0x90, 0xc0, 0xe7, 0x07, 0x00, 0x80, -    0x80, 0xc0, 0xe7, 0x07, 0x00, 0x00, 0x80, 0xc0, -    0xe7, 0x07, 0x00, 0x80, 0x80, 0xc0, 0xc0, 0x07, -    0x00, 0x00, 0xc0, 0x07, 0x00, 0x00, 0xc0, 0x07, -    0x00, 0x00, 0xe7, 0x07, 0x00, 0x00, 0x80, 0xc0, -    0xe7, 0x07, 0x00, 0x80, 0x80, 0xc0, 0xe7, 0x07, -    0x00, 0x80, 0x40, 0xc0, 0xc0, 0x07, 0x00, 0x00, -    0xe7, 0x07, 0x00, 0x00, 0x40, 0xc0, 0xe7, 0x07, -    0x00, 0x00, 0x80, 0xc0, 0xe7, 0x07, 0x04, 0x00, -    0x90, 0xc0, 0xe7, 0x07, 0x00, 0x02, 0x40, 0xc0, -    0xe7, 0x07, 0x0c, 0x02, 0x40, 0xc0, 0xe7, 0x07, -    0x00, 0x00, 0xc0, 0x06, 0xe7, 0x07, 0x00, 0x00, -    0xb8, 0x06, 0xe7, 0x07, 0x00, 0x00, 0xd2, 0x06, -    0xd7, 0x09, 0x00, 0xc0, 0xc1, 0xdf, 0x9f, 0xaf, -    0x34, 0x02, 0xe7, 0x05, 0x00, 0xc0, 0x9f, 0xaf, -    0xc4, 0x01, 0x97, 0xcf, 0xd7, 0x09, 0x00, 0xc0, -    0x17, 0x00, 0x17, 0x02, 0x97, 0x02, 0xe7, 0x57, -    0x00, 0x00, 0xa8, 0x06, 0x06, 0xc0, 0xc0, 0x09, -    0x92, 0xc0, 0xc0, 0x77, 0x09, 0x02, 0x9f, 0xc1, -    0x5c, 0x05, 0x9f, 0xcf, 0x32, 0x06, 0xd7, 0x09, -    0x0e, 0xc0, 0xe7, 0x07, 0x00, 0x00, 0x0e, 0xc0, -    0x9f, 0xaf, 0x02, 0x0c, 0xe7, 0x05, 0x0e, 0xc0, -    0x97, 0xcf, 0xd7, 0x09, 0x00, 0xc0, 0x17, 0x02, -    0xc8, 0x09, 0xb0, 0xc0, 0xe7, 0x67, 0xfe, 0x7f, -    0xb0, 0xc0, 0xc8, 0x77, 0x00, 0x20, 0x9f, 0xc1, -    0x64, 0xeb, 0xe7, 0x57, 0x00, 0x00, 0xc8, 0x02, -    0x9f, 0xc1, 0x80, 0xeb, 0xc8, 0x99, 0xca, 0x02, -    0xc8, 0x67, 0x04, 0x00, 0x9f, 0xc1, 0x96, 0xeb, -    0x9f, 0xcf, 0x4c, 0xeb, 0xe7, 0x07, 0x00, 0x00, -    0xa6, 0xc0, 0xe7, 0x09, 0xb0, 0xc0, 0xc8, 0x02, -    0xe7, 0x07, 0x03, 0x00, 0xb0, 0xc0, 0x97, 0xcf, -    0xc0, 0x09, 0xb0, 0x06, 0xc0, 0x37, 0x01, 0x00, -    0x97, 0xc9, 0xc9, 0x09, 0xb2, 0x06, 0x02, 0x00, -    0x41, 0x90, 0x48, 0x02, 0xc9, 0x17, 0x06, 0x00, -    0x9f, 0xaf, 0x08, 0x04, 0x9f, 0xa2, 0x72, 0x0c, -    0x02, 0xda, 0x77, 0xc1, 0x41, 0x60, 0x71, 0xc1, -    0x97, 0xcf, 0x17, 0x02, 0x57, 0x02, 0x43, 0x04, -    0x21, 0x04, 0xe0, 0x00, 0x43, 0x04, 0x21, 0x04, -    0xe0, 0x00, 0x43, 0x04, 0x21, 0x04, 0xe0, 0x00, -    0xc1, 0x07, 0x01, 0x00, 0xc9, 0x05, 0xc8, 0x05, -    0x97, 0xcf, 0xe7, 0x07, 0x01, 0x00, 0x8e, 0x06, -    0xc8, 0x07, 0x86, 0x06, 0xe7, 0x07, 0x00, 0x00, -    0x86, 0x06, 0xe7, 0x07, 0x10, 0x08, 0x88, 0x06, -    0xe7, 0x07, 0x04, 0x00, 0x8a, 0x06, 0xe7, 0x07, -    0xbc, 0x0c, 0x8c, 0x06, 0xc1, 0x07, 0x03, 0x80, -    0x50, 0xaf, 0x97, 0xcf, 0xe7, 0x07, 0x00, 0x00, -    0x8e, 0x06, 0x97, 0xcf, -    0x00, 0x00 -}; - -/**************************************************************** - *     kaweth_new_code_fix - ****************************************************************/ -static __u8 kaweth_new_code_fix[] =  -{ -    0xB6, 0xC3, 0xAA, 0xBB, 0xCC, 0xDD, -    0x02, 0x00, 0x08, 0x00, 0x28, 0x00, 0x2c, 0x00, -    0x34, 0x00, 0x3c, 0x00, 0x40, 0x00, 0x48, 0x00, -    0x54, 0x00, 0x58, 0x00, 0x5e, 0x00, 0x64, 0x00, -    0x68, 0x00, 0x6e, 0x00, 0x6c, 0x00, 0x72, 0x00, -    0x76, 0x00, 0x7c, 0x00, 0x80, 0x00, 0x86, 0x00, -    0x8a, 0x00, 0x90, 0x00, 0x94, 0x00, 0x98, 0x00, -    0x9e, 0x00, 0xa6, 0x00, 0xaa, 0x00, 0xb0, 0x00, -    0xb4, 0x00, 0xb8, 0x00, 0xc0, 0x00, 0xc6, 0x00, -    0xca, 0x00, 0xd0, 0x00, 0xd4, 0x00, 0xd8, 0x00, -    0xe0, 0x00, 0xde, 0x00, 0xe8, 0x00, 0xf0, 0x00, -    0xfc, 0x00, 0x04, 0x01, 0x0a, 0x01, 0x18, 0x01, -    0x22, 0x01, 0x28, 0x01, 0x3a, 0x01, 0x3e, 0x01, -    0x7e, 0x01, 0x98, 0x01, 0x9c, 0x01, 0xa2, 0x01, -    0xac, 0x01, 0xb2, 0x01, 0xba, 0x01, 0xc0, 0x01, -    0xc8, 0x01, 0xd0, 0x01, 0xd6, 0x01, 0xf4, 0x01, -    0xfc, 0x01, 0x08, 0x02, 0x16, 0x02, 0x1a, 0x02, -    0x22, 0x02, 0x2a, 0x02, 0x2e, 0x02, 0x3e, 0x02, -    0x44, 0x02, 0x4a, 0x02, 0x50, 0x02, 0x64, 0x02, -    0x62, 0x02, 0x6c, 0x02, 0x72, 0x02, 0x86, 0x02, -    0x8c, 0x02, 0x90, 0x02, 0x9e, 0x02, 0xbc, 0x02, -    0xd0, 0x02, 0xd8, 0x02, 0xdc, 0x02, 0xe0, 0x02, -    0xe8, 0x02, 0xe6, 0x02, 0xf4, 0x02, 0xfe, 0x02, -    0x04, 0x03, 0x0c, 0x03, 0x28, 0x03, 0x7c, 0x03, -    0x90, 0x03, 0x94, 0x03, 0x9c, 0x03, 0xa2, 0x03, -    0xc0, 0x03, 0xd0, 0x03, 0xd4, 0x03, 0xee, 0x03, -    0xfa, 0x03, 0xfe, 0x03, 0x2e, 0x04, 0x32, 0x04, -    0x3c, 0x04, 0x40, 0x04, 0x4e, 0x04, 0x76, 0x04, -    0x7c, 0x04, 0x84, 0x04, 0x8a, 0x04, 0x8e, 0x04, -    0xa6, 0x04, 0xb0, 0x04, 0xb8, 0x04, 0xbe, 0x04, -    0xd2, 0x04, 0xdc, 0x04, 0xee, 0x04, 0x10, 0x05, -    0x1a, 0x05, 0x24, 0x05, 0x2a, 0x05, 0x36, 0x05, -    0x34, 0x05, 0x3c, 0x05, 0x42, 0x05, 0x64, 0x05, -    0x6a, 0x05, 0x6e, 0x05, 0x86, 0x05, 0x22, 0x06, -    0x26, 0x06, 0x2c, 0x06, 0x30, 0x06, 0x42, 0x06, -    0x4a, 0x06, 0x4e, 0x06, 0x56, 0x06, 0x54, 0x06, -    0x5a, 0x06, 0x60, 0x06, 0x66, 0x06, 0xe8, 0x06, -    0xee, 0x06, 0xf4, 0x06, 0x16, 0x07, 0x26, 0x07, -    0x2c, 0x07, 0x32, 0x07, 0x36, 0x07, 0x3a, 0x07, -    0x3e, 0x07, 0x52, 0x07, 0x56, 0x07, 0x5a, 0x07, -    0x64, 0x07, 0x76, 0x07, 0x7a, 0x07, 0x80, 0x07, -    0x84, 0x07, 0x8a, 0x07, 0x9e, 0x07, 0xa2, 0x07, -    0xda, 0x07, 0xde, 0x07, 0xe2, 0x07, 0xe6, 0x07, -    0xea, 0x07, 0xee, 0x07, 0xf2, 0x07, 0xf6, 0x07, -    0x0e, 0x08, 0x16, 0x08, 0x18, 0x08, 0x1a, 0x08, -    0x1c, 0x08, 0x1e, 0x08, 0x20, 0x08, 0x22, 0x08, -    0x24, 0x08, 0x26, 0x08, 0x28, 0x08, 0x2a, 0x08, -    0x2c, 0x08, 0x2e, 0x08, 0x32, 0x08, 0x3a, 0x08, -    0x46, 0x08, 0x4e, 0x08, 0x54, 0x08, 0x5e, 0x08, -    0x78, 0x08, 0x7e, 0x08, 0x82, 0x08, 0x86, 0x08, -    0x8c, 0x08, 0x90, 0x08, 0x98, 0x08, 0x9e, 0x08, -    0xa4, 0x08, 0xaa, 0x08, 0xb0, 0x08, 0xae, 0x08, -    0xb4, 0x08, 0xbe, 0x08, 0xc4, 0x08, 0xc2, 0x08, -    0xca, 0x08, 0xc8, 0x08, 0xd4, 0x08, 0xe4, 0x08, -    0xe8, 0x08, 0xf6, 0x08, 0x14, 0x09, 0x12, 0x09, -    0x1a, 0x09, 0x20, 0x09, 0x26, 0x09, 0x24, 0x09, -    0x2a, 0x09, 0x3e, 0x09, 0x4c, 0x09, 0x56, 0x09, -    0x70, 0x09, 0x74, 0x09, 0x78, 0x09, 0x7e, 0x09, -    0x7c, 0x09, 0x82, 0x09, 0x98, 0x09, 0x9c, 0x09, -    0xa0, 0x09, 0xa6, 0x09, 0xb8, 0x09, 0xdc, 0x09, -    0xe8, 0x09, 0xec, 0x09, 0xfc, 0x09, 0x12, 0x0a, -    0x18, 0x0a, 0x1e, 0x0a, 0x42, 0x0a, 0x46, 0x0a, -    0x4e, 0x0a, 0x54, 0x0a, 0x5a, 0x0a, 0x5e, 0x0a, -    0x68, 0x0a, 0x6e, 0x0a, 0x72, 0x0a, 0x78, 0x0a, -    0x76, 0x0a, 0x7c, 0x0a, 0x80, 0x0a, 0x84, 0x0a, -    0x94, 0x0a, 0xa4, 0x0a, 0xb8, 0x0a, 0xbe, 0x0a, -    0xbc, 0x0a, 0xc2, 0x0a, 0xc8, 0x0a, 0xc6, 0x0a, -    0xcc, 0x0a, 0xd0, 0x0a, 0xd4, 0x0a, 0xd8, 0x0a, -    0xdc, 0x0a, 0xe0, 0x0a, 0xf2, 0x0a, 0xf6, 0x0a, -    0xfa, 0x0a, 0x14, 0x0b, 0x1a, 0x0b, 0x20, 0x0b, -    0x1e, 0x0b, 0x26, 0x0b, 0x2e, 0x0b, 0x2c, 0x0b, -    0x36, 0x0b, 0x3c, 0x0b, 0x42, 0x0b, 0x40, 0x0b, -    0x4a, 0x0b, 0xaa, 0x0b, 0xb0, 0x0b, 0xb6, 0x0b, -    0xc0, 0x0b, 0xc8, 0x0b, 0xda, 0x0b, 0xe8, 0x0b, -    0xec, 0x0b, 0xfa, 0x0b, 0x4a, 0x0c, 0x54, 0x0c, -    0x62, 0x0c, 0x66, 0x0c, 0x96, 0x0c, 0x9a, 0x0c, -    0xa0, 0x0c, 0xa6, 0x0c, 0xa4, 0x0c, 0xac, 0x0c, -    0xb2, 0x0c, 0xb0, 0x0c, 0xc0, 0x0c, -    0x00, 0x00 -}; - - -static const int len_kaweth_trigger_code = sizeof(kaweth_trigger_code); -static const int len_kaweth_trigger_code_fix = sizeof(kaweth_trigger_code_fix); -static const int len_kaweth_new_code = sizeof(kaweth_new_code); -static const int len_kaweth_new_code_fix = sizeof(kaweth_new_code_fix); diff --git a/drivers/net/wan/cosa.c b/drivers/net/wan/cosa.c index b0fce1387ea..5827324e9d9 100644 --- a/drivers/net/wan/cosa.c +++ b/drivers/net/wan/cosa.c @@ -92,6 +92,7 @@  #include <linux/spinlock.h>  #include <linux/mutex.h>  #include <linux/device.h> +#include <linux/smp_lock.h>  #undef COSA_SLOW_IO	/* for testing purposes only */ @@ -970,15 +971,21 @@ static int cosa_open(struct inode *inode, struct file *file)  	struct channel_data *chan;  	unsigned long flags;  	int n; +	int ret = 0; +	lock_kernel();  	if ((n=iminor(file->f_path.dentry->d_inode)>>CARD_MINOR_BITS) -		>= nr_cards) -		return -ENODEV; +		>= nr_cards) { +		ret = -ENODEV; +		goto out; +	}  	cosa = cosa_cards+n;  	if ((n=iminor(file->f_path.dentry->d_inode) -		& ((1<<CARD_MINOR_BITS)-1)) >= cosa->nchannels) -		return -ENODEV; +		& ((1<<CARD_MINOR_BITS)-1)) >= cosa->nchannels) { +		ret = -ENODEV; +		goto out; +	}  	chan = cosa->chan + n;  	file->private_data = chan; @@ -987,7 +994,8 @@ static int cosa_open(struct inode *inode, struct file *file)  	if (chan->usage < 0) { /* in netdev mode */  		spin_unlock_irqrestore(&cosa->lock, flags); -		return -EBUSY; +		ret = -EBUSY; +		goto out;  	}  	cosa->usage++;  	chan->usage++; @@ -996,7 +1004,9 @@ static int cosa_open(struct inode *inode, struct file *file)  	chan->setup_rx = chrdev_setup_rx;  	chan->rx_done = chrdev_rx_done;  	spin_unlock_irqrestore(&cosa->lock, flags); -	return 0; +out: +	unlock_kernel(); +	return ret;  }  static int cosa_release(struct inode *inode, struct file *file) diff --git a/drivers/net/wireless/atmel.c b/drivers/net/wireless/atmel.c index 28b6ff3eaa3..bd35bb0a148 100644 --- a/drivers/net/wireless/atmel.c +++ b/drivers/net/wireless/atmel.c @@ -559,7 +559,7 @@ static const struct {  static void build_wpa_mib(struct atmel_private *priv);  static int atmel_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);  static void atmel_copy_to_card(struct net_device *dev, u16 dest, -			       unsigned char *src, u16 len); +			       const unsigned char *src, u16 len);  static void atmel_copy_to_host(struct net_device *dev, unsigned char *dest,  			       u16 src, u16 len);  static void atmel_set_gcr(struct net_device *dev, u16 mask); @@ -3855,7 +3855,7 @@ static int reset_atmel_card(struct net_device *dev)  	if (priv->card_type == CARD_TYPE_EEPROM) {  		/* copy in firmware if needed */  		const struct firmware *fw_entry = NULL; -		unsigned char *fw; +		const unsigned char *fw;  		int len = priv->firmware_length;  		if (!(fw = priv->firmware)) {  			if (priv->firmware_type == ATMEL_FW_TYPE_NONE) { @@ -4122,7 +4122,7 @@ static void atmel_writeAR(struct net_device *dev, u16 data)  }  static void atmel_copy_to_card(struct net_device *dev, u16 dest, -			       unsigned char *src, u16 len) +			       const unsigned char *src, u16 len)  {  	int i;  	atmel_writeAR(dev, dest); diff --git a/drivers/net/wireless/libertas/if_cs.c b/drivers/net/wireless/libertas/if_cs.c index cc70d53fadd..04d7a251e3f 100644 --- a/drivers/net/wireless/libertas/if_cs.c +++ b/drivers/net/wireless/libertas/if_cs.c @@ -122,7 +122,7 @@ static inline void if_cs_write16(struct if_cs_card *card, uint reg, u16 val)  static inline void if_cs_write16_rep(  	struct if_cs_card *card,  	uint reg, -	void *buf, +	const void *buf,  	unsigned long count)  {  	if (debug_output) diff --git a/drivers/net/wireless/libertas/if_sdio.c b/drivers/net/wireless/libertas/if_sdio.c index 51f664bbee9..b54e2ea8346 100644 --- a/drivers/net/wireless/libertas/if_sdio.c +++ b/drivers/net/wireless/libertas/if_sdio.c @@ -1,7 +1,7 @@  /*   *  linux/drivers/net/wireless/libertas/if_sdio.c   * - *  Copyright 2007 Pierre Ossman + *  Copyright 2007-2008 Pierre Ossman   *   * Inspired by if_cs.c, Copyright 2007 Holger Schurig   * @@ -266,13 +266,10 @@ static int if_sdio_card_to_host(struct if_sdio_card *card)  	/*  	 * The transfer must be in one transaction or the firmware -	 * goes suicidal. +	 * goes suicidal. There's no way to guarantee that for all +	 * controllers, but we can at least try.  	 */ -	chunk = size; -	if ((chunk > card->func->cur_blksize) || (chunk > 512)) { -		chunk = (chunk + card->func->cur_blksize - 1) / -			card->func->cur_blksize * card->func->cur_blksize; -	} +	chunk = sdio_align_size(card->func, size);  	ret = sdio_readsb(card->func, card->buffer, card->ioport, chunk);  	if (ret) @@ -392,7 +389,7 @@ static int if_sdio_prog_helper(struct if_sdio_card *card)  	unsigned long timeout;  	u8 *chunk_buffer;  	u32 chunk_size; -	u8 *firmware; +	const u8 *firmware;  	size_t size;  	lbs_deb_enter(LBS_DEB_SDIO); @@ -508,7 +505,7 @@ static int if_sdio_prog_real(struct if_sdio_card *card)  	unsigned long timeout;  	u8 *chunk_buffer;  	u32 chunk_size; -	u8 *firmware; +	const u8 *firmware;  	size_t size, req_size;  	lbs_deb_enter(LBS_DEB_SDIO); @@ -696,13 +693,10 @@ static int if_sdio_host_to_card(struct lbs_private *priv,  	/*  	 * The transfer must be in one transaction or the firmware -	 * goes suicidal. +	 * goes suicidal. There's no way to guarantee that for all +	 * controllers, but we can at least try.  	 */ -	size = nb + 4; -	if ((size > card->func->cur_blksize) || (size > 512)) { -		size = (size + card->func->cur_blksize - 1) / -			card->func->cur_blksize * card->func->cur_blksize; -	} +	size = sdio_align_size(card->func, nb + 4);  	packet = kzalloc(sizeof(struct if_sdio_packet) + size,  			GFP_ATOMIC); diff --git a/drivers/net/wireless/libertas/if_usb.c b/drivers/net/wireless/libertas/if_usb.c index a8b4abce5bf..632c291404a 100644 --- a/drivers/net/wireless/libertas/if_usb.c +++ b/drivers/net/wireless/libertas/if_usb.c @@ -310,7 +310,7 @@ static void if_usb_disconnect(struct usb_interface *intf)  static int if_usb_send_fw_pkt(struct if_usb_card *cardp)  {  	struct fwdata *fwdata = cardp->ep_out_buf; -	uint8_t *firmware = cardp->fw->data; +	const uint8_t *firmware = cardp->fw->data;  	/* If we got a CRC failure on the last block, back  	   up and retry it */ @@ -768,7 +768,7 @@ static int if_usb_issue_boot_command(struct if_usb_card *cardp, int ivalue)   *         len               image length   *  @return     0 or -1   */ -static int check_fwfile_format(uint8_t *data, uint32_t totlen) +static int check_fwfile_format(const uint8_t *data, uint32_t totlen)  {  	uint32_t bincmd, exit;  	uint32_t blksize, offset, len; diff --git a/drivers/net/wireless/p54/p54usb.c b/drivers/net/wireless/p54/p54usb.c index 1610a7308c1..815c095ef79 100644 --- a/drivers/net/wireless/p54/p54usb.c +++ b/drivers/net/wireless/p54/p54usb.c @@ -376,7 +376,8 @@ static int p54u_upload_firmware_3887(struct ieee80211_hw *dev)  	const struct firmware *fw_entry = NULL;  	int err, alen;  	u8 carry = 0; -	u8 *buf, *tmp, *data; +	u8 *buf, *tmp; +	const u8 *data;  	unsigned int left, remains, block_size;  	struct x2_header *hdr;  	unsigned long timeout; @@ -523,7 +524,7 @@ static int p54u_upload_firmware_net2280(struct ieee80211_hw *dev)  	void *buf;  	__le32 reg;  	unsigned int remains, offset; -	u8 *data; +	const u8 *data;  	buf = kmalloc(512, GFP_KERNEL);  	if (!buf) { diff --git a/drivers/net/wireless/rt2x00/rt2x00.h b/drivers/net/wireless/rt2x00/rt2x00.h index 9fab0df18c3..07b03b3c7ef 100644 --- a/drivers/net/wireless/rt2x00/rt2x00.h +++ b/drivers/net/wireless/rt2x00/rt2x00.h @@ -487,8 +487,8 @@ struct rt2x00lib_ops {  	 */  	int (*probe_hw) (struct rt2x00_dev *rt2x00dev);  	char *(*get_firmware_name) (struct rt2x00_dev *rt2x00dev); -	u16 (*get_firmware_crc) (void *data, const size_t len); -	int (*load_firmware) (struct rt2x00_dev *rt2x00dev, void *data, +	u16 (*get_firmware_crc) (const void *data, const size_t len); +	int (*load_firmware) (struct rt2x00_dev *rt2x00dev, const void *data,  			      const size_t len);  	/* diff --git a/drivers/net/wireless/rt2x00/rt2x00pci.h b/drivers/net/wireless/rt2x00/rt2x00pci.h index 50c6df4f81d..80bf97c03e2 100644 --- a/drivers/net/wireless/rt2x00/rt2x00pci.h +++ b/drivers/net/wireless/rt2x00/rt2x00pci.h @@ -82,7 +82,7 @@ static inline void rt2x00pci_register_write(struct rt2x00_dev *rt2x00dev,  static inline void  rt2x00pci_register_multiwrite(struct rt2x00_dev *rt2x00dev,  			      const unsigned long offset, -			      void *value, const u16 length) +			      const void *value, const u16 length)  {  	memcpy_toio(rt2x00dev->csr.base + offset, value, length);  } diff --git a/drivers/net/wireless/rt2x00/rt61pci.c b/drivers/net/wireless/rt2x00/rt61pci.c index 70ef7bf434a..f7c1f92c144 100644 --- a/drivers/net/wireless/rt2x00/rt61pci.c +++ b/drivers/net/wireless/rt2x00/rt61pci.c @@ -926,7 +926,7 @@ static char *rt61pci_get_firmware_name(struct rt2x00_dev *rt2x00dev)  	return fw_name;  } -static u16 rt61pci_get_firmware_crc(void *data, const size_t len) +static u16 rt61pci_get_firmware_crc(const void *data, const size_t len)  {  	u16 crc; @@ -943,7 +943,7 @@ static u16 rt61pci_get_firmware_crc(void *data, const size_t len)  	return crc;  } -static int rt61pci_load_firmware(struct rt2x00_dev *rt2x00dev, void *data, +static int rt61pci_load_firmware(struct rt2x00_dev *rt2x00dev, const void *data,  				 const size_t len)  {  	int i; diff --git a/drivers/net/wireless/rt2x00/rt73usb.c b/drivers/net/wireless/rt2x00/rt73usb.c index 34c6ff27afc..d383735ab8f 100644 --- a/drivers/net/wireless/rt2x00/rt73usb.c +++ b/drivers/net/wireless/rt2x00/rt73usb.c @@ -867,7 +867,7 @@ static char *rt73usb_get_firmware_name(struct rt2x00_dev *rt2x00dev)  	return FIRMWARE_RT2571;  } -static u16 rt73usb_get_firmware_crc(void *data, const size_t len) +static u16 rt73usb_get_firmware_crc(const void *data, const size_t len)  {  	u16 crc; @@ -884,13 +884,13 @@ static u16 rt73usb_get_firmware_crc(void *data, const size_t len)  	return crc;  } -static int rt73usb_load_firmware(struct rt2x00_dev *rt2x00dev, void *data, +static int rt73usb_load_firmware(struct rt2x00_dev *rt2x00dev, const void *data,  				 const size_t len)  {  	unsigned int i;  	int status;  	u32 reg; -	char *ptr = data; +	const char *ptr = data;  	char *cache;  	int buflen; diff --git a/drivers/net/wireless/zd1201.c b/drivers/net/wireless/zd1201.c index 07e4d1f7320..b16ec6e5f0e 100644 --- a/drivers/net/wireless/zd1201.c +++ b/drivers/net/wireless/zd1201.c @@ -49,7 +49,7 @@ MODULE_DEVICE_TABLE(usb, zd1201_table);  static int zd1201_fw_upload(struct usb_device *dev, int apfw)  {  	const struct firmware *fw_entry; -	char *data; +	const char *data;  	unsigned long len;  	int err;  	unsigned char ret; diff --git a/drivers/net/xen-netfront.c b/drivers/net/xen-netfront.c index d26f69b0184..ef671d1a3bf 100644 --- a/drivers/net/xen-netfront.c +++ b/drivers/net/xen-netfront.c @@ -1324,7 +1324,7 @@ static int setup_netfront(struct xenbus_device *dev, struct netfront_info *info)  		goto fail;  	} -	txs = (struct xen_netif_tx_sring *)get_zeroed_page(GFP_KERNEL); +	txs = (struct xen_netif_tx_sring *)get_zeroed_page(GFP_NOIO | __GFP_HIGH);  	if (!txs) {  		err = -ENOMEM;  		xenbus_dev_fatal(dev, err, "allocating tx ring page"); @@ -1340,7 +1340,7 @@ static int setup_netfront(struct xenbus_device *dev, struct netfront_info *info)  	}  	info->tx_ring_ref = err; -	rxs = (struct xen_netif_rx_sring *)get_zeroed_page(GFP_KERNEL); +	rxs = (struct xen_netif_rx_sring *)get_zeroed_page(GFP_NOIO | __GFP_HIGH);  	if (!rxs) {  		err = -ENOMEM;  		xenbus_dev_fatal(dev, err, "allocating rx ring page");  |