2009-11-28 20:01:03 +02:00
|
|
|
--- a/include/linux/ath9k_platform.h
|
|
|
|
+++ b/include/linux/ath9k_platform.h
|
|
|
|
@@ -23,6 +23,7 @@
|
|
|
|
|
|
|
|
struct ath9k_platform_data {
|
|
|
|
u16 eeprom_data[ATH9K_PLAT_EEP_MAX_WORDS];
|
|
|
|
+ u8 *macaddr;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* _LINUX_ATH9K_PLATFORM_H */
|
2010-12-12 03:36:28 +02:00
|
|
|
--- a/drivers/net/wireless/ath/ath9k/init.c
|
|
|
|
+++ b/drivers/net/wireless/ath/ath9k/init.c
|
|
|
|
@@ -15,6 +15,7 @@
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/slab.h>
|
|
|
|
+#include <linux/ath9k_platform.h>
|
|
|
|
|
|
|
|
#include "ath9k.h"
|
|
|
|
|
2011-01-28 15:31:36 +02:00
|
|
|
@@ -526,6 +527,7 @@ static void ath9k_init_misc(struct ath_s
|
2010-12-12 03:36:28 +02:00
|
|
|
static int ath9k_init_softc(u16 devid, struct ath_softc *sc, u16 subsysid,
|
|
|
|
const struct ath_bus_ops *bus_ops)
|
|
|
|
{
|
|
|
|
+ struct ath9k_platform_data *pdata = sc->dev->platform_data;
|
|
|
|
struct ath_hw *ah = NULL;
|
|
|
|
struct ath_common *common;
|
|
|
|
int ret = 0, i;
|
2011-01-28 15:31:36 +02:00
|
|
|
@@ -540,7 +542,7 @@ static int ath9k_init_softc(u16 devid, s
|
2010-12-12 03:36:28 +02:00
|
|
|
ah->hw_version.subsysid = subsysid;
|
|
|
|
sc->sc_ah = ah;
|
|
|
|
|
|
|
|
- if (!sc->dev->platform_data)
|
|
|
|
+ if (!pdata)
|
|
|
|
ah->ah_flags |= AH_USE_EEPROM;
|
|
|
|
|
|
|
|
common = ath9k_hw_common(ah);
|
2011-01-28 15:31:36 +02:00
|
|
|
@@ -576,6 +578,9 @@ static int ath9k_init_softc(u16 devid, s
|
2010-12-12 03:36:28 +02:00
|
|
|
if (ret)
|
|
|
|
goto err_hw;
|
|
|
|
|
|
|
|
+ if (pdata && pdata->macaddr)
|
|
|
|
+ memcpy(common->macaddr, pdata->macaddr, ETH_ALEN);
|
|
|
|
+
|
|
|
|
ret = ath9k_init_queues(sc);
|
|
|
|
if (ret)
|
|
|
|
goto err_queues;
|