aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/ath79/generic/base-files/etc/hotplug.d/firmware/10-ath9k-eeprom
diff options
context:
space:
mode:
Diffstat (limited to 'target/linux/ath79/generic/base-files/etc/hotplug.d/firmware/10-ath9k-eeprom')
-rw-r--r--target/linux/ath79/generic/base-files/etc/hotplug.d/firmware/10-ath9k-eeprom144
1 files changed, 144 insertions, 0 deletions
diff --git a/target/linux/ath79/generic/base-files/etc/hotplug.d/firmware/10-ath9k-eeprom b/target/linux/ath79/generic/base-files/etc/hotplug.d/firmware/10-ath9k-eeprom
new file mode 100644
index 0000000000..f1bc6c3c22
--- /dev/null
+++ b/target/linux/ath79/generic/base-files/etc/hotplug.d/firmware/10-ath9k-eeprom
@@ -0,0 +1,144 @@
+#!/bin/sh
+
+[ -e /lib/firmware/$FIRMWARE ] && exit 0
+
+. /lib/functions/caldata.sh
+
+board=$(board_name)
+
+case "$FIRMWARE" in
+"ath9k-eeprom-ahb-18100000.wmac.bin")
+ case $board in
+ avm,fritz4020)
+ caldata_extract_reverse "urlader" 0x1541 0x440
+ ;;
+ dlink,dir-825-c1|\
+ dlink,dir-835-a1)
+ caldata_extract "art" 0x1000 0x440
+ ath9k_patch_mac $(mtd_get_mac_text "mac" 0x4)
+ ;;
+ dlink,dir-842-c1|\
+ dlink,dir-842-c2|\
+ dlink,dir-842-c3|\
+ dlink,dir-859-a1|\
+ nec,wg1200cr|\
+ wd,mynet-n750)
+ caldata_extract "art" 0x1000 0x440
+ ath9k_patch_mac $(mtd_get_mac_ascii devdata "wlan24mac")
+ ;;
+ engenius,ecb1750)
+ caldata_extract "art" 0x1000 0x440
+ ath9k_patch_mac $(macaddr_add $(mtd_get_mac_ascii u-boot-env "athaddr") +1)
+ ;;
+ engenius,epg5000|\
+ iodata,wn-ac1167dgr|\
+ iodata,wn-ac1600dgr|\
+ iodata,wn-ac1600dgr2|\
+ iodata,wn-ag300dgr|\
+ sitecom,wlr-7100)
+ caldata_extract "art" 0x1000 0x440
+ ath9k_patch_mac $(mtd_get_mac_ascii u-boot-env ethaddr)
+ ;;
+ nec,wg800hp)
+ caldata_extract "art" 0x1000 0x440
+ ath9k_patch_mac $(mtd_get_mac_text board_data 0x680)
+ ;;
+ qihoo,c301)
+ caldata_extract "radiocfg" 0x1000 0x440
+ ath9k_patch_mac $(mtd_get_mac_ascii devdata "wlan24mac")
+ ;;
+ zyxel,nbg6716)
+ caldata_extract "art" 0x1000 0x440
+ ath9k_patch_mac $(mtd_get_mac_ascii u-boot-env ethaddr)
+ ;;
+ *)
+ caldata_die "board $board is not supported yet"
+ ;;
+ esac
+ ;;
+"ath9k-eeprom-pci-0000:00:00.0.bin")
+ case $board in
+ avm,fritz300e)
+ caldata_extract_reverse "urloader" 0x1541 0x440
+ ;;
+ buffalo,wzr-hp-g302h-a1a0)
+ caldata_extract "art" 0x1000 0xeb8
+ ;;
+ buffalo,wzr-hp-g450h)
+ caldata_extract "art" 0x1000 0x440
+ ;;
+ dlink,dir-825-c1|\
+ dlink,dir-835-a1)
+ caldata_extract "art" 0x5000 0x440
+ ath9k_patch_mac $(macaddr_add $(mtd_get_mac_text "mac" 0x18) 1)
+ ;;
+ ocedo,raccoon|\
+ tplink,tl-wdr3500-v1|\
+ tplink,tl-wdr3600-v1|\
+ tplink,tl-wdr4300-v1|\
+ tplink,tl-wdr4900-v2|\
+ winchannel,wb2000)
+ caldata_extract "art" 0x5000 0x440
+ ;;
+ pcs,cap324|\
+ tplink,tl-wr2543-v1|\
+ tplink,tl-wr842n-v1|\
+ ubnt,airrouter|\
+ ubnt,bullet-m|\
+ ubnt,nano-m|\
+ ubnt,rocket-m)
+ caldata_extract "art" 0x1000 0x1000
+ ;;
+ ubnt,unifi)
+ caldata_extract "art" 0x1000 0x800
+ ;;
+ wd,mynet-n750)
+ caldata_extract "art" 0x5000 0x440
+ ath9k_patch_mac $(mtd_get_mac_ascii devdata "wlan5mac")
+ ;;
+ wd,mynet-wifi-rangeextender)
+ caldata_extract "art" 0x1000 0x1000
+ ath9k_patch_mac $(nvram get wl0_hwaddr)
+ ;;
+ *)
+ caldata_die "board $board is not supported yet"
+ ;;
+ esac
+ ;;
+"ath9k-eeprom-pci-0000:00:11.0.bin")
+ case $board in
+ buffalo,wzr-hp-ag300h|\
+ netgear,wndr3700|\
+ netgear,wndr3700v2|\
+ netgear,wndr3800|\
+ netgear,wndr3800ch)
+ caldata_extract "art" 0x1000 0xeb8
+ ;;
+ dlink,dir-825-b1)
+ caldata_extract "caldata" 0x1000 0xeb8
+ ath9k_patch_mac_crc $(mtd_get_mac_text "caldata" 0xffa0) 0x20c
+ ;;
+ *)
+ caldata_die "board $board is not supported yet"
+ ;;
+ esac
+ ;;
+"ath9k-eeprom-pci-0000:00:12.0.bin")
+ case $board in
+ buffalo,wzr-hp-ag300h|\
+ netgear,wndr3700|\
+ netgear,wndr3700v2|\
+ netgear,wndr3800|\
+ netgear,wndr3800ch)
+ caldata_extract "art" 0x5000 0xeb8
+ ;;
+ dlink,dir-825-b1)
+ caldata_extract "caldata" 0x5000 0xeb8
+ ath9k_patch_mac_crc $(macaddr_add $(mtd_get_mac_text "caldata" 0xffb4) 1) 0x20c
+ ;;
+ *)
+ caldata_die "board $board is not supported yet"
+ ;;
+ esac
+ ;;
+esac