ipq806x: add support for TP-Link Talon AD7200
[openwrt/openwrt.git] / target / linux / ipq806x / base-files / etc / hotplug.d / firmware / 11-ath10k-caldata
index bdc36070f2240a9cba76830657cf495c52f04d62..3befc40630c988d7f84c940bf4cff4d0b2c4cfc4 100644 (file)
 #!/bin/sh
 
-# xor multiple hex values of the same length
-xor() {
-       local val
-       local ret="0x$1"
-       local retlen=${#1}
-
-       shift
-       while [ -n "$1" ]; do
-               val="0x$1"
-               ret=$((ret ^ val))
-               shift
-       done
-
-       printf "%0${retlen}x" "$ret"
-}
-
-ath10kcal_die() {
-       echo "ath10cal: " "$*"
-       exit 1
-}
-
-ath10kcal_from_file() {
-       local source=$1
-       local offset=$(($2))
-       local count=$(($3))
-
-       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_crc() {
-       local mac=$1
-       local mac_offset=6
-       local chksum_offset=2
-       local xor_mac
-       local xor_fw_mac
-       local xor_fw_chksum
-
-       [ -z "$mac" ] && return
-
-       xor_fw_mac=$(hexdump -v -n 6 -s $mac_offset -e '/1 "%02x"' /lib/firmware/$FIRMWARE)
-       xor_fw_mac="${xor_fw_mac:0:4} ${xor_fw_mac:4:4} ${xor_fw_mac:8:4}"
-
-       macaddr_2bin $mac | dd of=/lib/firmware/$FIRMWARE conv=notrunc bs=1 seek=6 count=6
-
-       xor_mac=${mac//:/}
-       xor_mac="${xor_mac:0:4} ${xor_mac:4:4} ${xor_mac:8:4}"
-
-       xor_fw_chksum=$(hexdump -v -n 2 -s $chksum_offset -e '/1 "%02x"' /lib/firmware/$FIRMWARE)
-       xor_fw_chksum=$(xor $xor_fw_chksum $xor_fw_mac $xor_mac)
-
-       printf "%b" "\x${xor_fw_chksum:0:2}\x${xor_fw_chksum:2:2}" | \
-               dd of=/lib/firmware/$FIRMWARE conv=notrunc bs=1 seek=$chksum_offset count=2
-}
-
 [ -e /lib/firmware/$FIRMWARE ] && exit 0
 
-. /lib/functions.sh
-. /lib/functions/system.sh
+. /lib/functions/caldata.sh
 
 board=$(board_name)
 
 case "$FIRMWARE" in
 "ath10k/pre-cal-pci-0000:01:00.0.bin")
        case $board in
+       asrock,g10)
+               caldata_extract "0:ART" 0x1000 0x2f20
+               ;;
        buffalo,wxr-2533dhp)
-               ath10kcal_extract "ART" 0x1000 0x2f20
-               ath10kcal_patch_mac_crc $(mtd_get_mac_binary ART 0x1e)
+               caldata_extract "ART" 0x1000 0x2f20
+               ath10k_patch_mac $(mtd_get_mac_binary ART 0x1e)
                ;;
+       edgecore,ecw5410)
+               caldata_extract "0:ART" 0x1000 0x2f20
+               ;;
+       linksys,ea7500-v1 |\
        linksys,ea8500)
-               ath10kcal_extract "art" 0x1000 0x2f20
-               ath10kcal_patch_mac_crc $(macaddr_add $(mtd_get_mac_ascii devinfo hw_mac_addr) +1)
+               caldata_extract "art" 0x1000 0x2f20
+               ath10k_patch_mac $(macaddr_add $(mtd_get_mac_ascii devinfo hw_mac_addr) +1)
                ;;
-       nec,wg2600hp)
-               ath10kcal_extract "ART" 0x1000 0x2f20
-               ath10kcal_patch_mac_crc $(macaddr_add $(mtd_get_mac_binary PRODUCTDATA 0xc) +1)
+       nec,wg2600hp |\
+       nec,wg2600hp3)
+               caldata_extract "ART" 0x1000 0x2f20
+               ath10k_patch_mac $(mtd_get_mac_binary PRODUCTDATA 0x12)
                ;;
        netgear,d7800 |\
        netgear,r7500v2 |\
        netgear,r7800)
-               ath10kcal_extract "art" 0x1000 0x2f20
-               ath10kcal_patch_mac_crc $(macaddr_add $(mtd_get_mac_binary art 0x6) +1)
+               caldata_extract "art" 0x1000 0x2f20
+               ath10k_patch_mac $(macaddr_add $(mtd_get_mac_binary art 0x6) +1)
                ;;
