diff options
Diffstat (limited to 'target/linux/ar71xx/files/arch')
| -rw-r--r-- | target/linux/ar71xx/files/arch/mips/ar71xx/mach-wndr3700.c | 14 | 
1 files changed, 9 insertions, 5 deletions
| diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/mach-wndr3700.c b/target/linux/ar71xx/files/arch/mips/ar71xx/mach-wndr3700.c index 472d603ba..5f95270ad 100644 --- a/target/linux/ar71xx/files/arch/mips/ar71xx/mach-wndr3700.c +++ b/target/linux/ar71xx/files/arch/mips/ar71xx/mach-wndr3700.c @@ -107,7 +107,9 @@ static struct ar71xx_pci_irq wndr3700_pci_irqs[] __initdata = {  };  static struct ath9k_platform_data wndr3700_wmac0_data; +static u8 wndr3700_wmac0_macaddr[6];  static struct ath9k_platform_data wndr3700_wmac1_data; +static u8 wndr3700_wmac1_macaddr[6];  static void wndr3700_pci_fixup(struct pci_dev *dev)  { @@ -201,15 +203,17 @@ static int wndr3700_pci_plat_dev_init(struct pci_dev *dev)  static void __init wndr3700_pci_init(void)  { -	u8 *ee; +	u8 *ee = (u8 *) KSEG1ADDR(0x1fff0000); -	ee = (u8 *) KSEG1ADDR(0x1fff1000); -	memcpy(wndr3700_wmac0_data.eeprom_data, ee, +	memcpy(wndr3700_wmac0_data.eeprom_data, ee + 0x1000,  	       sizeof(wndr3700_wmac0_data.eeprom_data)); +	memcpy(wndr3700_wmac0_macaddr, ee, sizeof(wndr3700_wmac0_macaddr)); +	wndr3700_wmac0_data.macaddr = wndr3700_wmac0_macaddr; -	ee = (u8 *) KSEG1ADDR(0x1fff5000); -	memcpy(wndr3700_wmac1_data.eeprom_data, ee, +	memcpy(wndr3700_wmac1_data.eeprom_data, ee + 0x5000,  	       sizeof(wndr3700_wmac1_data.eeprom_data)); +	memcpy(wndr3700_wmac1_macaddr, ee + 12, sizeof(wndr3700_wmac1_macaddr)); +	wndr3700_wmac1_data.macaddr = wndr3700_wmac1_macaddr;  	ar71xx_pci_plat_dev_init = wndr3700_pci_plat_dev_init;  	ar71xx_pci_init(ARRAY_SIZE(wndr3700_pci_irqs), wndr3700_pci_irqs); | 
