OpenWrt – Rev 1

Subversion Repositories:
Rev:
From 5ed5b5e9614fa5b02da699ab565af76c7e63d64d Mon Sep 17 00:00:00 2001
From: Jonas Gorski <jogo@openwrt.org>
Date: Mon, 7 Jan 2013 17:45:39 +0100
Subject: [PATCH 72/72] 446-BCM63XX-add-a-fixup-for-rt2x00-devices

---
 arch/mips/bcm63xx/Makefile                         |    2 +-
 arch/mips/bcm63xx/boards/board_bcm963xx.c          |   17 ++++-
 arch/mips/bcm63xx/dev-flash.c                      |    2 +-
 arch/mips/bcm63xx/pci-rt2x00-fixup.c               |   71 ++++++++++++++++++++
 .../include/asm/mach-bcm63xx/bcm63xx_dev_flash.h   |    2 +-
 .../mips/include/asm/mach-bcm63xx/board_bcm963xx.h |    9 ++-
 .../include/asm/mach-bcm63xx/pci_rt2x00_fixup.h    |    9 +++
 7 files changed, 104 insertions(+), 8 deletions(-)
 create mode 100644 arch/mips/bcm63xx/pci-rt2x00-fixup.c
 create mode 100644 arch/mips/include/asm/mach-bcm63xx/pci_rt2x00_fixup.h

--- a/arch/mips/bcm63xx/Makefile
+++ b/arch/mips/bcm63xx/Makefile
@@ -3,7 +3,7 @@ obj-y           += clk.o cpu.o cs.o gpio.o irq.o
                   setup.o timer.o dev-enet.o dev-flash.o dev-pcmcia.o \
                   dev-rng.o dev-wdt.o \
                   dev-usb-ehci.o dev-usb-ohci.o dev-usb-usbd.o usb-common.o \
-                  pci-ath9k-fixup.o sprom.o
+                  pci-ath9k-fixup.o pci-rt2x00-fixup.o sprom.o
 obj-$(CONFIG_EARLY_PRINTK)     += early_printk.o
 
 obj-y          += boards/
--- a/arch/mips/bcm63xx/boards/board_common.c
+++ b/arch/mips/bcm63xx/boards/board_common.c
@@ -32,6 +32,7 @@
 #include <bcm63xx_dev_usb_usbd.h>
 #include <board_bcm963xx.h>
 #include <pci_ath9k_fixup.h>
+#include <pci_rt2x00_fixup.h>
 
 #include "board_common.h"
 
@@ -244,9 +245,19 @@ int __init board_register_devices(void)
        }
 
        /* register any fixups */
-       for (i = 0; i < board.has_caldata; i++)
-               pci_enable_ath9k_fixup(board.caldata[i].slot, board.caldata[i].caldata_offset,
-                       board.caldata[i].endian_check, board.caldata[i].led_pin, board.caldata[i].led_active_high);
+       for (i = 0; i < board.has_caldata; i++) {
+               switch (board.caldata[i].vendor) {
+               case PCI_VENDOR_ID_ATHEROS:
+                       pci_enable_ath9k_fixup(board.caldata[i].slot,
+                               board.caldata[i].caldata_offset, board.caldata[i].endian_check,
+                               board.caldata[i].led_pin, board.caldata[i].led_active_high);
+                       break;
+               case PCI_VENDOR_ID_RALINK:
+                       pci_enable_rt2x00_fixup(board.caldata[i].slot,
+                               board.caldata[i].eeprom);
+                       break;
+               }
+       }
 
        return 0;
 }