+       tplink,ad7200 |\
        tplink,c2600)
-               ath10kcal_extract "radio" 0x1000 0x2f20
-               ath10kcal_patch_mac_crc $(macaddr_add $(mtd_get_mac_binary default-mac 0x8) -1)
+               caldata_extract "radio" 0x1000 0x2f20
+               ath10k_patch_mac $(macaddr_add $(mtd_get_mac_binary default-mac 0x8) -1)
                ;;
        tplink,vr2600v)
-               ath10kcal_extract "ART" 0x1000 0x2f20
-               ath10kcal_patch_mac_crc $(macaddr_add $(mtd_get_mac_binary default-mac 0x0) -1)
+               caldata_extract "ART" 0x1000 0x2f20
+               ath10k_patch_mac $(macaddr_add $(mtd_get_mac_binary default-mac 0x0) -1)
                ;;
        zyxel,nbg6817)
-               ath10kcal_extract "0:ART" 0x1000 0x2f20
-               ath10kcal_patch_mac_crc $(macaddr_add $(mtd_get_mac_ascii 0:APPSBLENV ethaddr) +1)
+               caldata_extract "0:ART" 0x1000 0x2f20
+               ath10k_patch_mac $(macaddr_add $(mtd_get_mac_ascii 0:APPSBLENV ethaddr) +1)
                ;;
        esac
        ;;
 "ath10k/pre-cal-pci-0001:01:00.0.bin")
        case $board in
+       asrock,g10)
+               caldata_extract "0:ART" 0x5000 0x2f20
+               ;;
        buffalo,wxr-2533dhp)
-               ath10kcal_extract "ART" 0x5000 0x2f20
-               ath10kcal_patch_mac_crc $(mtd_get_mac_binary ART 0x18)
+               caldata_extract "ART" 0x5000 0x2f20
+               ath10k_patch_mac $(mtd_get_mac_binary ART 0x18)
                ;;
+       linksys,ea7500-v1 |\
        linksys,ea8500)
-               ath10kcal_extract "art" 0x5000 0x2f20
-               ath10kcal_patch_mac_crc $(macaddr_add $(mtd_get_mac_ascii devinfo hw_mac_addr) +2)
+               caldata_extract "art" 0x5000 0x2f20
+               ath10k_patch_mac $(macaddr_add $(mtd_get_mac_ascii devinfo hw_mac_addr) +2)
                ;;
-       nec,wg2600hp)
-               ath10kcal_extract "ART" 0x5000 0x2f20
-               ath10kcal_patch_mac_crc $(mtd_get_mac_binary PRODUCTDATA 0xc)
+       nec,wg2600hp |\
+       nec,wg2600hp3)
+               caldata_extract "ART" 0x5000 0x2f20
+               ath10k_patch_mac $(mtd_get_mac_binary PRODUCTDATA 0xc)
                ;;
        netgear,d7800 |\
        netgear,r7500v2 |\
        netgear,r7800)
-               ath10kcal_extract "art" 0x5000 0x2f20
-               ath10kcal_patch_mac_crc $(macaddr_add $(mtd_get_mac_binary art 0x6) +2)
+               caldata_extract "art" 0x5000 0x2f20
+               ath10k_patch_mac $(macaddr_add $(mtd_get_mac_binary art 0x6) +2)
                ;;
+       tplink,ad7200 |\
        tplink,c2600)
-               ath10kcal_extract "radio" 0x5000 0x2f20
-               ath10kcal_patch_mac_crc $(mtd_get_mac_binary default-mac 0x8)
+               caldata_extract "radio" 0x5000 0x2f20
+               ath10k_patch_mac $(mtd_get_mac_binary default-mac 0x8)
                ;;
        tplink,vr2600v)
-               ath10kcal_extract "ART" 0x5000 0x2f20
-               ath10kcal_patch_mac_crc $(mtd_get_mac_binary default-mac 0x0)
+               caldata_extract "ART" 0x5000 0x2f20
+               ath10k_patch_mac $(mtd_get_mac_binary default-mac 0x0)
                ;;
        zyxel,nbg6817)
-               ath10kcal_extract "0:ART" 0x5000 0x2f20
-               ath10kcal_patch_mac_crc $(mtd_get_mac_ascii 0:APPSBLENV ethaddr)
+               caldata_extract "0:ART" 0x5000 0x2f20
+               ath10k_patch_mac $(mtd_get_mac_ascii 0:APPSBLENV ethaddr)
+               ;;
+       esac
+       ;;
+"ath10k/pre-cal-pci-0002:01:00.0.bin")
+       case $board in
+       edgecore,ecw5410)
+               caldata_extract "0:ART" 0x5000 0x2f20
                ;;
        esac
        ;;