X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/c1679af6b381809d1c133fbc609f0c5c465a512a..d8f4833329935373d318a6a04cd098a8f3f701d0:/target/linux/ar71xx/base-files/lib/upgrade/platform.sh?ds=sidebyside diff --git a/target/linux/ar71xx/base-files/lib/upgrade/platform.sh b/target/linux/ar71xx/base-files/lib/upgrade/platform.sh index 8b69bc59a..2800b05df 100755 --- a/target/linux/ar71xx/base-files/lib/upgrade/platform.sh +++ b/target/linux/ar71xx/base-files/lib/upgrade/platform.sh @@ -61,6 +61,10 @@ platform_do_upgrade_combined() { fi } +tplink_get_image_hwid() { + get_image "$@" | dd bs=4 count=1 skip=16 2>/dev/null | hexdump -v -n 4 -e '1/1 "%02x"' +} + platform_check_image() { local board=$(ar71xx_board_name) local magic="$(get_magic_word "$1")" @@ -77,6 +81,7 @@ platform_check_image() { ap121-mini | \ ap96 | \ db120 | \ + hornet-ub | \ zcn-1523h-2 | \ zcn-1523h-5) [ "$magic_long" != "68737173" -a "$magic_long" != "19852003" ] && { @@ -125,6 +130,18 @@ platform_check_image() { echo "Invalid image type." return 1 } + + local hwid + local imageid + + hwid=$(tplink_get_hwid) + imageid=$(tplink_get_image_hwid "$1") + + [ "$hwid" != "$imageid" ] && { + echo "Invalid image, hardware ID mismatch, hw:$hwid image:$imageid." + return 1 + } + return 0 ;; wndr3700)