ar71xx: add user-space support for RB911G-5HPacD
authorGabor Juhos <juhosg@openwrt.org>
Tue, 7 Apr 2015 20:04:14 +0000 (20:04 +0000)
committerGabor Juhos <juhosg@openwrt.org>
Tue, 7 Apr 2015 20:04:14 +0000 (20:04 +0000)
Signed-off-by: Gabor Juhos <juhosg@openwrt.org>
SVN-Revision: 45300

target/linux/ar71xx/base-files/etc/diag.sh
target/linux/ar71xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata [new file with mode: 0644]
target/linux/ar71xx/base-files/etc/uci-defaults/02_network
target/linux/ar71xx/base-files/lib/ar71xx.sh

index 59acc714a1b561fc1506db6f0a1d6f8dfadaa94d..14ff625d614dbbf4ba28d1ec650ee4a1941885eb 100644 (file)
@@ -161,6 +161,7 @@ get_status_led() {
                status_led="rb750:green:act"
                ;;
        rb-911g-2hpnd|\
+       rb-911g-5hpacd|\
        rb-911g-5hpnd|\
        rb-912uag-2hpnd|\
        rb-912uag-5hpnd)
diff --git a/target/linux/ar71xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata b/target/linux/ar71xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata
new file mode 100644 (file)
index 0000000..164d3ab
--- /dev/null
@@ -0,0 +1,45 @@
+#!/bin/sh
+
+ath10kcal_die() {
+       echo "ath10cal: " "$*"
+       exit 1
+}
+
+ath10kcal_from_file() {
+       local source=$1
+       local offset=$2
+       local target=$3
+
+       dd if=$source of=$target bs=1 skip=$offset count=2116 2>/dev/null || \
+               ath10kcal_die "failed to extract calibration data from $source"
+}
+
+[ -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)
+
+case "$FIRMWARE" in
+"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
+               ;;
+       esac
+       ;;
+
+*)
+       exit 1
+       ;;
+esac
+
+[ -f $ath10kcal_tmp ] && {
+       cp $ath10kcal_tmp /lib/firmware/$FIRMWARE
+       rm -f $ath10kcal_tmp
+}
index 20f34d50da297a33b50e07cbf4b79a7f399f7d15..9789834dcf3311f514f629f4b180984e8101e099 100644 (file)
@@ -312,6 +312,7 @@ mr900 |\
 mr900v2 |\
 rb-411 |\
 rb-911g-2hpnd |\
+rb-911g-5hpacd |\
 rb-911g-5hpnd |\
 rb-912uag-2hpnd |\
 rb-912uag-5hpnd |\
index 802524c545865867c2102937a5ae28e6e96fdb1b..b3dbcf5891eb18abe2cc6c8ecb18b7253691e56c 100755 (executable)
@@ -582,6 +582,9 @@ ar71xx_board_detect() {
        *"RouterBOARD 911G-5HPnD")
                name="rb-911g-5hpnd"
                ;;
+       *"RouterBOARD 911G-5HPacD")
+               name="rb-911g-5hpacd"
+               ;;
        *"RouterBOARD 912UAG-2HPnD")
                name="rb-912uag-2hpnd"
                ;;