summaryrefslogtreecommitdiff
path: root/target/rb411/patches/ar71xx.patch
diff options
context:
space:
mode:
Diffstat (limited to 'target/rb411/patches/ar71xx.patch')
-rw-r--r--target/rb411/patches/ar71xx.patch9913
1 files changed, 0 insertions, 9913 deletions
diff --git a/target/rb411/patches/ar71xx.patch b/target/rb411/patches/ar71xx.patch
deleted file mode 100644
index 3646174f4..000000000
--- a/target/rb411/patches/ar71xx.patch
+++ /dev/null
@@ -1,9913 +0,0 @@
-diff -Nur linux-2.6.29.1.orig/arch/mips/Kconfig linux-2.6.29.1/arch/mips/Kconfig
---- linux-2.6.29.1.orig/arch/mips/Kconfig 2009-04-02 22:55:27.000000000 +0200
-+++ linux-2.6.29.1/arch/mips/Kconfig 2009-04-13 14:27:23.734393467 +0200
-@@ -22,6 +22,23 @@
- config MACH_ALCHEMY
- bool "Alchemy processor based machines"
-
-+config ATHEROS_AR71XX
-+ bool "Atheros AR71xx based boards"
-+ select CEVT_R4K
-+ select CSRC_R4K
-+ select DMA_NONCOHERENT
-+ select HW_HAS_PCI
-+ select IRQ_CPU
-+ select ARCH_REQUIRE_GPIOLIB
-+ select SYS_HAS_CPU_MIPS32_R1
-+ select SYS_HAS_CPU_MIPS32_R2
-+ select SYS_SUPPORTS_32BIT_KERNEL
-+ select SYS_SUPPORTS_BIG_ENDIAN
-+ select SYS_HAS_EARLY_PRINTK
-+ select MIPS_MACHINE
-+ help
-+ Support for Atheros AR71xx based boards.
-+
- config BASLER_EXCITE
- bool "Basler eXcite smart camera"
- select CEVT_R4K
-@@ -640,6 +657,7 @@
- endchoice
-
- source "arch/mips/alchemy/Kconfig"
-+source "arch/mips/ar71xx/Kconfig"
- source "arch/mips/basler/excite/Kconfig"
- source "arch/mips/jazz/Kconfig"
- source "arch/mips/lasat/Kconfig"
-@@ -810,6 +828,9 @@
- config SYNC_R4K
- bool
-
-+config MIPS_MACHINE
-+ def_bool n
-+
- config NO_IOPORT
- def_bool n
-
-diff -Nur linux-2.6.29.1.orig/arch/mips/Makefile linux-2.6.29.1/arch/mips/Makefile
---- linux-2.6.29.1.orig/arch/mips/Makefile 2009-04-02 22:55:27.000000000 +0200
-+++ linux-2.6.29.1/arch/mips/Makefile 2009-04-13 14:27:34.483063970 +0200
-@@ -602,6 +602,14 @@
- load-$(CONFIG_CPU_CAVIUM_OCTEON) += 0xffffffff81100000
- endif
-
-+#
-+# Atheros AR71xx
-+#
-+core-$(CONFIG_ATHEROS_AR71XX) += arch/mips/ar71xx/
-+cflags-$(CONFIG_ATHEROS_AR71XX) += -I$(srctree)/arch/mips/include/asm/mach-ar71xx
-+load-$(CONFIG_ATHEROS_AR71XX) += 0xffffffff80060000
-+
-+
- cflags-y += -I$(srctree)/arch/mips/include/asm/mach-generic
- drivers-$(CONFIG_PCI) += arch/mips/pci/
-
-diff -Nur linux-2.6.29.1.orig/arch/mips/ar71xx/Kconfig linux-2.6.29.1/arch/mips/ar71xx/Kconfig
---- linux-2.6.29.1.orig/arch/mips/ar71xx/Kconfig 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.29.1/arch/mips/ar71xx/Kconfig 2009-04-13 14:27:34.483063970 +0200
-@@ -0,0 +1,64 @@
-+if ATHEROS_AR71XX
-+
-+config AR71XX_EARLY_SERIAL
-+ bool "Use early serial console"
-+ default n
-+
-+menu "Atheros AR71xx machine selection"
-+
-+config AR71XX_MACH_AP81
-+ bool "Atheros AP81 board support"
-+ default y
-+
-+config AR71XX_MACH_AP83
-+ bool "Atheros AP83 board support"
-+ default y
-+
-+config AR71XX_MACH_PB42
-+ bool "Atheros PB42 board support"
-+ default y
-+
-+config AR71XX_MACH_AW_NR580
-+ bool "AzureWave AW-NR580 board support"
-+ default y
-+
-+config AR71XX_MACH_GENERIC
-+ bool "Generic AR71xx based machine support"
-+ default y
-+
-+config AR71XX_MACH_WP543
-+ bool "Compex WP543 board support"
-+ select MYLOADER
-+ default y
-+
-+config AR71XX_MACH_RB_4XX
-+ bool "MikroTik RouterBOARD 4xx series support"
-+ default y
-+
-+config AR71XX_MACH_WNR2000
-+ bool "NETGEAR WNR2000 board support"
-+ default y
-+
-+config AR71XX_MACH_MZK_W04NU
-+ bool "Planex MZK-W04NU board support"
-+ default y
-+
-+config AR71XX_MACH_MZK_W300NH
-+ bool "Planex MZK-W300NH board support"
-+ default y
-+
-+config AR71XX_MACH_TL_WR941ND
-+ bool "TP-LINK TL-WR941ND support"
-+ default y
-+
-+config AR71XX_MACH_TEW_632BRP
-+ bool "TRENDnet TEW-632BRP support"
-+ default y
-+
-+config AR71XX_MACH_UBNT
-+ bool "Ubiquiti AR71xx based boards support"
-+ default y
-+
-+endmenu
-+
-+endif
-diff -Nur linux-2.6.29.1.orig/arch/mips/ar71xx/Makefile linux-2.6.29.1/arch/mips/ar71xx/Makefile
---- linux-2.6.29.1.orig/arch/mips/ar71xx/Makefile 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.29.1/arch/mips/ar71xx/Makefile 2009-04-13 14:27:34.487064480 +0200
-@@ -0,0 +1,25 @@
-+#
-+# Makefile for the Atheros AR71xx SoC specific parts of the kernel
-+#
-+# Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org>
-+# Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
-+#
-+# This program is free software; you can redistribute it and/or modify it
-+# under the terms of the GNU General Public License version 2 as published
-+# by the Free Software Foundation.
-+
-+obj-y := prom.o irq.o setup.o devices.o gpio.o ar71xx.o
-+
-+obj-$(CONFIG_AR71XX_MACH_AP81) += mach-ap81.o
-+obj-$(CONFIG_AR71XX_MACH_AP83) += mach-ap83.o
-+obj-$(CONFIG_AR71XX_MACH_AW_NR580) += mach-aw-nr580.o
-+obj-$(CONFIG_AR71XX_MACH_GENERIC) += mach-generic.o
-+obj-$(CONFIG_AR71XX_MACH_MZK_W04NU) += mach-mzk-w04nu.o
-+obj-$(CONFIG_AR71XX_MACH_MZK_W300NH) += mach-mzk-w300nh.o
-+obj-$(CONFIG_AR71XX_MACH_PB42) += mach-pb42.o
-+obj-$(CONFIG_AR71XX_MACH_RB_4XX) += mach-rb-4xx.o
-+obj-$(CONFIG_AR71XX_MACH_TEW_632BRP) += mach-tew-632brp.o
-+obj-$(CONFIG_AR71XX_MACH_TL_WR941ND) += mach-tl-wr941nd.o
-+obj-$(CONFIG_AR71XX_MACH_UBNT) += mach-ubnt.o
-+obj-$(CONFIG_AR71XX_MACH_WNR2000) += mach-wnr2000.o
-+obj-$(CONFIG_AR71XX_MACH_WP543) += mach-wp543.o
-diff -Nur linux-2.6.29.1.orig/arch/mips/ar71xx/ar71xx.c linux-2.6.29.1/arch/mips/ar71xx/ar71xx.c
---- linux-2.6.29.1.orig/arch/mips/ar71xx/ar71xx.c 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.29.1/arch/mips/ar71xx/ar71xx.c 2009-04-13 14:27:34.487064480 +0200
-@@ -0,0 +1,100 @@
-+/*
-+ * AR71xx SoC routines
-+ *
-+ * Copyright (C) 2008 Gabor Juhos <juhosg@openwrt.org>
-+ * Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
-+ *
-+ * This program is free software; you can redistribute it and/or modify it
-+ * under the terms of the GNU General Public License version 2 as published
-+ * by the Free Software Foundation.
-+ */
-+
-+#include <linux/kernel.h>
-+#include <linux/module.h>
-+#include <linux/types.h>
-+
-+#include <asm/mach-ar71xx/ar71xx.h>
-+
-+void __iomem *ar71xx_ddr_base;
-+EXPORT_SYMBOL_GPL(ar71xx_ddr_base);
-+
-+void __iomem *ar71xx_pll_base;
-+EXPORT_SYMBOL_GPL(ar71xx_pll_base);
-+
-+void __iomem *ar71xx_reset_base;
-+EXPORT_SYMBOL_GPL(ar71xx_reset_base);
-+
-+void __iomem *ar71xx_gpio_base;
-+EXPORT_SYMBOL_GPL(ar71xx_gpio_base);
-+
-+void __iomem *ar71xx_usb_ctrl_base;
-+EXPORT_SYMBOL_GPL(ar71xx_usb_ctrl_base);
-+
-+void ar71xx_device_stop(u32 mask)
-+{
-+ unsigned long flags;
-+ u32 t;
-+
-+ switch (ar71xx_soc) {
-+ case AR71XX_SOC_AR7130:
-+ case AR71XX_SOC_AR7141:
-+ case AR71XX_SOC_AR7161:
-+ local_irq_save(flags);
-+ t = ar71xx_reset_rr(AR71XX_RESET_REG_RESET_MODULE);
-+ ar71xx_reset_wr(AR71XX_RESET_REG_RESET_MODULE, t | mask);
-+ local_irq_restore(flags);
-+ break;
-+
-+ case AR71XX_SOC_AR9130:
-+ case AR71XX_SOC_AR9132:
-+ local_irq_save(flags);
-+ t = ar71xx_reset_rr(AR91XX_RESET_REG_RESET_MODULE);
-+ ar71xx_reset_wr(AR91XX_RESET_REG_RESET_MODULE, t | mask);
-+ local_irq_restore(flags);
-+ break;
-+
-+ default:
-+ BUG();
-+ }
-+}
-+EXPORT_SYMBOL_GPL(ar71xx_device_stop);
-+
-+void ar71xx_device_start(u32 mask)
-+{
-+ unsigned long flags;
-+ u32 t;
-+
-+ switch (ar71xx_soc) {
-+ case AR71XX_SOC_AR7130:
-+ case AR71XX_SOC_AR7141:
-+ case AR71XX_SOC_AR7161:
-+ local_irq_save(flags);
-+ t = ar71xx_reset_rr(AR71XX_RESET_REG_RESET_MODULE);
-+ ar71xx_reset_wr(AR71XX_RESET_REG_RESET_MODULE, t & ~mask);
-+ local_irq_restore(flags);
-+ break;
-+
-+ case AR71XX_SOC_AR9130:
-+ case AR71XX_SOC_AR9132:
-+ local_irq_save(flags);
-+ t = ar71xx_reset_rr(AR91XX_RESET_REG_RESET_MODULE);
-+ ar71xx_reset_wr(AR91XX_RESET_REG_RESET_MODULE, t & ~mask);
-+ local_irq_restore(flags);
-+ break;
-+
-+ default:
-+ BUG();
-+ }
-+}
-+EXPORT_SYMBOL_GPL(ar71xx_device_start);
-+
-+void ar71xx_ddr_flush(u32 reg)
-+{
-+ ar71xx_ddr_wr(reg, 1);
-+ while ((ar71xx_ddr_rr(reg) & 0x1));
-+
-+ ar71xx_ddr_wr(reg, 1);
-+ while ((ar71xx_ddr_rr(reg) & 0x1));
-+}
-+EXPORT_SYMBOL_GPL(ar71xx_ddr_flush);
-+
-diff -Nur linux-2.6.29.1.orig/arch/mips/ar71xx/devices.c linux-2.6.29.1/arch/mips/ar71xx/devices.c
---- linux-2.6.29.1.orig/arch/mips/ar71xx/devices.c 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.29.1/arch/mips/ar71xx/devices.c 2009-04-13 14:27:34.491064431 +0200
-@@ -0,0 +1,675 @@
-+/*
-+ * Atheros AR71xx SoC platform devices
-+ *
-+ * Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org>
-+ * Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
-+ *
-+ * Parts of this file are based on Atheros' 2.6.15 BSP
-+ *
-+ * This program is free software; you can redistribute it and/or modify it
-+ * under the terms of the GNU General Public License version 2 as published
-+ * by the Free Software Foundation.
-+ */
-+
-+#include <linux/kernel.h>
-+#include <linux/init.h>
-+#include <linux/delay.h>
-+#include <linux/dma-mapping.h>
-+#include <linux/etherdevice.h>
-+#include <linux/platform_device.h>
-+#include <linux/serial_8250.h>
-+#include <linux/ath9k_platform.h>
-+
-+#include <asm/mach-ar71xx/ar71xx.h>
-+
-+#include "devices.h"
-+
-+static u8 ar71xx_mac_base[ETH_ALEN] __initdata;
-+
-+/*
-+ * OHCI (USB full speed host controller)
-+ */
-+static struct resource ar71xx_ohci_resources[] = {
-+ [0] = {
-+ .start = AR71XX_OHCI_BASE,
-+ .end = AR71XX_OHCI_BASE + AR71XX_OHCI_SIZE - 1,
-+ .flags = IORESOURCE_MEM,
-+ },
-+ [1] = {
-+ .start = AR71XX_MISC_IRQ_OHCI,
-+ .end = AR71XX_MISC_IRQ_OHCI,
-+ .flags = IORESOURCE_IRQ,
-+ },
-+};
-+
-+static u64 ar71xx_ohci_dmamask = DMA_BIT_MASK(32);
-+static struct platform_device ar71xx_ohci_device = {
-+ .name = "ar71xx-ohci",
-+ .id = -1,
-+ .resource = ar71xx_ohci_resources,
-+ .num_resources = ARRAY_SIZE(ar71xx_ohci_resources),
-+ .dev = {
-+ .dma_mask = &ar71xx_ohci_dmamask,
-+ .coherent_dma_mask = DMA_BIT_MASK(32),
-+ },
-+};
-+
-+/*
-+ * EHCI (USB full speed host controller)
-+ */
-+static struct resource ar71xx_ehci_resources[] = {
-+ [0] = {
-+ .start = AR71XX_EHCI_BASE,
-+ .end = AR71XX_EHCI_BASE + AR71XX_EHCI_SIZE - 1,
-+ .flags = IORESOURCE_MEM,
-+ },
-+ [1] = {
-+ .start = AR71XX_CPU_IRQ_USB,
-+ .end = AR71XX_CPU_IRQ_USB,
-+ .flags = IORESOURCE_IRQ,
-+ },
-+};
-+
-+
-+static u64 ar71xx_ehci_dmamask = DMA_BIT_MASK(32);
-+static struct ar71xx_ehci_platform_data ar71xx_ehci_data;
-+
-+static struct platform_device ar71xx_ehci_device = {
-+ .name = "ar71xx-ehci",
-+ .id = -1,
-+ .resource = ar71xx_ehci_resources,
-+ .num_resources = ARRAY_SIZE(ar71xx_ehci_resources),
-+ .dev = {
-+ .dma_mask = &ar71xx_ehci_dmamask,
-+ .coherent_dma_mask = DMA_BIT_MASK(32),
-+ .platform_data = &ar71xx_ehci_data,
-+ },
-+};
-+
-+#define AR71XX_USB_RESET_MASK \
-+ (RESET_MODULE_USB_HOST | RESET_MODULE_USB_PHY \
-+ | RESET_MODULE_USB_OHCI_DLL)
-+
-+static void ar71xx_usb_setup(void)
-+{
-+ ar71xx_device_stop(AR71XX_USB_RESET_MASK);
-+ mdelay(1000);
-+ ar71xx_device_start(AR71XX_USB_RESET_MASK);
-+
-+ /* Turning on the Buff and Desc swap bits */
-+ ar71xx_usb_ctrl_wr(USB_CTRL_REG_CONFIG, 0xf0000);
-+
-+ /* WAR for HW bug. Here it adjusts the duration between two SOFS */
-+ ar71xx_usb_ctrl_wr(USB_CTRL_REG_FLADJ, 0x20c00);
-+
-+ mdelay(900);
-+}
-+
-+static void ar91xx_usb_setup(void)
-+{
-+ ar71xx_device_stop(RESET_MODULE_USBSUS_OVERRIDE);
-+ mdelay(10);
-+
-+ ar71xx_device_start(RESET_MODULE_USB_HOST);
-+ mdelay(10);
-+
-+ ar71xx_device_start(RESET_MODULE_USB_PHY);
-+ mdelay(10);
-+}
-+
-+void __init ar71xx_add_device_usb(void)
-+{
-+ switch (ar71xx_soc) {
-+ case AR71XX_SOC_AR7130:
-+ case AR71XX_SOC_AR7141:
-+ case AR71XX_SOC_AR7161:
-+ ar71xx_usb_setup();
-+ platform_device_register(&ar71xx_ohci_device);
-+ platform_device_register(&ar71xx_ehci_device);
-+ break;
-+
-+ case AR71XX_SOC_AR9130:
-+ case AR71XX_SOC_AR9132:
-+ ar91xx_usb_setup();
-+ ar71xx_ehci_data.is_ar91xx = 1;
-+ platform_device_register(&ar71xx_ehci_device);
-+ break;
-+
-+ default:
-+ BUG();
-+ }
-+}
-+
-+#ifndef CONFIG_AR71XX_EARLY_SERIAL
-+static struct resource ar71xx_uart_resources[] = {
-+ {
-+ .start = AR71XX_UART_BASE,
-+ .end = AR71XX_UART_BASE + AR71XX_UART_SIZE - 1,
-+ .flags = IORESOURCE_MEM,
-+ },
-+};
-+
-+#define AR71XX_UART_FLAGS (UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_IOREMAP)
-+static struct plat_serial8250_port ar71xx_uart_data[] = {
-+ {
-+ .mapbase = AR71XX_UART_BASE,
-+ .irq = AR71XX_MISC_IRQ_UART,
-+ .flags = AR71XX_UART_FLAGS,
-+ .iotype = UPIO_MEM32,
-+ .regshift = 2,
-+ }, {
-+ /* terminating entry */
-+ }
-+};
-+
-+static struct platform_device ar71xx_uart_device = {
-+ .name = "serial8250",
-+ .id = PLAT8250_DEV_PLATFORM,
-+ .resource = ar71xx_uart_resources,
-+ .num_resources = ARRAY_SIZE(ar71xx_uart_resources),
-+ .dev = {
-+ .platform_data = ar71xx_uart_data
-+ },
-+};
-+
-+void __init ar71xx_add_device_uart(void)
-+{
-+ ar71xx_uart_data[0].uartclk = ar71xx_ahb_freq;
-+ platform_device_register(&ar71xx_uart_device);
-+}
-+#endif /* CONFIG_AR71XX_EARLY_SERIAL */
-+
-+static struct resource ar71xx_mdio_resources[] = {
-+ {
-+ .name = "mdio_base",
-+ .flags = IORESOURCE_MEM,
-+ .start = AR71XX_GE0_BASE + 0x20,
-+ .end = AR71XX_GE0_BASE + 0x38 - 1,
-+ }
-+};
-+
-+static struct ag71xx_mdio_platform_data ar71xx_mdio_data = {
-+ .phy_mask = 0xffffffff,
-+};
-+
-+static struct platform_device ar71xx_mdio_device = {
-+ .name = "ag71xx-mdio",
-+ .id = -1,
-+ .resource = ar71xx_mdio_resources,
-+ .num_resources = ARRAY_SIZE(ar71xx_mdio_resources),
-+ .dev = {
-+ .platform_data = &ar71xx_mdio_data,
-+ },
-+};
-+
-+void __init ar71xx_add_device_mdio(u32 phy_mask)
-+{
-+ ar71xx_mdio_data.phy_mask = phy_mask;
-+ platform_device_register(&ar71xx_mdio_device);
-+}
-+
-+static void ar71xx_set_pll(u32 cfg_reg, u32 pll_reg, u32 pll_val, u32 shift)
-+{
-+ void __iomem *base;
-+ u32 t;
-+
-+ base = ioremap_nocache(AR71XX_PLL_BASE, AR71XX_PLL_SIZE);
-+
-+ t = __raw_readl(base + cfg_reg);
-+ t &= ~(3 << shift);
-+ t |= (2 << shift);
-+ __raw_writel(t, base + cfg_reg);
-+ udelay(100);
-+
-+ __raw_writel(pll_val, base + pll_reg);
-+
-+ t |= (3 << shift);
-+ __raw_writel(t, base + cfg_reg);
-+ udelay(100);
-+
-+ t &= ~(3 << shift);
-+ __raw_writel(t, base + cfg_reg);
-+ udelay(100);
-+
-+ printk(KERN_DEBUG "ar71xx: pll_reg %#x: %#x\n",
-+ (unsigned int)(base + pll_reg), __raw_readl(base + pll_reg));
-+
-+ iounmap(base);
-+}
-+
-+static void ar71xx_set_pll_ge0(u32 val)
-+{
-+ ar71xx_set_pll(AR71XX_PLL_REG_SEC_CONFIG, AR71XX_PLL_REG_ETH0_INT_CLOCK,
-+ val, AR71XX_ETH0_PLL_SHIFT);
-+}
-+
-+static void ar71xx_set_pll_ge1(u32 val)
-+{
-+ ar71xx_set_pll(AR71XX_PLL_REG_SEC_CONFIG, AR71XX_PLL_REG_ETH1_INT_CLOCK,
-+ val, AR71XX_ETH1_PLL_SHIFT);
-+}
-+
-+static void ar91xx_set_pll_ge0(u32 val)
-+{
-+ ar71xx_set_pll(AR91XX_PLL_REG_ETH_CONFIG, AR91XX_PLL_REG_ETH0_INT_CLOCK,
-+ val, AR91XX_ETH0_PLL_SHIFT);
-+}
-+
-+static void ar91xx_set_pll_ge1(u32 val)
-+{
-+ ar71xx_set_pll(AR91XX_PLL_REG_ETH_CONFIG, AR91XX_PLL_REG_ETH1_INT_CLOCK,
-+ val, AR91XX_ETH1_PLL_SHIFT);
-+}
-+
-+static void ar71xx_ddr_flush_ge0(void)
-+{
-+ ar71xx_ddr_flush(AR71XX_DDR_REG_FLUSH_GE0);
-+}
-+
-+static void ar71xx_ddr_flush_ge1(void)
-+{
-+ ar71xx_ddr_flush(AR71XX_DDR_REG_FLUSH_GE1);
-+}
-+
-+static void ar91xx_ddr_flush_ge0(void)
-+{
-+ ar71xx_ddr_flush(AR91XX_DDR_REG_FLUSH_GE0);
-+}
-+
-+static void ar91xx_ddr_flush_ge1(void)
-+{
-+ ar71xx_ddr_flush(AR91XX_DDR_REG_FLUSH_GE1);
-+}
-+
-+static struct resource ar71xx_eth0_resources[] = {
-+ {
-+ .name = "mac_base",
-+ .flags = IORESOURCE_MEM,
-+ .start = AR71XX_GE0_BASE,
-+ .end = AR71XX_GE0_BASE + 0x20 - 1,
-+ }, {
-+ .name = "mac_base2",
-+ .flags = IORESOURCE_MEM,
-+ .start = AR71XX_GE0_BASE + 0x38,
-+ .end = AR71XX_GE0_BASE + 0x200 - 1,
-+ }, {
-+ .name = "mii_ctrl",
-+ .flags = IORESOURCE_MEM,
-+ .start = AR71XX_MII_BASE + MII_REG_MII0_CTRL,
-+ .end = AR71XX_MII_BASE + MII_REG_MII0_CTRL + 3,
-+ }, {
-+ .name = "mac_irq",
-+ .flags = IORESOURCE_IRQ,
-+ .start = AR71XX_CPU_IRQ_GE0,
-+ .end = AR71XX_CPU_IRQ_GE0,
-+ },
-+};
-+
-+struct ag71xx_platform_data ar71xx_eth0_data = {
-+ .reset_bit = RESET_MODULE_GE0_MAC,
-+};
-+
-+static struct platform_device ar71xx_eth0_device = {
-+ .name = "ag71xx",
-+ .id = 0,
-+ .resource = ar71xx_eth0_resources,
-+ .num_resources = ARRAY_SIZE(ar71xx_eth0_resources),
-+ .dev = {
-+ .platform_data = &ar71xx_eth0_data,
-+ },
-+};
-+
-+static struct resource ar71xx_eth1_resources[] = {
-+ {
-+ .name = "mac_base",
-+ .flags = IORESOURCE_MEM,
-+ .start = AR71XX_GE1_BASE,
-+ .end = AR71XX_GE1_BASE + 0x20 - 1,
-+ }, {
-+ .name = "mac_base2",
-+ .flags = IORESOURCE_MEM,
-+ .start = AR71XX_GE1_BASE + 0x38,
-+ .end = AR71XX_GE1_BASE + 0x200 - 1,
-+ }, {
-+ .name = "mii_ctrl",
-+ .flags = IORESOURCE_MEM,
-+ .start = AR71XX_MII_BASE + MII_REG_MII1_CTRL,
-+ .end = AR71XX_MII_BASE + MII_REG_MII1_CTRL + 3,
-+ }, {
-+ .name = "mac_irq",
-+ .flags = IORESOURCE_IRQ,
-+ .start = AR71XX_CPU_IRQ_GE1,
-+ .end = AR71XX_CPU_IRQ_GE1,
-+ },
-+};
-+
-+struct ag71xx_platform_data ar71xx_eth1_data = {
-+ .reset_bit = RESET_MODULE_GE1_MAC,
-+};
-+
-+static struct platform_device ar71xx_eth1_device = {
-+ .name = "ag71xx",
-+ .id = 1,
-+ .resource = ar71xx_eth1_resources,
-+ .num_resources = ARRAY_SIZE(ar71xx_eth1_resources),
-+ .dev = {
-+ .platform_data = &ar71xx_eth1_data,
-+ },
-+};
-+
-+static int ar71xx_eth_instance __initdata;
-+void __init ar71xx_add_device_eth(unsigned int id)
-+{
-+ struct platform_device *pdev;
-+ struct ag71xx_platform_data *pdata;
-+
-+ switch (id) {
-+ case 0:
-+ switch (ar71xx_eth0_data.phy_if_mode) {
-+ case PHY_INTERFACE_MODE_MII:
-+ ar71xx_eth0_data.mii_if = MII0_CTRL_IF_MII;
-+ break;
-+ case PHY_INTERFACE_MODE_GMII:
-+ ar71xx_eth0_data.mii_if = MII0_CTRL_IF_GMII;
-+ break;
-+ case PHY_INTERFACE_MODE_RGMII:
-+ ar71xx_eth0_data.mii_if = MII0_CTRL_IF_RGMII;
-+ break;
-+ case PHY_INTERFACE_MODE_RMII:
-+ ar71xx_eth0_data.mii_if = MII0_CTRL_IF_RMII;
-+ break;
-+ default:
-+ printk(KERN_ERR "ar71xx: invalid PHY interface mode "
-+ "for eth0\n");
-+ return;
-+ }
-+ pdev = &ar71xx_eth0_device;
-+ break;
-+ case 1:
-+ switch (ar71xx_eth1_data.phy_if_mode) {
-+ case PHY_INTERFACE_MODE_RMII:
-+ ar71xx_eth1_data.mii_if = MII1_CTRL_IF_RMII;
-+ break;
-+ case PHY_INTERFACE_MODE_RGMII:
-+ ar71xx_eth1_data.mii_if = MII1_CTRL_IF_RGMII;
-+ break;
-+ default:
-+ printk(KERN_ERR "ar71xx: invalid PHY interface mode "
-+ "for eth1\n");
-+ return;
-+ }
-+ pdev = &ar71xx_eth1_device;
-+ break;
-+ default:
-+ printk(KERN_ERR "ar71xx: invalid ethernet id %d\n", id);
-+ return;
-+ }
-+
-+ pdata = pdev->dev.platform_data;
-+
-+ switch (ar71xx_soc) {
-+ case AR71XX_SOC_AR7130:
-+ pdata->ddr_flush = id ? ar71xx_ddr_flush_ge1
-+ : ar71xx_ddr_flush_ge0;
-+ pdata->set_pll = id ? ar71xx_set_pll_ge1
-+ : ar71xx_set_pll_ge0;
-+ break;
-+
-+ case AR71XX_SOC_AR7141:
-+ case AR71XX_SOC_AR7161:
-+ pdata->ddr_flush = id ? ar71xx_ddr_flush_ge1
-+ : ar71xx_ddr_flush_ge0;
-+ pdata->set_pll = id ? ar71xx_set_pll_ge1
-+ : ar71xx_set_pll_ge0;
-+ pdata->has_gbit = 1;
-+ break;
-+
-+ case AR71XX_SOC_AR9130:
-+ pdata->ddr_flush = id ? ar91xx_ddr_flush_ge1
-+ : ar91xx_ddr_flush_ge0;
-+ pdata->set_pll = id ? ar91xx_set_pll_ge1
-+ : ar91xx_set_pll_ge0;
-+ pdata->is_ar91xx = 1;
-+ break;
-+
-+ case AR71XX_SOC_AR9132:
-+ pdata->ddr_flush = id ? ar91xx_ddr_flush_ge1
-+ : ar91xx_ddr_flush_ge0;
-+ pdata->set_pll = id ? ar91xx_set_pll_ge1
-+ : ar91xx_set_pll_ge0;
-+ pdata->is_ar91xx = 1;
-+ pdata->has_gbit = 1;
-+ break;
-+
-+ default:
-+ BUG();
-+ }
-+
-+ switch (pdata->phy_if_mode) {
-+ case PHY_INTERFACE_MODE_GMII:
-+ case PHY_INTERFACE_MODE_RGMII:
-+ if (!pdata->has_gbit) {
-+ printk(KERN_ERR "ar71xx: no gbit available on eth%d\n",
-+ id);
-+ return;
-+ }
-+ /* fallthrough */
-+ default:
-+ break;
-+ }
-+
-+ if (is_valid_ether_addr(ar71xx_mac_base)) {
-+ memcpy(pdata->mac_addr, ar71xx_mac_base, ETH_ALEN);
-+ pdata->mac_addr[5] += ar71xx_eth_instance;
-+ } else {
-+ random_ether_addr(pdata->mac_addr);
-+ printk(KERN_DEBUG
-+ "ar71xx: using random MAC address for eth%d\n",
-+ ar71xx_eth_instance);
-+ }
-+
-+ platform_device_register(pdev);
-+ ar71xx_eth_instance++;
-+}
-+
-+static struct resource ar71xx_spi_resources[] = {
-+ [0] = {
-+ .start = AR71XX_SPI_BASE,
-+ .end = AR71XX_SPI_BASE + AR71XX_SPI_SIZE - 1,
-+ .flags = IORESOURCE_MEM,
-+ },
-+};
-+
-+static struct platform_device ar71xx_spi_device = {
-+ .name = "ar71xx-spi",
-+ .id = -1,
-+ .resource = ar71xx_spi_resources,
-+ .num_resources = ARRAY_SIZE(ar71xx_spi_resources),
-+};
-+
-+void __init ar71xx_add_device_spi(struct ar71xx_spi_platform_data *pdata,
-+ struct spi_board_info const *info,
-+ unsigned n)
-+{
-+ spi_register_board_info(info, n);
-+ ar71xx_spi_device.dev.platform_data = pdata;
-+ platform_device_register(&ar71xx_spi_device);
-+}
-+
-+void __init ar71xx_add_device_leds_gpio(int id, unsigned num_leds,
-+ struct gpio_led *leds)
-+{
-+ struct platform_device *pdev;
-+ struct gpio_led_platform_data pdata;
-+ struct gpio_led *p;
-+ int err;
-+
-+ p = kmalloc(num_leds * sizeof(*p), GFP_KERNEL);
-+ if (!p)
-+ return;
-+
-+ memcpy(p, leds, num_leds * sizeof(*p));
-+
-+ pdev = platform_device_alloc("leds-gpio", id);
-+ if (!pdev)
-+ goto err_free_leds;
-+
-+ memset(&pdata, 0, sizeof(pdata));
-+ pdata.num_leds = num_leds;
-+ pdata.leds = p;
-+
-+ err = platform_device_add_data(pdev, &pdata, sizeof(pdata));
-+ if (err)
-+ goto err_put_pdev;
-+
-+ err = platform_device_add(pdev);
-+ if (err)
-+ goto err_put_pdev;
-+
-+ return;
-+
-+err_put_pdev:
-+ platform_device_put(pdev);
-+
-+err_free_leds:
-+ kfree(p);
-+}
-+
-+void __init ar71xx_add_device_gpio_buttons(int id,
-+ unsigned poll_interval,
-+ unsigned nbuttons,
-+ struct gpio_button *buttons)
-+{
-+ struct platform_device *pdev;
-+ struct gpio_buttons_platform_data pdata;
-+ struct gpio_button *p;
-+ int err;
-+
-+ p = kmalloc(nbuttons * sizeof(*p), GFP_KERNEL);
-+ if (!p)
-+ return;
-+
-+ memcpy(p, buttons, nbuttons * sizeof(*p));
-+
-+ pdev = platform_device_alloc("gpio-buttons", id);
-+ if (!pdev)
-+ goto err_free_buttons;
-+
-+ memset(&pdata, 0, sizeof(pdata));
-+ pdata.poll_interval = poll_interval;
-+ pdata.nbuttons = nbuttons;
-+ pdata.buttons = p;
-+
-+ err = platform_device_add_data(pdev, &pdata, sizeof(pdata));
-+ if (err)
-+ goto err_put_pdev;
-+
-+
-+ err = platform_device_add(pdev);
-+ if (err)
-+ goto err_put_pdev;
-+
-+ return;
-+
-+err_put_pdev:
-+ platform_device_put(pdev);
-+
-+err_free_buttons:
-+ kfree(p);
-+}
-+
-+void __init ar71xx_add_device_wdt(void)
-+{
-+ platform_device_register_simple("ar71xx-wdt", -1, NULL, 0);
-+}
-+
-+void __init ar71xx_set_mac_base(unsigned char *mac)
-+{
-+ memcpy(ar71xx_mac_base, mac, ETH_ALEN);
-+}
-+
-+void __init ar71xx_parse_mac_addr(char *mac_str)
-+{
-+ u8 tmp[ETH_ALEN];
-+ int t;
-+
-+ t = sscanf(mac_str, "%02hhx:%02hhx:%02hhx:%02hhx:%02hhx:%02hhx",
-+ &tmp[0], &tmp[1], &tmp[2], &tmp[3], &tmp[4], &tmp[5]);
-+
-+ if (t != ETH_ALEN)
-+ t = sscanf(mac_str, "%02hhx.%02hhx.%02hhx.%02hhx.%02hhx.%02hhx",
-+ &tmp[0], &tmp[1], &tmp[2], &tmp[3], &tmp[4], &tmp[5]);
-+
-+ if (t == ETH_ALEN)
-+ ar71xx_set_mac_base(tmp);
-+ else
-+ printk(KERN_DEBUG "ar71xx: failed to parse mac address "
-+ "\"%s\"\n", mac_str);
-+}
-+
-+static struct resource ar91xx_wmac_resources[] = {
-+ {
-+ .start = AR91XX_WMAC_BASE,
-+ .end = AR91XX_WMAC_BASE + AR91XX_WMAC_SIZE - 1,
-+ .flags = IORESOURCE_MEM,
-+ }, {
-+ .start = AR71XX_CPU_IRQ_WMAC,
-+ .end = AR71XX_CPU_IRQ_WMAC,
-+ .flags = IORESOURCE_IRQ,
-+ },
-+};
-+
-+static struct ath9k_platform_data ar91xx_wmac_data;
-+
-+static struct platform_device ar91xx_wmac_device = {
-+ .name = "ath9k",
-+ .id = -1,
-+ .resource = ar91xx_wmac_resources,
-+ .num_resources = ARRAY_SIZE(ar91xx_wmac_resources),
-+ .dev = {
-+ .platform_data = &ar91xx_wmac_data,
-+ },
-+};
-+
-+void __init ar91xx_add_device_wmac(void)
-+{
-+ u8 *ee = (u8 *) KSEG1ADDR(0x1fff1000);
-+
-+ memcpy(ar91xx_wmac_data.eeprom_data, ee,
-+ sizeof(ar91xx_wmac_data.eeprom_data));
-+
-+ ar71xx_device_stop(RESET_MODULE_AMBA2WMAC);
-+ mdelay(10);
-+
-+ ar71xx_device_start(RESET_MODULE_AMBA2WMAC);
-+ mdelay(10);
-+
-+ platform_device_register(&ar91xx_wmac_device);
-+}
-+
-+static struct platform_device ar71xx_dsa_switch_device = {
-+ .name = "dsa",
-+ .id = 0,
-+};
-+
-+void __init ar71xx_add_device_dsa(unsigned int id,
-+ struct dsa_platform_data *d)
-+{
-+ switch (id) {
-+ case 0:
-+ d->netdev = &ar71xx_eth0_device.dev;
-+ break;
-+ case 1:
-+ d->netdev = &ar71xx_eth1_device.dev;
-+ break;
-+ default:
-+ printk(KERN_ERR
-+ "ar71xx: invalid ethernet id %d for DSA switch\n",
-+ id);
-+ return;
-+ }
-+ d->mii_bus = &ar71xx_mdio_device.dev;
-+ ar71xx_dsa_switch_device.dev.platform_data = d;
-+
-+ platform_device_register(&ar71xx_dsa_switch_device);
-+}
-diff -Nur linux-2.6.29.1.orig/arch/mips/ar71xx/devices.h linux-2.6.29.1/arch/mips/ar71xx/devices.h
---- linux-2.6.29.1.orig/arch/mips/ar71xx/devices.h 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.29.1/arch/mips/ar71xx/devices.h 2009-04-13 14:27:34.491064431 +0200
-@@ -0,0 +1,58 @@
-+/*
-+ * Atheros AR71xx SoC device definitions
-+ *
-+ * Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org>
-+ * Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
-+ *
-+ * This program is free software; you can redistribute it and/or modify it
-+ * under the terms of the GNU General Public License version 2 as published
-+ * by the Free Software Foundation.
-+ */
-+
-+#ifndef __AR71XX_DEVICES_H
-+#define __AR71XX_DEVICES_H
-+
-+#include <asm/mach-ar71xx/platform.h>
-+
-+#include <linux/leds.h>
-+#include <linux/gpio_buttons.h>
-+#include <net/dsa.h>
-+
-+void ar71xx_add_device_spi(struct ar71xx_spi_platform_data *pdata,
-+ struct spi_board_info const *info,
-+ unsigned n) __init;
-+
-+void ar71xx_set_mac_base(unsigned char *mac) __init;
-+void ar71xx_parse_mac_addr(char *mac_str) __init;
-+
-+extern struct ag71xx_platform_data ar71xx_eth0_data;
-+extern struct ag71xx_platform_data ar71xx_eth1_data;
-+void ar71xx_add_device_eth(unsigned int id) __init;
-+
-+void ar71xx_add_device_mdio(u32 phy_mask) __init;
-+
-+void ar71xx_add_device_leds_gpio(int id,
-+ unsigned num_leds,
-+ struct gpio_led *leds) __init;
-+
-+void ar71xx_add_device_gpio_buttons(int id,
-+ unsigned poll_interval,
-+ unsigned nbuttons,
-+ struct gpio_button *buttons) __init;
-+
-+void ar71xx_add_device_usb(void) __init;
-+
-+#ifdef CONFIG_AR71XX_EARLY_SERIAL
-+static inline void ar71xx_add_device_uart(void) {}
-+#else
-+void ar71xx_add_device_uart(void) __init;
-+#endif
-+
-+void ar71xx_add_device_wdt(void) __init;
-+
-+void ar91xx_add_device_wmac(void) __init;
-+
-+void ar71xx_add_device_dsa(unsigned int id,
-+ struct dsa_platform_data *d) __init;
-+
-+#endif /* __AR71XX_DEVICES_H */
-diff -Nur linux-2.6.29.1.orig/arch/mips/ar71xx/gpio.c linux-2.6.29.1/arch/mips/ar71xx/gpio.c
---- linux-2.6.29.1.orig/arch/mips/ar71xx/gpio.c 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.29.1/arch/mips/ar71xx/gpio.c 2009-04-13 14:27:34.495064103 +0200
-@@ -0,0 +1,154 @@
-+/*
-+ * Atheros AR71xx SoC GPIO API support
-+ *
-+ * Copyright (C) 2008 Gabor Juhos <juhosg@openwrt.org>
-+ * Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
-+ *
-+ * This program is free software; you can redistribute it and/or modify it
-+ * under the terms of the GNU General Public License version 2 as published
-+ * by the Free Software Foundation.
-+ */
-+
-+#include <linux/kernel.h>
-+#include <linux/init.h>
-+#include <linux/module.h>
-+#include <linux/types.h>
-+#include <linux/spinlock.h>
-+#include <linux/io.h>
-+#include <linux/ioport.h>
-+#include <linux/gpio.h>
-+
-+#include <asm/mach-ar71xx/ar71xx.h>
-+
-+static DEFINE_SPINLOCK(ar71xx_gpio_lock);
-+
-+unsigned long ar71xx_gpio_count;
-+EXPORT_SYMBOL(ar71xx_gpio_count);
-+
-+void __ar71xx_gpio_set_value(unsigned gpio, int value)
-+{
-+ unsigned long flags;
-+
-+ spin_lock_irqsave(&ar71xx_gpio_lock, flags);
-+
-+ if (value)
-+ ar71xx_gpio_wr(GPIO_REG_SET, (1 << gpio));
-+ else
-+ ar71xx_gpio_wr(GPIO_REG_CLEAR, (1 << gpio));
-+
-+ spin_unlock_irqrestore(&ar71xx_gpio_lock, flags);
-+}
-+EXPORT_SYMBOL(__ar71xx_gpio_set_value);
-+
-+int __ar71xx_gpio_get_value(unsigned gpio)
-+{
-+ return (ar71xx_gpio_rr(GPIO_REG_IN) & (1 << gpio)) ? 1 : 0;
-+}
-+EXPORT_SYMBOL(__ar71xx_gpio_get_value);
-+
-+static int ar71xx_gpio_get_value(struct gpio_chip *chip, unsigned offset)
-+{
-+ return __ar71xx_gpio_get_value(offset);
-+}
-+
-+static void ar71xx_gpio_set_value(struct gpio_chip *chip,
-+ unsigned offset, int value)
-+{
-+ __ar71xx_gpio_set_value(offset, value);
-+}
-+
-+static int ar71xx_gpio_direction_input(struct gpio_chip *chip,
-+ unsigned offset)
-+{
-+ unsigned long flags;
-+
-+ spin_lock_irqsave(&ar71xx_gpio_lock, flags);
-+
-+ ar71xx_gpio_wr(GPIO_REG_OE,
-+ ar71xx_gpio_rr(GPIO_REG_OE) & ~(1 << offset));
-+
-+ spin_unlock_irqrestore(&ar71xx_gpio_lock, flags);
-+
-+ return 0;
-+}
-+
-+static int ar71xx_gpio_direction_output(struct gpio_chip *chip,
-+ unsigned offset, int value)
-+{
-+ unsigned long flags;
-+
-+ spin_lock_irqsave(&ar71xx_gpio_lock, flags);
-+
-+ if (value)
-+ ar71xx_gpio_wr(GPIO_REG_SET, (1 << offset));
-+ else
-+ ar71xx_gpio_wr(GPIO_REG_CLEAR, (1 << offset));
-+
-+ ar71xx_gpio_wr(GPIO_REG_OE,
-+ ar71xx_gpio_rr(GPIO_REG_OE) | (1 << offset));
-+
-+ spin_unlock_irqrestore(&ar71xx_gpio_lock, flags);
-+
-+ return 0;
-+}
-+
-+static struct gpio_chip ar71xx_gpio_chip = {
-+ .label = "ar71xx",
-+ .get = ar71xx_gpio_get_value,
-+ .set = ar71xx_gpio_set_value,
-+ .direction_input = ar71xx_gpio_direction_input,
-+ .direction_output = ar71xx_gpio_direction_output,
-+ .base = 0,
-+ .ngpio = AR71XX_GPIO_COUNT,
-+};
-+
-+void ar71xx_gpio_function_enable(u32 mask)
-+{
-+ unsigned long flags;
-+
-+ spin_lock_irqsave(&ar71xx_gpio_lock, flags);
-+
-+ ar71xx_gpio_wr(GPIO_REG_FUNC, ar71xx_gpio_rr(GPIO_REG_FUNC) | mask);
-+
-+ spin_unlock_irqrestore(&ar71xx_gpio_lock, flags);
-+}
-+
-+void ar71xx_gpio_function_disable(u32 mask)
-+{
-+ unsigned long flags;
-+
-+ spin_lock_irqsave(&ar71xx_gpio_lock, flags);
-+
-+ ar71xx_gpio_wr(GPIO_REG_FUNC, ar71xx_gpio_rr(GPIO_REG_FUNC) & ~mask);
-+
-+ spin_unlock_irqrestore(&ar71xx_gpio_lock, flags);
-+}
-+
-+void __init ar71xx_gpio_init(void)
-+{
-+ int err;
-+
-+ if (!request_mem_region(AR71XX_GPIO_BASE, AR71XX_GPIO_SIZE,
-+ "AR71xx GPIO controller"))
-+ panic("cannot allocate AR71xx GPIO registers page");
-+
-+ switch (ar71xx_soc) {
-+ case AR71XX_SOC_AR7130:
-+ case AR71XX_SOC_AR7141:
-+ case AR71XX_SOC_AR7161:
-+ ar71xx_gpio_chip.ngpio = AR71XX_GPIO_COUNT;
-+ break;
-+
-+ case AR71XX_SOC_AR9130:
-+ case AR71XX_SOC_AR9132:
-+ ar71xx_gpio_chip.ngpio = AR91XX_GPIO_COUNT;
-+ break;
-+
-+ default:
-+ BUG();
-+ }
-+
-+ err = gpiochip_add(&ar71xx_gpio_chip);
-+ if (err)
-+ panic("cannot add AR71xx GPIO chip, error=%d", err);
-+}
-diff -Nur linux-2.6.29.1.orig/arch/mips/ar71xx/irq.c linux-2.6.29.1/arch/mips/ar71xx/irq.c
---- linux-2.6.29.1.orig/arch/mips/ar71xx/irq.c 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.29.1/arch/mips/ar71xx/irq.c 2009-04-13 14:27:34.543070220 +0200
-@@ -0,0 +1,302 @@
-+/*
-+ * Atheros AR71xx SoC specific interrupt handling
-+ *
-+ * Copyright (C) 2008 Gabor Juhos <juhosg@openwrt.org>
-+ * Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
-+ *
-+ * Parts of this file are based on Atheros' 2.6.15 BSP
-+ *
-+ * This program is free software; you can redistribute it and/or modify it
-+ * under the terms of the GNU General Public License version 2 as published
-+ * by the Free Software Foundation.
-+ */
-+
-+#include <linux/kernel.h>
-+#include <linux/init.h>
-+#include <linux/interrupt.h>
-+#include <linux/irq.h>
-+
-+#include <asm/irq_cpu.h>
-+#include <asm/mipsregs.h>
-+
-+#include <asm/mach-ar71xx/ar71xx.h>
-+
-+#ifdef CONFIG_PCI
-+static void ar71xx_pci_irq_dispatch(void)
-+{
-+ u32 pending;
-+
-+ pending = ar71xx_reset_rr(AR71XX_RESET_REG_PCI_INT_STATUS) &
-+ ar71xx_reset_rr(AR71XX_RESET_REG_PCI_INT_ENABLE);
-+
-+ if (pending & PCI_INT_DEV0)
-+ do_IRQ(AR71XX_PCI_IRQ_DEV0);
-+
-+ else if (pending & PCI_INT_DEV1)
-+ do_IRQ(AR71XX_PCI_IRQ_DEV1);
<