mirror of
git://git.openwrt.org/openwrt/openwrt.git
synced 2025-01-10 00:29:26 +00:00
7d1cd9dfab
Fix "cfe-" string length copy. Check if there's an extra byte a.b.c-d.e / a.b.c-d.e-f. Add support for Huawei CFE versions ("cfe-vd"). Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com> Patchwork: http://patchwork.openwrt.org/patch/3766/ Signed-off-by: Jonas Gorski <jogo@openwrt.org> SVN-Revision: 37101
52 lines
1.7 KiB
Diff
52 lines
1.7 KiB
Diff
--- a/arch/mips/include/asm/mach-bcm63xx/pci_ath9k_fixup.h
|
|
+++ b/arch/mips/include/asm/mach-bcm63xx/pci_ath9k_fixup.h
|
|
@@ -2,6 +2,7 @@
|
|
#define _PCI_ATH9K_FIXUP
|
|
|
|
|
|
-void pci_enable_ath9k_fixup(unsigned slot, u32 offset) __init;
|
|
+void pci_enable_ath9k_fixup(unsigned slot, u32 offset,
|
|
+ unsigned endian_check) __init;
|
|
|
|
#endif /* _PCI_ATH9K_FIXUP */
|
|
--- a/arch/mips/include/asm/mach-bcm63xx/board_bcm963xx.h
|
|
+++ b/arch/mips/include/asm/mach-bcm63xx/board_bcm963xx.h
|
|
@@ -19,6 +19,7 @@
|
|
struct ath9k_caldata {
|
|
unsigned int slot;
|
|
u32 caldata_offset;
|
|
+ unsigned int endian_check:1;
|
|
};
|
|
|
|
/*
|
|
--- a/arch/mips/bcm63xx/pci-ath9k-fixup.c
|
|
+++ b/arch/mips/bcm63xx/pci-ath9k-fixup.c
|
|
@@ -172,12 +172,14 @@ static void ath9k_pci_fixup(struct pci_d
|
|
}
|
|
DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_ATHEROS, PCI_ANY_ID, ath9k_pci_fixup);
|
|
|
|
-void __init pci_enable_ath9k_fixup(unsigned slot, u32 offset)
|
|
+void __init pci_enable_ath9k_fixup(unsigned slot, u32 offset,
|
|
+ unsigned endian_check)
|
|
{
|
|
if (ath9k_num_fixups >= ARRAY_SIZE(ath9k_fixups))
|
|
return;
|
|
|
|
ath9k_fixups[ath9k_num_fixups].slot = slot;
|
|
+ ath9k_fixups[ath9k_num_fixups].pdata.endian_check = endian_check;
|
|
|
|
if (!bcm63xx_read_eeprom(ath9k_fixups[ath9k_num_fixups].pdata.eeprom_data, offset))
|
|
return;
|
|
--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
|
|
+++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
|
|
@@ -1047,7 +1047,8 @@ 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);
|
|
+ pci_enable_ath9k_fixup(board.caldata[i].slot, board.caldata[i].caldata_offset,
|
|
+ board.caldata[i].endian_check);
|
|
|
|
return 0;
|
|
}
|