From ca18bd2e66accae4cb8ca110a5a372b4b081d100 Mon Sep 17 00:00:00 2001 From: juhosg Date: Thu, 12 Feb 2009 19:48:27 +0000 Subject: [PATCH] [ar71xx] add preliminary support for the Ubiquiti LS-SR71 board (thanks to Xianghua Xiao for the initial patch, and for testing) git-svn-id: svn://svn.openwrt.org/openwrt/trunk@14488 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../mips/include/asm/mach-ar71xx/ar71xx.h | 1 + .../ar71xx/files/arch/mips/ar71xx/mach-ubnt.c | 24 +++++++++++++++++-- .../ar71xx/files/arch/mips/ar71xx/prom.c | 3 +++ .../include/asm-mips/mach-ar71xx/ar71xx.h | 1 + 4 files changed, 27 insertions(+), 2 deletions(-) diff --git a/target/linux/ar71xx/files-2.6.28/arch/mips/include/asm/mach-ar71xx/ar71xx.h b/target/linux/ar71xx/files-2.6.28/arch/mips/include/asm/mach-ar71xx/ar71xx.h index a4e6ed3ec..c0f3e7bc9 100644 --- a/target/linux/ar71xx/files-2.6.28/arch/mips/include/asm/mach-ar71xx/ar71xx.h +++ b/target/linux/ar71xx/files-2.6.28/arch/mips/include/asm/mach-ar71xx/ar71xx.h @@ -126,6 +126,7 @@ extern unsigned long ar71xx_mach_type; #define AR71XX_MACH_PB42 12 /* Atheros PB42 */ #define AR71XX_MACH_MZK_W300NH 13 /* Planex MZK-W300NH */ #define AR71XX_MACH_MZK_W04NU 14 /* Planex MZK-W04NU */ +#define AR71XX_MACH_UBNT_LSSR71 15 /* Ubiquiti LS-SR71 */ /* * PLL block diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/mach-ubnt.c b/target/linux/ar71xx/files/arch/mips/ar71xx/mach-ubnt.c index b23d4a973..0cb4181c8 100644 --- a/target/linux/ar71xx/files/arch/mips/ar71xx/mach-ubnt.c +++ b/target/linux/ar71xx/files/arch/mips/ar71xx/mach-ubnt.c @@ -34,7 +34,7 @@ static struct spi_board_info ubnt_spi_info[] = { } }; -static struct ar71xx_pci_irq ubnt_rs_pci_irqs[] __initdata = { +static struct ar71xx_pci_irq ubnt_pci_irqs[] __initdata = { { .slot = 0, .pin = 1, @@ -93,7 +93,7 @@ static void __init ubnt_rs_setup(void) ar71xx_add_device_usb(); - ar71xx_pci_init(ARRAY_SIZE(ubnt_rs_pci_irqs), ubnt_rs_pci_irqs); + ar71xx_pci_init(ARRAY_SIZE(ubnt_pci_irqs), ubnt_pci_irqs); ar71xx_add_device_leds_gpio(-1, ARRAY_SIZE(ubnt_rs_leds_gpio), ubnt_rs_leds_gpio); @@ -109,6 +109,26 @@ static void __init ubnt_lsx_setup(void) { ar71xx_add_device_spi(NULL, ubnt_spi_info, ARRAY_SIZE(ubnt_spi_info)); + } MIPS_MACHINE(AR71XX_MACH_UBNT_LSX, "Ubiquiti LSX", ubnt_lsx_setup); + +#define UBNT_LSSR71_PHY_MASK (1 << 1) + +static void __init ubnt_lssr71_setup(void) +{ + ar71xx_add_device_spi(NULL, ubnt_spi_info, + ARRAY_SIZE(ubnt_spi_info)); + + ar71xx_add_device_mdio(~UBNT_LSSR71_PHY_MASK); + + ar71xx_eth0_data.phy_if_mode = PHY_INTERFACE_MODE_MII; + ar71xx_eth0_data.phy_mask = UBNT_LSSR71_PHY_MASK; + + ar71xx_add_device_eth(0); + + ar71xx_pci_init(ARRAY_SIZE(ubnt_pci_irqs), ubnt_pci_irqs); +} + +MIPS_MACHINE(AR71XX_MACH_UBNT_LSSR71, "Ubiquiti LS-SR71", ubnt_lssr71_setup); diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/prom.c b/target/linux/ar71xx/files/arch/mips/ar71xx/prom.c index 03b03047e..0116d0f5c 100644 --- a/target/linux/ar71xx/files/arch/mips/ar71xx/prom.c +++ b/target/linux/ar71xx/files/arch/mips/ar71xx/prom.c @@ -55,6 +55,9 @@ static struct board_rec boards[] __initdata = { }, { .name = "UBNT-RS", .mach_type = AR71XX_MACH_UBNT_RS, + }, { + .name = "UBNT-LS-SR71", + .mach_type = AR71XX_MACH_UBNT_LSSR71, }, { .name = "UBNT-LSX", .mach_type = AR71XX_MACH_UBNT_LSX, diff --git a/target/linux/ar71xx/files/include/asm-mips/mach-ar71xx/ar71xx.h b/target/linux/ar71xx/files/include/asm-mips/mach-ar71xx/ar71xx.h index a4e6ed3ec..c0f3e7bc9 100644 --- a/target/linux/ar71xx/files/include/asm-mips/mach-ar71xx/ar71xx.h +++ b/target/linux/ar71xx/files/include/asm-mips/mach-ar71xx/ar71xx.h @@ -126,6 +126,7 @@ extern unsigned long ar71xx_mach_type; #define AR71XX_MACH_PB42 12 /* Atheros PB42 */ #define AR71XX_MACH_MZK_W300NH 13 /* Planex MZK-W300NH */ #define AR71XX_MACH_MZK_W04NU 14 /* Planex MZK-W04NU */ +#define AR71XX_MACH_UBNT_LSSR71 15 /* Ubiquiti LS-SR71 */ /* * PLL block