--- /dev/null
+++ b/arch/mips/bcm63xx/pci-rt2x00-fixup.c
@@ -0,0 +1,72 @@
+/*
+ *  Broadcom BCM63XX RT2x00 EEPROM fixup helper.
+ *
+ *  Copyright (C) 2012 Álvaro Fernández Rojas <noltari@gmail.com>
+ *
+ *  Based on
+ *
+ *  Broadcom BCM63XX Ath9k EEPROM fixup helper.
+ *
+ *  Copyright (C) 2012 Jonas Gorski <jonas.gorski@gmail.com>
+ *
+ *  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/if_ether.h>
+#include <linux/pci.h>
+#include <linux/platform_device.h>
+#include <linux/rt2x00_platform.h>
+
+#include <bcm63xx_nvram.h>
+#include <pci_rt2x00_fixup.h>
+
+struct rt2x00_fixup {
+       unsigned slot;
+       u8 mac[ETH_ALEN];
+       struct rt2x00_platform_data pdata;
+};
+
+static int rt2x00_num_fixups;
+static struct rt2x00_fixup rt2x00_fixups[2] = {
+       {
+               .slot = 255,
+       },
+       {
+               .slot = 255,
+       },
+};
+
+static void rt2x00_pci_fixup(struct pci_dev *dev)
+{
+       unsigned i;
+       struct rt2x00_platform_data *pdata = NULL;
+
+       for (i = 0; i < rt2x00_num_fixups; i++) {
+               if (rt2x00_fixups[i].slot != PCI_SLOT(dev->devfn))
+                       continue;
+
+               pdata = &rt2x00_fixups[i].pdata;
+               break;
+       }
+
+       dev->dev.platform_data = pdata;
+}
+DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_RALINK, PCI_ANY_ID, rt2x00_pci_fixup);
+
+void __init pci_enable_rt2x00_fixup(unsigned slot, char* eeprom)
+{
+       if (rt2x00_num_fixups >= ARRAY_SIZE(rt2x00_fixups))
+               return;
+
+       rt2x00_fixups[rt2x00_num_fixups].slot = slot;
+       rt2x00_fixups[rt2x00_num_fixups].pdata.eeprom_file_name = kstrdup(eeprom, GFP_KERNEL);
+
+       if (bcm63xx_nvram_get_mac_address(rt2x00_fixups[rt2x00_num_fixups].mac))
+               return;
+
+       rt2x00_fixups[rt2x00_num_fixups].pdata.mac_address = rt2x00_fixups[rt2x00_num_fixups].mac;
+       rt2x00_num_fixups++;
+}
+
--- a/arch/mips/include/asm/mach-bcm63xx/board_bcm963xx.h
+++ b/arch/mips/include/asm/mach-bcm63xx/board_bcm963xx.h
@@ -10,6 +10,7 @@
 #include <bcm63xx_dev_usb_usbd.h>
 #include <bcm63xx_fallback_sprom.h>
 #include <pci_ath9k_fixup.h>
+#include <pci_rt2x00_fixup.h>
 
 /*
  * flash mapping
@@ -17,12 +18,16 @@
 #define BCM963XX_CFE_VERSION_OFFSET    0x570
 #define BCM963XX_NVRAM_OFFSET          0x580
 
-struct ath9k_caldata {
+struct bcm63xx_caldata {
+       unsigned int    vendor;
        unsigned int    slot;
        u32             caldata_offset;
+       /* Atheros */
        unsigned int    endian_check:1;
        int             led_pin;
        bool            led_active_high;
+       /* Ralink */
+       char*           eeprom;
 };
 
 /*
@@ -45,7 +50,7 @@ struct board_info {
        unsigned int    has_caldata:2;
 
        /* wifi calibration data config */
-       struct ath9k_caldata caldata[2];
+       struct bcm63xx_caldata caldata[2];
 
        /* ethernet config */
        struct bcm63xx_enet_platform_data enet0;
--- /dev/null
+++ b/arch/mips/include/asm/mach-bcm63xx/pci_rt2x00_fixup.h
@@ -0,0 +1,9 @@
+#ifndef _PCI_RT2X00_FIXUP
+#define _PCI_RT2X00_FIXUP
+
+#define PCI_VENDOR_ID_RALINK 0x1814
+
+void pci_enable_rt2x00_fixup(unsigned slot, char* eeprom) __init;
+
+#endif /* _PCI_RT2X00_FIXUP */
+

Generated by GNU Enscript 1.6.5.90.