add preliminary support for the Atheros PB42 board
SVN-Revision: 13860
This commit is contained in:
parent
54b85f55d9
commit
f1953fdf4b
9 changed files with 86 additions and 4 deletions
|
@ -7,11 +7,12 @@ CONFIG_AG71XX=y
|
||||||
CONFIG_AR71XX_MACH_AP83=y
|
CONFIG_AR71XX_MACH_AP83=y
|
||||||
CONFIG_AR71XX_MACH_AW_NR580=y
|
CONFIG_AR71XX_MACH_AW_NR580=y
|
||||||
CONFIG_AR71XX_MACH_GENERIC=y
|
CONFIG_AR71XX_MACH_GENERIC=y
|
||||||
|
CONFIG_AR71XX_MACH_PB42=y
|
||||||
CONFIG_AR71XX_MACH_RB_4XX=y
|
CONFIG_AR71XX_MACH_RB_4XX=y
|
||||||
CONFIG_AR71XX_MACH_TEW_632BRP=y
|
CONFIG_AR71XX_MACH_TEW_632BRP=y
|
||||||
CONFIG_AR71XX_MACH_UBNT=y
|
CONFIG_AR71XX_MACH_UBNT=y
|
||||||
CONFIG_AR71XX_MACH_WP543=y
|
|
||||||
CONFIG_AR71XX_MACH_WNR2000=y
|
CONFIG_AR71XX_MACH_WNR2000=y
|
||||||
|
CONFIG_AR71XX_MACH_WP543=y
|
||||||
CONFIG_AR71XX_WDT=y
|
CONFIG_AR71XX_WDT=y
|
||||||
# CONFIG_ARCH_HAS_ILOG2_U32 is not set
|
# CONFIG_ARCH_HAS_ILOG2_U32 is not set
|
||||||
# CONFIG_ARCH_HAS_ILOG2_U64 is not set
|
# CONFIG_ARCH_HAS_ILOG2_U64 is not set
|
||||||
|
|
|
@ -7,11 +7,12 @@ CONFIG_AG71XX=y
|
||||||
CONFIG_AR71XX_MACH_AP83=y
|
CONFIG_AR71XX_MACH_AP83=y
|
||||||
CONFIG_AR71XX_MACH_AW_NR580=y
|
CONFIG_AR71XX_MACH_AW_NR580=y
|
||||||
CONFIG_AR71XX_MACH_GENERIC=y
|
CONFIG_AR71XX_MACH_GENERIC=y
|
||||||
|
CONFIG_AR71XX_MACH_PB42=y
|
||||||
CONFIG_AR71XX_MACH_RB_4XX=y
|
CONFIG_AR71XX_MACH_RB_4XX=y
|
||||||
CONFIG_AR71XX_MACH_TEW_632BRP=y
|
CONFIG_AR71XX_MACH_TEW_632BRP=y
|
||||||
CONFIG_AR71XX_MACH_UBNT=y
|
CONFIG_AR71XX_MACH_UBNT=y
|
||||||
CONFIG_AR71XX_MACH_WP543=y
|
|
||||||
CONFIG_AR71XX_MACH_WNR2000=y
|
CONFIG_AR71XX_MACH_WNR2000=y
|
||||||
|
CONFIG_AR71XX_MACH_WP543=y
|
||||||
CONFIG_AR71XX_WDT=y
|
CONFIG_AR71XX_WDT=y
|
||||||
# CONFIG_ARCH_HAS_ILOG2_U32 is not set
|
# CONFIG_ARCH_HAS_ILOG2_U32 is not set
|
||||||
# CONFIG_ARCH_HAS_ILOG2_U64 is not set
|
# CONFIG_ARCH_HAS_ILOG2_U64 is not set
|
||||||
|
|
|
@ -7,11 +7,12 @@ CONFIG_AG71XX=y
|
||||||
CONFIG_AR71XX_MACH_AP83=y
|
CONFIG_AR71XX_MACH_AP83=y
|
||||||
CONFIG_AR71XX_MACH_AW_NR580=y
|
CONFIG_AR71XX_MACH_AW_NR580=y
|
||||||
CONFIG_AR71XX_MACH_GENERIC=y
|
CONFIG_AR71XX_MACH_GENERIC=y
|
||||||
|
CONFIG_AR71XX_MACH_PB42=y
|
||||||
CONFIG_AR71XX_MACH_RB_4XX=y
|
CONFIG_AR71XX_MACH_RB_4XX=y
|
||||||
CONFIG_AR71XX_MACH_TEW_632BRP=y
|
CONFIG_AR71XX_MACH_TEW_632BRP=y
|
||||||
CONFIG_AR71XX_MACH_UBNT=y
|
CONFIG_AR71XX_MACH_UBNT=y
|
||||||
CONFIG_AR71XX_MACH_WP543=y
|
|
||||||
CONFIG_AR71XX_MACH_WNR2000=y
|
CONFIG_AR71XX_MACH_WNR2000=y
|
||||||
|
CONFIG_AR71XX_MACH_WP543=y
|
||||||
CONFIG_AR71XX_WDT=y
|
CONFIG_AR71XX_WDT=y
|
||||||
# CONFIG_ARCH_HAS_ILOG2_U32 is not set
|
# CONFIG_ARCH_HAS_ILOG2_U32 is not set
|
||||||
# CONFIG_ARCH_HAS_ILOG2_U64 is not set
|
# CONFIG_ARCH_HAS_ILOG2_U64 is not set
|
||||||
|
|
|
@ -120,6 +120,8 @@ extern unsigned long ar71xx_mach_type;
|
||||||
#define AR71XX_MACH_UBNT_RS 9 /* Ubiquiti RouterStation */
|
#define AR71XX_MACH_UBNT_RS 9 /* Ubiquiti RouterStation */
|
||||||
#define AR71XX_MACH_UBNT_LSX 10 /* Ubiquiti LSX */
|
#define AR71XX_MACH_UBNT_LSX 10 /* Ubiquiti LSX */
|
||||||
#define AR71XX_MACH_WNR2000 11 /* NETGEAR WNR2000 */
|
#define AR71XX_MACH_WNR2000 11 /* NETGEAR WNR2000 */
|
||||||
|
#define AR71XX_MACH_PB42 12 /* Atheros PB42 */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* PLL block
|
* PLL block
|
||||||
|
|
|
@ -10,6 +10,10 @@ config AR71XX_MACH_AP83
|
||||||
bool "Atheros AP83 board support"
|
bool "Atheros AP83 board support"
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config AR71XX_MACH_PB42
|
||||||
|
bool "Atheros PB42 board support"
|
||||||
|
default y
|
||||||
|
|
||||||
config AR71XX_MACH_AW_NR580
|
config AR71XX_MACH_AW_NR580
|
||||||
bool "AzureWave AW-NR580 board support"
|
bool "AzureWave AW-NR580 board support"
|
||||||
default y
|
default y
|
||||||
|
|
|
@ -13,8 +13,9 @@ obj-y := prom.o irq.o setup.o platform.o gpio.o ar71xx.o
|
||||||
obj-$(CONFIG_AR71XX_MACH_AP83) += mach-ap83.o
|
obj-$(CONFIG_AR71XX_MACH_AP83) += mach-ap83.o
|
||||||
obj-$(CONFIG_AR71XX_MACH_AW_NR580) += mach-aw-nr580.o
|
obj-$(CONFIG_AR71XX_MACH_AW_NR580) += mach-aw-nr580.o
|
||||||
obj-$(CONFIG_AR71XX_MACH_GENERIC) += mach-generic.o
|
obj-$(CONFIG_AR71XX_MACH_GENERIC) += mach-generic.o
|
||||||
|
obj-$(CONFIG_AR71XX_MACH_PB42) += mach-pb42.o
|
||||||
obj-$(CONFIG_AR71XX_MACH_RB_4XX) += mach-rb-4xx.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_TEW_632BRP) += mach-tew-632brp.o
|
||||||
obj-$(CONFIG_AR71XX_MACH_UBNT) += mach-ubnt.o
|
obj-$(CONFIG_AR71XX_MACH_UBNT) += mach-ubnt.o
|
||||||
obj-$(CONFIG_AR71XX_MACH_WP543) += mach-wp543.o
|
|
||||||
obj-$(CONFIG_AR71XX_MACH_WNR2000) += mach-wnr2000.o
|
obj-$(CONFIG_AR71XX_MACH_WNR2000) += mach-wnr2000.o
|
||||||
|
obj-$(CONFIG_AR71XX_MACH_WP543) += mach-wp543.o
|
||||||
|
|
68
target/linux/ar71xx/files/arch/mips/ar71xx/mach-pb42.c
Normal file
68
target/linux/ar71xx/files/arch/mips/ar71xx/mach-pb42.c
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
/*
|
||||||
|
* Atheros PB42 board 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/init.h>
|
||||||
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/spi/spi.h>
|
||||||
|
#include <linux/spi/flash.h>
|
||||||
|
|
||||||
|
#include <asm/mips_machine.h>
|
||||||
|
#include <asm/mach-ar71xx/ar71xx.h>
|
||||||
|
#include <asm/mach-ar71xx/pci.h>
|
||||||
|
#include <asm/mach-ar71xx/platform.h>
|
||||||
|
|
||||||
|
static struct spi_board_info pb42_spi_info[] = {
|
||||||
|
{
|
||||||
|
.bus_num = 0,
|
||||||
|
.chip_select = 0,
|
||||||
|
.max_speed_hz = 25000000,
|
||||||
|
.modalias = "m25p80",
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct ar71xx_pci_irq pb42_pci_irqs[] __initdata = {
|
||||||
|
{
|
||||||
|
.slot = 0,
|
||||||
|
.pin = 1,
|
||||||
|
.irq = AR71XX_PCI_IRQ_DEV0,
|
||||||
|
}, {
|
||||||
|
.slot = 1,
|
||||||
|
.pin = 1,
|
||||||
|
.irq = AR71XX_PCI_IRQ_DEV1,
|
||||||
|
}, {
|
||||||
|
.slot = 2,
|
||||||
|
.pin = 1,
|
||||||
|
.irq = AR71XX_PCI_IRQ_DEV2,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static void __init pb42_init(void)
|
||||||
|
{
|
||||||
|
ar71xx_add_device_spi(NULL, pb42_spi_info,
|
||||||
|
ARRAY_SIZE(pb42_spi_info));
|
||||||
|
|
||||||
|
ar71xx_add_device_mdio(0xffe0ffff);
|
||||||
|
|
||||||
|
ar71xx_eth0_data.phy_if_mode = PHY_INTERFACE_MODE_MII;
|
||||||
|
ar71xx_eth0_data.phy_mask = 0x000f0000;
|
||||||
|
|
||||||
|
ar71xx_eth1_data.phy_if_mode = PHY_INTERFACE_MODE_RMII;
|
||||||
|
ar71xx_eth1_data.phy_mask = 0x00100000;
|
||||||
|
|
||||||
|
ar71xx_add_device_eth(0);
|
||||||
|
ar71xx_add_device_eth(1);
|
||||||
|
|
||||||
|
ar71xx_add_device_usb();
|
||||||
|
|
||||||
|
ar71xx_pci_init(ARRAY_SIZE(pb42_pci_irqs), pb42_pci_irqs);
|
||||||
|
}
|
||||||
|
|
||||||
|
MIPS_MACHINE(AR71XX_MACH_PB42, "Atheros PB42", pb42_init);
|
|
@ -61,6 +61,9 @@ static struct board_rec boards[] __initdata = {
|
||||||
}, {
|
}, {
|
||||||
.name = "WNR2000",
|
.name = "WNR2000",
|
||||||
.mach_type = AR71XX_MACH_WNR2000,
|
.mach_type = AR71XX_MACH_WNR2000,
|
||||||
|
}, {
|
||||||
|
.name = "PB42",
|
||||||
|
.mach_type = AR71XX_MACH_PB42,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -120,6 +120,7 @@ extern unsigned long ar71xx_mach_type;
|
||||||
#define AR71XX_MACH_UBNT_RS 9 /* Ubiquiti RouterStation */
|
#define AR71XX_MACH_UBNT_RS 9 /* Ubiquiti RouterStation */
|
||||||
#define AR71XX_MACH_UBNT_LSX 10 /* Ubiquiti LSX */
|
#define AR71XX_MACH_UBNT_LSX 10 /* Ubiquiti LSX */
|
||||||
#define AR71XX_MACH_WNR2000 11 /* NETGEAR WNR2000 */
|
#define AR71XX_MACH_WNR2000 11 /* NETGEAR WNR2000 */
|
||||||
|
#define AR71XX_MACH_PB42 12 /* Atheros PB42 */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* PLL block
|
* PLL block
|
||||||
|
|
Loading…
Reference in a new issue