mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-07 14:28:50 +00:00
af015f956c
Tested on the following boards: ALFA AP96 TL-MR3220 v1 TL-WR1043ND v1 TL-WR2543ND v1 TL-WR703N v1 TL-WR741ND v1 TL-WR741ND v4 WNDR3700 v1 WZR-HP-G300NH SVN-Revision: 29868
129 lines
3.1 KiB
Diff
129 lines
3.1 KiB
Diff
--- a/arch/mips/ath79/mach-ap81.c
|
|
+++ b/arch/mips/ath79/mach-ap81.c
|
|
@@ -9,12 +9,16 @@
|
|
* by the Free Software Foundation.
|
|
*/
|
|
|
|
-#include "machtypes.h"
|
|
-#include "dev-wmac.h"
|
|
+#include <linux/mtd/mtd.h>
|
|
+#include <linux/mtd/partitions.h>
|
|
+
|
|
+#include "dev-eth.h"
|
|
#include "dev-gpio-buttons.h"
|
|
#include "dev-leds-gpio.h"
|
|
-#include "dev-spi.h"
|
|
+#include "dev-m25p80.h"
|
|
#include "dev-usb.h"
|
|
+#include "dev-wmac.h"
|
|
+#include "machtypes.h"
|
|
|
|
#define AP81_GPIO_LED_STATUS 1
|
|
#define AP81_GPIO_LED_AOSS 3
|
|
@@ -29,6 +33,37 @@
|
|
|
|
#define AP81_CAL_DATA_ADDR 0x1fff1000
|
|
|
|
+static struct mtd_partition ap81_partitions[] = {
|
|
+ {
|
|
+ .name = "u-boot",
|
|
+ .offset = 0,
|
|
+ .size = 0x040000,
|
|
+ .mask_flags = MTD_WRITEABLE,
|
|
+ }, {
|
|
+ .name = "u-boot-env",
|
|
+ .offset = 0x040000,
|
|
+ .size = 0x010000,
|
|
+ }, {
|
|
+ .name = "rootfs",
|
|
+ .offset = 0x050000,
|
|
+ .size = 0x500000,
|
|
+ }, {
|
|
+ .name = "uImage",
|
|
+ .offset = 0x550000,
|
|
+ .size = 0x100000,
|
|
+ }, {
|
|
+ .name = "ART",
|
|
+ .offset = 0x650000,
|
|
+ .size = 0x1b0000,
|
|
+ .mask_flags = MTD_WRITEABLE,
|
|
+ }
|
|
+};
|
|
+
|
|
+static struct flash_platform_data ap81_flash_data = {
|
|
+ .parts = ap81_partitions,
|
|
+ .nr_parts = ARRAY_SIZE(ap81_partitions),
|
|
+};
|
|
+
|
|
static struct gpio_led ap81_leds_gpio[] __initdata = {
|
|
{
|
|
.name = "ap81:green:status",
|
|
@@ -67,26 +102,6 @@ static struct gpio_keys_button ap81_gpio
|
|
}
|
|
};
|
|
|
|
-static struct ath79_spi_controller_data ap81_spi0_data = {
|
|
- .cs_type = ATH79_SPI_CS_TYPE_INTERNAL,
|
|
- .cs_line = 0,
|
|
-};
|
|
-
|
|
-static struct spi_board_info ap81_spi_info[] = {
|
|
- {
|
|
- .bus_num = 0,
|
|
- .chip_select = 0,
|
|
- .max_speed_hz = 25000000,
|
|
- .modalias = "m25p64",
|
|
- .controller_data = &ap81_spi0_data,
|
|
- }
|
|
-};
|
|
-
|
|
-static struct ath79_spi_platform_data ap81_spi_data = {
|
|
- .bus_num = 0,
|
|
- .num_chipselect = 1,
|
|
-};
|
|
-
|
|
static void __init ap81_setup(void)
|
|
{
|
|
u8 *cal_data = (u8 *) KSEG1ADDR(AP81_CAL_DATA_ADDR);
|
|
@@ -96,10 +111,24 @@ static void __init ap81_setup(void)
|
|
ath79_register_gpio_keys_polled(-1, AP81_KEYS_POLL_INTERVAL,
|
|
ARRAY_SIZE(ap81_gpio_keys),
|
|
ap81_gpio_keys);
|
|
- ath79_register_spi(&ap81_spi_data, ap81_spi_info,
|
|
- ARRAY_SIZE(ap81_spi_info));
|
|
+ ath79_register_m25p80(&ap81_flash_data);
|
|
ath79_register_wmac(cal_data, NULL);
|
|
ath79_register_usb();
|
|
+
|
|
+ ath79_register_mdio(0, 0x0);
|
|
+
|
|
+ ath79_init_mac(ath79_eth0_data.mac_addr, cal_data, 0);
|
|
+ ath79_eth0_data.phy_if_mode = PHY_INTERFACE_MODE_RMII;
|
|
+ ath79_eth0_data.speed = SPEED_100;
|
|
+ ath79_eth0_data.duplex = DUPLEX_FULL;
|
|
+ ath79_eth0_data.has_ar8216 = 1;
|
|
+
|
|
+ ath79_init_mac(ath79_eth1_data.mac_addr, cal_data, 1);
|
|
+ ath79_eth1_data.phy_if_mode = PHY_INTERFACE_MODE_RMII;
|
|
+ ath79_eth1_data.phy_mask = 0x10;
|
|
+
|
|
+ ath79_register_eth(0);
|
|
+ ath79_register_eth(1);
|
|
}
|
|
|
|
MIPS_MACHINE(ATH79_MACH_AP81, "AP81", "Atheros AP81 reference board",
|
|
--- a/arch/mips/ath79/Kconfig
|
|
+++ b/arch/mips/ath79/Kconfig
|
|
@@ -18,9 +18,10 @@ config ATH79_MACH_AP121
|
|
config ATH79_MACH_AP81
|
|
bool "Atheros AP81 reference board"
|
|
select SOC_AR913X
|
|
+ select ATH79_DEV_ETH
|
|
select ATH79_DEV_GPIO_BUTTONS
|
|
select ATH79_DEV_LEDS_GPIO
|
|
- select ATH79_DEV_SPI
|
|
+ select ATH79_DEV_M25P80
|
|
select ATH79_DEV_USB
|
|
select ATH79_DEV_WMAC
|
|
help
|