mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2025-04-21 12:27:27 +03:00
backport mac80211 and iw from trunk
git-svn-id: svn://svn.openwrt.org/openwrt/branches/backfire@24505 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
@@ -9,26 +9,7 @@
|
||||
|
||||
#include "ath5k.h"
|
||||
#include "reg.h"
|
||||
@@ -34,6 +36,18 @@
|
||||
static int ath5k_hw_eeprom_read(struct ath5k_hw *ah, u32 offset, u16 *data)
|
||||
{
|
||||
u32 status, timeout;
|
||||
+ struct ath5k_platform_data *pdata = NULL;
|
||||
+
|
||||
+ if (ah->ah_sc->pdev)
|
||||
+ pdata = ah->ah_sc->pdev->dev.platform_data;
|
||||
+
|
||||
+ if (pdata && pdata->eeprom_data && pdata->eeprom_data[0] == AR5K_EEPROM_MAGIC_VALUE)
|
||||
+ {
|
||||
+ ATH5K_INFO(ah->ah_sc, "using eeprom-content from platform_data\n");
|
||||
+ if (offset >= ATH5K_PLAT_EEP_MAX_WORDS) return -EIO;
|
||||
+ *data = pdata->eeprom_data[offset];
|
||||
+ return 0;
|
||||
+ }
|
||||
|
||||
/*
|
||||
* Initialize EEPROM access
|
||||
@@ -1788,7 +1802,7 @@ ath5k_eeprom_init(struct ath5k_hw *ah)
|
||||
@@ -1726,7 +1728,7 @@ ath5k_eeprom_read_spur_chans(struct ath5
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -37,7 +18,7 @@
|
||||
*/
|
||||
int ath5k_eeprom_read_mac(struct ath5k_hw *ah, u8 *mac)
|
||||
{
|
||||
@@ -1796,6 +1810,16 @@ int ath5k_eeprom_read_mac(struct ath5k_h
|
||||
@@ -1734,6 +1736,16 @@ int ath5k_eeprom_read_mac(struct ath5k_h
|
||||
u32 total, offset;
|
||||
u16 data;
|
||||
int octet, ret;
|
||||
@@ -52,5 +33,35 @@
|
||||
+ return 0;
|
||||
+ }
|
||||
|
||||
ret = ath5k_hw_eeprom_read(ah, 0x20, &data);
|
||||
ret = ath5k_hw_nvram_read(ah, 0x20, &data);
|
||||
if (ret)
|
||||
--- a/drivers/net/wireless/ath/ath5k/pci.c
|
||||
+++ b/drivers/net/wireless/ath/ath5k/pci.c
|
||||
@@ -17,6 +17,7 @@
|
||||
#include <linux/nl80211.h>
|
||||
#include <linux/pci.h>
|
||||
#include <linux/pci-aspm.h>
|
||||
+#include <linux/ath5k_platform.h>
|
||||
#include "../ath.h"
|
||||
#include "ath5k.h"
|
||||
#include "debug.h"
|
||||
@@ -73,6 +74,19 @@ bool ath5k_pci_eeprom_read(struct ath_co
|
||||
{
|
||||
struct ath5k_hw *ah = (struct ath5k_hw *) common->ah;
|
||||
u32 status, timeout;
|
||||
+ struct ath5k_platform_data *pdata = NULL;
|
||||
+
|
||||
+ if (ah->ah_sc->pdev)
|
||||
+ pdata = ah->ah_sc->pdev->dev.platform_data;
|
||||
+
|
||||
+ if (pdata && pdata->eeprom_data && pdata->eeprom_data[0] == AR5K_EEPROM_MAGIC_VALUE)
|
||||
+ {
|
||||
+ if (offset >= ATH5K_PLAT_EEP_MAX_WORDS)
|
||||
+ return -EIO;
|
||||
+
|
||||
+ *data = pdata->eeprom_data[offset];
|
||||
+ return 0;
|
||||
+ }
|
||||
|
||||
/*
|
||||
* Initialize EEPROM access
|
||||
|
||||
Reference in New Issue
Block a user