From 87485f3a88e010622e56248442db5d0fdde4e41f Mon Sep 17 00:00:00 2001 From: juhosg Date: Fri, 6 Apr 2012 06:45:07 +0000 Subject: ar71xx: initial support for Mikrotik RB751G-2HnD and RB751U-2HnD Great collaboration on these two fantastic routers on the openwrt forum: https://forum.openwrt.org/viewtopic.php?id=32320 Above all kudos to aryufan. Well done and thank you everyone else who contributed. To-Do: LED for wlan is not yet activated To-Do: TxPower over 20dBm (RB751U) or 22dBm (RB751G) are not accepted by the router Signed-off-by: Hanno Schupp [juhosg: fix line wrapped patch, fix checkpatch errors, add missing kernel patches] git-svn-id: svn://svn.openwrt.org/openwrt/trunk@31208 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../ar71xx/files/arch/mips/ath79/mach-rb750.c | 92 ++++++++++++++++++++++ 1 file changed, 92 insertions(+) (limited to 'target/linux/ar71xx/files') diff --git a/target/linux/ar71xx/files/arch/mips/ath79/mach-rb750.c b/target/linux/ar71xx/files/arch/mips/ath79/mach-rb750.c index 3187e8f34..3e4a5527f 100644 --- a/target/linux/ar71xx/files/arch/mips/ath79/mach-rb750.c +++ b/target/linux/ar71xx/files/arch/mips/ath79/mach-rb750.c @@ -9,17 +9,24 @@ */ #include +#include +#include #include #include #include #include #include +#include +#include #include #include "common.h" +#include "dev-usb.h" #include "dev-eth.h" #include "machtypes.h" +#include "pci-ath9k-fixup.h" +#include "pci.h" static struct rb750_led_data rb750_leds[] = { { @@ -270,3 +277,88 @@ static void __init rb750gr3_setup(void) MIPS_MACHINE(ATH79_MACH_RB_750G_R3, "750Gr3", "MikroTik RouterBOARD 750GL", rb750gr3_setup); + +static struct ath9k_platform_data rb751_wmac_data = { + .led_pin = -1, +}; + +static u8 rb751_wmac_mac[6]; + +static int rb751_pci_plat_dev_init(struct pci_dev *dev) +{ + switch (PCI_SLOT(dev->devfn)) { + case 0: + dev->dev.platform_data = &rb751_wmac_data; + break; + } + + return 0; +} + +static int decode_rle(char *output, int len, char *in) +{ + char *ptr = output; + char *end = output + len; + while (*in) { + if (*in < 0) { + int i = -*in++; + while (i-- > 0) { + if (ptr >= end) + return -1; + *ptr++ = *in++; + } + } else if (*in > 0) { + int i = *in++; + while (i-- > 0) { + if (ptr >= end) + return -1; + *ptr++ = *in; + } + in++; + } + } + return ptr - output; +} + +#define RB751_HARDCONFIG 0x1f00b000 +#define RB751_MAC_ADDRESS_OFFSET 0xE80 +#define RB751_CALDATA_OFFSET 0x27C + +static void __init rb751_wlan_and_usb_setup(void) +{ + u8 *hardconfig = (u8 *) KSEG1ADDR(RB751_HARDCONFIG); + + ath79_register_usb(); + + ath79_pci_set_plat_dev_init(rb751_pci_plat_dev_init); + ath79_register_pci(); + + rb751_wmac_data.macaddr = memcpy(rb751_wmac_mac, + hardconfig + RB751_MAC_ADDRESS_OFFSET, 6); + + if (decode_rle((char *)rb751_wmac_data.eeprom_data, + sizeof(rb751_wmac_data.eeprom_data), + hardconfig + RB751_CALDATA_OFFSET) == + sizeof(rb751_wmac_data.eeprom_data)) { + pr_info("rb7xx: calibration data found\n"); + pci_enable_ath9k_fixup(0, rb751_wmac_data.eeprom_data); + } +} + +static void __init rb751_setup(void) +{ + rb750_setup(); + rb751_wlan_and_usb_setup(); +} + +MIPS_MACHINE(ATH79_MACH_RB_751, "751", "MikroTik RouterBOARD 751", + rb751_setup); + +static void __init rb751g_setup(void) +{ + rb750gr3_setup(); + rb751_wlan_and_usb_setup(); +} + +MIPS_MACHINE(ATH79_MACH_RB_751G, "751g", "MikroTik RouterBOARD 751G", + rb751g_setup); -- cgit v1.2.3