|  | @@ -0,0 +1,58 @@
 | 
	
		
			
				|  |  | +--- a/drivers/net/wireless/ath/ath9k/pci.c
 | 
	
		
			
				|  |  | ++++ b/drivers/net/wireless/ath/ath9k/pci.c
 | 
	
		
			
				|  |  | +@@ -16,6 +16,7 @@
 | 
	
		
			
				|  |  | + 
 | 
	
		
			
				|  |  | + #include <linux/nl80211.h>
 | 
	
		
			
				|  |  | + #include <linux/pci.h>
 | 
	
		
			
				|  |  | ++#include <linux/ath9k_platform.h>
 | 
	
		
			
				|  |  | + #include "ath9k.h"
 | 
	
		
			
				|  |  | + 
 | 
	
		
			
				|  |  | + static struct pci_device_id ath_pci_id_table[] __devinitdata = {
 | 
	
		
			
				|  |  | +@@ -61,21 +62,36 @@ static void ath_pci_cleanup(struct ath_c
 | 
	
		
			
				|  |  | + 
 | 
	
		
			
				|  |  | + static bool ath_pci_eeprom_read(struct ath_common *common, u32 off, u16 *data)
 | 
	
		
			
				|  |  | + {
 | 
	
		
			
				|  |  | +-	struct ath_hw *ah = (struct ath_hw *) common->ah;
 | 
	
		
			
				|  |  | ++	struct ath_softc *sc = (struct ath_softc *) common->priv;
 | 
	
		
			
				|  |  | ++	struct ath9k_platform_data *pdata = sc->dev->platform_data;
 | 
	
		
			
				|  |  | + 
 | 
	
		
			
				|  |  | +-	common->ops->read(ah, AR5416_EEPROM_OFFSET + (off << AR5416_EEPROM_S));
 | 
	
		
			
				|  |  | ++	if (pdata) {
 | 
	
		
			
				|  |  | ++		if (off >= (ARRAY_SIZE(pdata->eeprom_data))) {
 | 
	
		
			
				|  |  | ++			ath_print(common, ATH_DBG_FATAL,
 | 
	
		
			
				|  |  | ++				  "%s: eeprom read failed, offset %08x "
 | 
	
		
			
				|  |  | ++				  "is out of range\n",
 | 
	
		
			
				|  |  | ++				  __func__, off);
 | 
	
		
			
				|  |  | ++		}
 | 
	
		
			
				|  |  | ++
 | 
	
		
			
				|  |  | ++		*data = pdata->eeprom_data[off];
 | 
	
		
			
				|  |  | ++	} else {
 | 
	
		
			
				|  |  | ++		struct ath_hw *ah = (struct ath_hw *) common->ah;
 | 
	
		
			
				|  |  | ++
 | 
	
		
			
				|  |  | ++		common->ops->read(ah, AR5416_EEPROM_OFFSET +
 | 
	
		
			
				|  |  | ++				      (off << AR5416_EEPROM_S));
 | 
	
		
			
				|  |  | ++
 | 
	
		
			
				|  |  | ++		if (!ath9k_hw_wait(ah,
 | 
	
		
			
				|  |  | ++				   AR_EEPROM_STATUS_DATA,
 | 
	
		
			
				|  |  | ++				   AR_EEPROM_STATUS_DATA_BUSY |
 | 
	
		
			
				|  |  | ++				   AR_EEPROM_STATUS_DATA_PROT_ACCESS, 0,
 | 
	
		
			
				|  |  | ++				   AH_WAIT_TIMEOUT)) {
 | 
	
		
			
				|  |  | ++			return false;
 | 
	
		
			
				|  |  | ++		}
 | 
	
		
			
				|  |  | + 
 | 
	
		
			
				|  |  | +-	if (!ath9k_hw_wait(ah,
 | 
	
		
			
				|  |  | +-			   AR_EEPROM_STATUS_DATA,
 | 
	
		
			
				|  |  | +-			   AR_EEPROM_STATUS_DATA_BUSY |
 | 
	
		
			
				|  |  | +-			   AR_EEPROM_STATUS_DATA_PROT_ACCESS, 0,
 | 
	
		
			
				|  |  | +-			   AH_WAIT_TIMEOUT)) {
 | 
	
		
			
				|  |  | +-		return false;
 | 
	
		
			
				|  |  | ++		*data = MS(common->ops->read(ah, AR_EEPROM_STATUS_DATA),
 | 
	
		
			
				|  |  | ++			   AR_EEPROM_STATUS_DATA_VAL);
 | 
	
		
			
				|  |  | + 	}
 | 
	
		
			
				|  |  | + 
 | 
	
		
			
				|  |  | +-	*data = MS(common->ops->read(ah, AR_EEPROM_STATUS_DATA),
 | 
	
		
			
				|  |  | +-		   AR_EEPROM_STATUS_DATA_VAL);
 | 
	
		
			
				|  |  | +-
 | 
	
		
			
				|  |  | + 	return true;
 | 
	
		
			
				|  |  | + }
 | 
	
		
			
				|  |  | + 
 |