ar71xx: add support for Nokia WI2A-AC200i
[openwrt/staging/dedeckeh.git] / target / linux / ar71xx / base-files / etc / hotplug.d / firmware / 11-ath10k-caldata
index 164d3abd39436a2c80e51226effee17aa17ec34f..9a5f82b7cd6dfe3b3efc0f0860ae39926b9156e1 100644 (file)
@@ -8,38 +8,144 @@ ath10kcal_die() {
 ath10kcal_from_file() {
        local source=$1
        local offset=$2
-       local target=$3
+       local count=$3
 
-       dd if=$source of=$target bs=1 skip=$offset count=2116 2>/dev/null || \
+       dd if=$source of=/lib/firmware/$FIRMWARE bs=1 skip=$offset count=$count 2>/dev/null || \
                ath10kcal_die "failed to extract calibration data from $source"
 }
 
+ath10kcal_extract() {
+       local part=$1
+       local offset=$2
+       local count=$3
+       local mtd
+
+       mtd=$(find_mtd_chardev $part)
+       [ -n "$mtd" ] || \
+               ath10kcal_die "no mtd device found for partition $part"
+
+       dd if=$mtd of=/lib/firmware/$FIRMWARE bs=1 skip=$offset count=$count 2>/dev/null || \
+               ath10kcal_die "failed to extract calibration data from $mtd"
+}
+
+ath10kcal_patch_mac() {
+       local mac=$1
+
+       [ -z "$mac" ] && return
+
+       macaddr_2bin $mac | dd of=/lib/firmware/$FIRMWARE conv=notrunc bs=1 seek=6 count=6
+}
+
 [ -e /lib/firmware/$FIRMWARE ] && exit 0
 
-. /lib/ar71xx.sh
 . /lib/functions.sh
 . /lib/functions/system.sh
 
-ath10kcal_mac=""
-ath10kcal_tmp="/tmp/ath10k-caldata.bin"
-
-board=$(ar71xx_board_name)
+board=$(board_name)
 
 case "$FIRMWARE" in
+"ath10k/cal-pci-0000:00:00.0.bin")
+       case $board in
+       a40|\
+       a60|\
+       mr1750|\
+       mr1750v2|\
+       om5p-acv2)
+               ath10kcal_extract "ART" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth0/address) +16)
+               ;;
+       archer-c25-v1|\
+       archer-c59-v1|\
+       archer-c60-v1|\
+       tl-wdr6500-v2)
+               ath10kcal_extract "art" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth1/address) -2)
+               ;;
+       cf-e355ac|\
+       cf-e380ac-v1|\
+       cf-e380ac-v2|\
+       dlan-pro-1200-ac|\
+       sr3200|\
+       xd3200)
+               ath10kcal_extract "art" 20480 2116
+               ;;
+       dap-2695-a1)
+               ath10kcal_extract "radiocfg" 20480 2116
+               ath10kcal_patch_mac $(mtd_get_mac_ascii bdcfg wlanmac_a)
+               ;;
+       dir-869-a1|\
+       qihoo-c301)
+               ath10kcal_extract "radiocfg" 20480 2116
+               ath10kcal_patch_mac $(mtd_get_mac_ascii devdata wlan5mac)
+               ;;
+       dw33d)
+               ath10kcal_extract "art" 20480 2116
+               ath10kcal_patch_mac $(mtd_get_mac_binary art 18)
+               ;;
+       epg5000|\
+       esr1750)
+               ath10kcal_extract "caldata" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth0/address) +1)
+               ;;
+       mc-mac1200r)
+               ath10kcal_extract "art" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth1/address) -1)
+               ;;
+       r6100)
+               ath10kcal_extract "caldata" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth1/address) +2)
+               ;;
+       rb-952ui-5ac2nd)
+               ath10kcal_from_file "/sys/firmware/routerboot/ext_wlan_data" 20480 2116
+               ;;
+       re450|\
+       tl-wr902ac-v1)
+               ath10kcal_extract "art" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth0/address) -2)
+               ;;
+       tl-wpa8630)
+               ath10kcal_extract "art" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth0/address) +1)
+               ;;
+       unifiac-lite|\
+       unifiac-pro)
+               ath10kcal_extract "EEPROM" 20480 2116
+               ;;
+       wi2a-ac200i)
+               ath10kcal_extract "ART" 20480 2116
+               ;;
+       esac
+       ;;
 "ath10k/cal-pci-0000:01:00.0.bin")
        case $board in
-       rb-911g-5hpacd)
-               ath10kcal_from_file "/sys/firmware/routerboot/ext_wlan_data" 20480 $ath10kcal_tmp
+       archer-c5|\
+       archer-c7)
+               ath10kcal_extract "art" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth1/address) -2)
+               ;;
+       nbg6616|\
+       nbg6716)
+               ath10kcal_extract "RFdata" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth1/address) -2)
+               ;;
+       om5p-ac)
+               ath10kcal_extract "ART" 20480 2116
+               ath10kcal_patch_mac $(macaddr_add $(cat /sys/class/net/eth0/address) +16)
+               ;;
+       rb-911g-5hpacd|\
+       rb-962uigs-5hact2hnt)
+               ath10kcal_from_file "/sys/firmware/routerboot/ext_wlan_data" 20480 2116
+               ;;
+       esac
+       ;;
+"ath10k/pre-cal-pci-0000:00:00.0.bin")
+       case $board in
+       archer-c58-v1)
+               ath10kcal_extract "art" 20480 12064
                ;;
        esac
        ;;
-
 *)
        exit 1
        ;;
 esac
-
-[ -f $ath10kcal_tmp ] && {
-       cp $ath10kcal_tmp /lib/firmware/$FIRMWARE
-       rm -f $ath10kcal_tmp
-}