[OpenWrt-Devel] [PATCH v4 5/6] ipq40xx: Make use of common eeprom.sh library for caldata
Adrian Schmutzler
freifunk at adrianschmutzler.de
Fri Mar 1 09:40:21 EST 2019
This merges the ath10k-caldata extraction into the common
eeprom.sh.
Signed-off-by: Adrian Schmutzler <freifunk at adrianschmutzler.de>
---
New in v3:
Moved over from alternate patchset
Changed in v4:
- Rebased
---
package/base-files/files/lib/functions/eeprom.sh | 5 +-
.../etc/hotplug.d/firmware/11-ath10k-caldata | 82 ++++++----------------
2 files changed, 26 insertions(+), 61 deletions(-)
diff --git a/package/base-files/files/lib/functions/eeprom.sh b/package/base-files/files/lib/functions/eeprom.sh
index 80df3bb359..48c7fd362d 100644
--- a/package/base-files/files/lib/functions/eeprom.sh
+++ b/package/base-files/files/lib/functions/eeprom.sh
@@ -67,9 +67,12 @@ ubi_eeprom_extract() {
local part=$1
local offset=$2
local count=$3
- local ubidev=$(nand_find_ubi $CI_UBIPART)
+ local ubidev
local ubi
+ . /lib/upgrade/nand.sh
+
+ ubidev=$(nand_find_ubi $CI_UBIPART)
ubi=$(nand_find_volume $ubidev $part)
[ -n "$ubi" ] || \
eeprom_die "no UBI volume found for $part"
diff --git a/target/linux/ipq40xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata b/target/linux/ipq40xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata
index 1264d2ef36..75e8f1a237 100644
--- a/target/linux/ipq40xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata
+++ b/target/linux/ipq40xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata
@@ -1,5 +1,7 @@
#!/bin/sh
+. /lib/functions/eeprom.sh
+
# xor multiple hex values of the same length
xor() {
local val
@@ -16,43 +18,6 @@ xor() {
printf "%0${retlen}x" "$ret"
}
-ath10kcal_die() {
- echo "ath10cal: " "$*"
- exit 1
-}
-
-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 iflag=skip_bytes bs=$count skip=$offset count=1 2>/dev/null || \
- ath10kcal_die "failed to extract calibration data from $mtd"
-}
-
-ath10kcal_ubi_extract() {
- local part=$1
- local offset=$2
- local count=$3
- local ubidev
- local ubi
-
- . /lib/upgrade/nand.sh
-
- ubidev=$(nand_find_ubi $CI_UBIPART)
- ubi=$(nand_find_volume $ubidev $part)
- [ -n "$ubi" ] || \
- ath10kcal_die "no UBI volume found for $part"
-
- dd if=/dev/$ubi of=/lib/firmware/$FIRMWARE iflag=skip_bytes bs=$count skip=$offset count=1 2>/dev/null || \
- ath10kcal_die "failed to extract from $ubi"
-}
-
ath10kcal_patch_mac_crc() {
local mac=$1
local mac_offset=6
@@ -88,9 +53,6 @@ ath10kcal_is_caldata_valid() {
[ -e /lib/firmware/$FIRMWARE ] && exit 0
-. /lib/functions.sh
-. /lib/functions/system.sh
-
board=$(board_name)
@@ -98,8 +60,8 @@ case "$FIRMWARE" in
"ath10k/cal-pci-0000:01:00.0.bin")
case "$board" in
meraki,mr33)
- ath10kcal_ubi_extract "ART" 36864 2116
- ath10kcal_is_caldata_valid "4408" || ath10kcal_extract "ART" 36864 2116
+ ubi_eeprom_extract "ART" 36864 2116
+ ath10kcal_is_caldata_valid "4408" || mtd_eeprom_extract "ART" 36864 2116
ath10kcal_patch_mac_crc $(macaddr_add $(get_mac_binary "/sys/bus/i2c/devices/0-0050/eeprom" 102) +1)
;;
esac
@@ -107,12 +69,12 @@ case "$FIRMWARE" in
"ath10k/pre-cal-pci-0000:01:00.0.bin")
case "$board" in
asus,map-ac2200)
- ath10kcal_ubi_extract "Factory" 36864 12064
+ ubi_eeprom_extract "Factory" 36864 12064
ln -sf /lib/firmware/ath10k/pre-cal-pci-0000\:00\:00.0.bin \
/lib/firmware/ath10k/QCA9888/hw2.0/board.bin
;;
openmesh,a62)
- ath10kcal_extract "0:ART" 36864 12064
+ mtd_eeprom_extract "0:ART" 36864 12064
;;
esac
;;
@@ -123,14 +85,14 @@ case "$FIRMWARE" in
glinet,gl-b1300 |\
linksys,ea6350v3 |\
qcom,ap-dk01.1-c1)
- ath10kcal_extract "ART" 4096 12064
+ mtd_eeprom_extract "ART" 4096 12064
;;
asus,map-ac2200)
- ath10kcal_ubi_extract "Factory" 4096 12064
+ ubi_eeprom_extract "Factory" 4096 12064
;;
asus,rt-ac58u)
CI_UBIPART=UBI_DEV
- ath10kcal_ubi_extract "Factory" 4096 12064
+ ubi_eeprom_extract "Factory" 4096 12064
;;
avm,fritzbox-4040)
/usr/bin/fritz_cal_extract -i 1 -s 0x400 -e 0x207 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader_config")
@@ -145,21 +107,21 @@ case "$FIRMWARE" in
openmesh,a62 |\
qxwlan,e2600ac-c1 |\
qxwlan,e2600ac-c2)
- ath10kcal_extract "0:ART" 4096 12064
+ mtd_eeprom_extract "0:ART" 4096 12064
;;
meraki,mr33)
- ath10kcal_ubi_extract "ART" 4096 12064
- ath10kcal_is_caldata_valid "202f" || ath10kcal_extract "ART" 4096 12064
+ ubi_eeprom_extract "ART" 4096 12064
+ ath10kcal_is_caldata_valid "202f" || mtd_eeprom_extract "ART" 4096 12064
ath10kcal_patch_mac_crc $(macaddr_add $(get_mac_binary "/sys/bus/i2c/devices/0-0050/eeprom" 102) +2)
;;
netgear,ex6100v2 |\
netgear,ex6150v2)
- ath10kcal_extract "ART" 4096 12064
+ mtd_eeprom_extract "ART" 4096 12064
ath10kcal_patch_mac_crc $(mtd_get_mac_binary dnidata 0)
;;
zyxel,nbg6617 |\
zyxel,wre6606)
- ath10kcal_extract "ART" 4096 12064
+ mtd_eeprom_extract "ART" 4096 12064
ath10kcal_patch_mac_crc $(macaddr_add $(cat /sys/class/net/eth0/address) -2)
;;
esac
@@ -171,14 +133,14 @@ case "$FIRMWARE" in
glinet,gl-b1300 |\
linksys,ea6350v3 |\
qcom,ap-dk01.1-c1)
- ath10kcal_extract "ART" 20480 12064
+ mtd_eeprom_extract "ART" 20480 12064
;;
asus,map-ac2200)
- ath10kcal_ubi_extract "Factory" 20480 12064
+ ubi_eeprom_extract "Factory" 20480 12064
;;
asus,rt-ac58u)
CI_UBIPART=UBI_DEV
- ath10kcal_ubi_extract "Factory" 20480 12064
+ ubi_eeprom_extract "Factory" 20480 12064
;;
avm,fritzbox-4040)
/usr/bin/fritz_cal_extract -i 1 -s 0x400 -e 0x208 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader_config")
@@ -193,21 +155,21 @@ case "$FIRMWARE" in
openmesh,a62 |\
qxwlan,e2600ac-c1 |\
qxwlan,e2600ac-c2)
- ath10kcal_extract "0:ART" 20480 12064
+ mtd_eeprom_extract "0:ART" 20480 12064
;;
meraki,mr33)
- ath10kcal_ubi_extract "ART" 20480 12064
- ath10kcal_is_caldata_valid "202f" || ath10kcal_extract "ART" 20480 12064
+ ubi_eeprom_extract "ART" 20480 12064
+ ath10kcal_is_caldata_valid "202f" || mtd_eeprom_extract "ART" 20480 12064
ath10kcal_patch_mac_crc $(macaddr_add $(get_mac_binary "/sys/bus/i2c/devices/0-0050/eeprom" 102) +3)
;;
netgear,ex6100v2 |\
netgear,ex6150v2)
- ath10kcal_extract "ART" 20480 12064
+ mtd_eeprom_extract "ART" 20480 12064
ath10kcal_patch_mac_crc $(mtd_get_mac_binary dnidata 12)
;;
zyxel,nbg6617 |\
zyxel,wre6606)
- ath10kcal_extract "ART" 20480 12064
+ mtd_eeprom_extract "ART" 20480 12064
ath10kcal_patch_mac_crc $(macaddr_add $(cat /sys/class/net/eth0/address) -1)
;;
esac
--
2.11.0
_______________________________________________
openwrt-devel mailing list
openwrt-devel at lists.openwrt.org
https://lists.openwrt.org/mailman/listinfo/openwrt-devel
More information about the openwrt-devel
mailing list