aboutsummaryrefslogtreecommitdiffstats
path: root/target
diff options
context:
space:
mode:
authorRafał Miłecki <zajec5@gmail.com>2014-12-30 17:45:53 +0000
committerRafał Miłecki <zajec5@gmail.com>2014-12-30 17:45:53 +0000
commit60baecf9876b7b4d88e93be745cd5a408fdd250c (patch)
tree2f7712569fe802d8df7b8f9bdbea60ab38dc5675 /target
parentee585e5b9e0f8f14a1d1cf7ca93c029492c85daf (diff)
downloadupstream-60baecf9876b7b4d88e93be745cd5a408fdd250c.tar.gz
upstream-60baecf9876b7b4d88e93be745cd5a408fdd250c.tar.bz2
upstream-60baecf9876b7b4d88e93be745cd5a408fdd250c.zip
bcm53xx: support flashing CHK and CyberTAN images
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@43800 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target')
-rw-r--r--target/linux/bcm53xx/base-files/lib/upgrade/platform.sh20
1 files changed, 16 insertions, 4 deletions
diff --git a/target/linux/bcm53xx/base-files/lib/upgrade/platform.sh b/target/linux/bcm53xx/base-files/lib/upgrade/platform.sh
index de8d8835c3..3d911d1246 100644
--- a/target/linux/bcm53xx/base-files/lib/upgrade/platform.sh
+++ b/target/linux/bcm53xx/base-files/lib/upgrade/platform.sh
@@ -56,14 +56,26 @@ platform_check_image() {
local board_id_len=$(($header_len - 40))
local board_id=$(dd if="$1" skip=40 bs=1 count=$board_id_len 2>/dev/null | hexdump -v -e '1/1 "%c"')
echo "Found CHK image with device board_id $board_id"
- echo "Flashing CHK images in unsupported. Please use only .trx files."
- return 1
+
+ magic=$(get_magic_long_at "$1" "$header_len")
+ [ "$magic" != "48445230" ] && {
+ echo "No valid TRX firmware in the CHK image"
+ return 1
+ }
+
+ return 0
;;
"cybertan")
local magic=$(dd if="$1" bs=1 count=4 2>/dev/null | hexdump -v -e '1/1 "%c"')
echo "Found CyberTAN image with device magic: $magic"
- echo "Flashing CyberTAN images in unsupported. Please use only .trx files."
- return 1
+
+ magic=$(get_magic_long_at "$1" 32)
+ [ "$magic" != "48445230" ] && {
+ echo "No valid TRX firmware in the CyberTAN image"
+ return 1
+ }
+
+ return 0
;;
"trx")
return 0