7bbf4117c6
This add support for kernel 4.9 to the ar71xx target. It was compile tested with the generic, NAND and mikrotik subtarget. Multiple members of the community tested it on their boards and did not report any major problem so far. Especially the NAND part received some changes to adapt to the new kernel APIs. The serial driver hack used for the Arduino Yun was not ported because the kernel changed there a lot. Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
70 lines
2.1 KiB
Diff
70 lines
2.1 KiB
Diff
--- a/arch/mips/ath79/dev-wmac.c
|
|
+++ b/arch/mips/ath79/dev-wmac.c
|
|
@@ -15,6 +15,7 @@
|
|
#include <linux/init.h>
|
|
#include <linux/delay.h>
|
|
#include <linux/irq.h>
|
|
+#include <linux/etherdevice.h>
|
|
#include <linux/platform_device.h>
|
|
#include <linux/ath9k_platform.h>
|
|
|
|
@@ -22,6 +23,7 @@
|
|
#include <asm/mach-ath79/ar71xx_regs.h>
|
|
#include "dev-wmac.h"
|
|
|
|
+static u8 ath79_wmac_mac[ETH_ALEN];
|
|
static struct ath9k_platform_data ath79_wmac_data;
|
|
|
|
static struct resource ath79_wmac_resources[] = {
|
|
@@ -161,7 +163,7 @@ static void qca955x_wmac_setup(void)
|
|
ath79_wmac_data.is_clk_25mhz = true;
|
|
}
|
|
|
|
-void __init ath79_register_wmac(u8 *cal_data)
|
|
+void __init ath79_register_wmac(u8 *cal_data, u8 *mac_addr)
|
|
{
|
|
if (soc_is_ar913x())
|
|
ar913x_wmac_setup();
|
|
@@ -178,5 +180,10 @@ void __init ath79_register_wmac(u8 *cal_
|
|
memcpy(ath79_wmac_data.eeprom_data, cal_data,
|
|
sizeof(ath79_wmac_data.eeprom_data));
|
|
|
|
+ if (mac_addr) {
|
|
+ memcpy(ath79_wmac_mac, mac_addr, sizeof(ath79_wmac_mac));
|
|
+ ath79_wmac_data.macaddr = ath79_wmac_mac;
|
|
+ }
|
|
+
|
|
platform_device_register(&ath79_wmac_device);
|
|
}
|
|
--- a/arch/mips/ath79/dev-wmac.h
|
|
+++ b/arch/mips/ath79/dev-wmac.h
|
|
@@ -12,6 +12,6 @@
|
|
#ifndef _ATH79_DEV_WMAC_H
|
|
#define _ATH79_DEV_WMAC_H
|
|
|
|
-void ath79_register_wmac(u8 *cal_data);
|
|
+void ath79_register_wmac(u8 *cal_data, u8 *mac_addr);
|
|
|
|
#endif /* _ATH79_DEV_WMAC_H */
|
|
--- a/arch/mips/ath79/mach-db120.c
|
|
+++ b/arch/mips/ath79/mach-db120.c
|
|
@@ -128,7 +128,7 @@ static void __init db120_setup(void)
|
|
ath79_register_spi(&db120_spi_data, db120_spi_info,
|
|
ARRAY_SIZE(db120_spi_info));
|
|
ath79_register_usb();
|
|
- ath79_register_wmac(art + DB120_WMAC_CALDATA_OFFSET);
|
|
+ ath79_register_wmac(art + DB120_WMAC_CALDATA_OFFSET, NULL);
|
|
db120_pci_init(art + DB120_PCIE_CALDATA_OFFSET);
|
|
}
|
|
|
|
--- a/arch/mips/ath79/mach-ap121.c
|
|
+++ b/arch/mips/ath79/mach-ap121.c
|
|
@@ -85,7 +85,7 @@ static void __init ap121_setup(void)
|
|
ath79_register_spi(&ap121_spi_data, ap121_spi_info,
|
|
ARRAY_SIZE(ap121_spi_info));
|
|
ath79_register_usb();
|
|
- ath79_register_wmac(cal_data);
|
|
+ ath79_register_wmac(cal_data, NULL);
|
|
}
|
|
|
|
MIPS_MACHINE(ATH79_MACH_AP121, "AP121", "Atheros AP121 reference board",
|