diff options
author | Gabor Juhos <juhosg@openwrt.org> | 2009-02-12 19:48:27 +0000 |
---|---|---|
committer | Gabor Juhos <juhosg@openwrt.org> | 2009-02-12 19:48:27 +0000 |
commit | 40b538d6d24b583f671fa82d99cb819d7c8516ba (patch) | |
tree | fd877b8280ae627fcafe13d4d9bc3862134dc339 /target/linux/ar71xx | |
parent | 31b2c31085b333968fc9e587163141411dd4fb2c (diff) | |
download | upstream-40b538d6d24b583f671fa82d99cb819d7c8516ba.tar.gz upstream-40b538d6d24b583f671fa82d99cb819d7c8516ba.tar.bz2 upstream-40b538d6d24b583f671fa82d99cb819d7c8516ba.zip |
add preliminary support for the Ubiquiti LS-SR71 board (thanks to Xianghua Xiao for the initial patch, and for testing)
SVN-Revision: 14488
Diffstat (limited to 'target/linux/ar71xx')
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 a4e6ed3ecf..c0f3e7bc99 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 b23d4a973f..0cb4181c80 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 03b03047e0..0116d0f5c5 100644 --- a/target/linux/ar71xx/files/arch/mips/ar71xx/prom.c +++ b/target/linux/ar71xx/files/arch/mips/ar71xx/prom.c @@ -56,6 +56,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 a4e6ed3ecf..c0f3e7bc99 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 |