ar71xx: add support for Compex WPJ342
[openwrt/openwrt.git] / target / linux / ar71xx / base-files / lib / upgrade / platform.sh
index dfec1336fcdb28aaed4dee5d4a26b767333fecc7..86375a9acce557f132398dbfa322dbedba0a30f7 100755 (executable)
@@ -2,6 +2,7 @@
 # Copyright (C) 2011 OpenWrt.org
 #
 
+. /lib/functions/system.sh
 . /lib/ar71xx.sh
 
 PART_NAME=firmware
@@ -65,10 +66,41 @@ tplink_get_image_hwid() {
        get_image "$@" | dd bs=4 count=1 skip=16 2>/dev/null | hexdump -v -n 4 -e '1/1 "%02x"'
 }
 
+tplink_get_image_mid() {
+       get_image "$@" | dd bs=4 count=1 skip=17 2>/dev/null | hexdump -v -n 4 -e '1/1 "%02x"'
+}
+
 tplink_get_image_boot_size() {
        get_image "$@" | dd bs=4 count=1 skip=37 2>/dev/null | hexdump -v -n 4 -e '1/1 "%02x"'
 }
 
+tplink_pharos_check_image() {
+       local magic_long="$(get_magic_long "$1")"
+       [ "$magic_long" != "7f454c46" ] && {
+               echo "Invalid image magic '$magic_long'"
+               return 1
+       }
+
+       local model_string="$(tplink_pharos_get_model_string)"
+       local line
+
+       # Here $1 is given to dd directly instead of get_image as otherwise the skip
+       # will take almost a second (as dd can't seek then)
+       #
+       # This will fail if the image isn't local, but that's fine: as the
+       # read loop won't be executed at all, it will return true, so the image
+       # is accepted (loading the first 1.5M of a remote image for this check seems
+       # a bit extreme)
+       dd if="$1" bs=1 skip=1511432 count=1024 2>/dev/null | while read line; do
+               [ "$line" == "$model_string" ] && break
+       done || {
+               echo "Unsupported image (model not in support-list)"
+               return 1
+       }
+
+       return 0
+}
+
 seama_get_type_magic() {
        get_image "$@" | dd bs=1 count=4 skip=53 2>/dev/null | hexdump -v -n 4 -e '1/1 "%02x"'
 }
@@ -106,6 +138,29 @@ platform_do_upgrade_compex() {
        fi
 }
 
+alfa_check_image() {
+       local magic_long="$(get_magic_long "$1")"
+       local fw_part_size=$(mtd_get_part_size firmware)
+
+       case "$magic_long" in
+       "27051956")
+               [ "$fw_part_size" != "16318464" ] && {
+                       echo "Invalid image magic \"$magic_long\" for $fw_part_size bytes"
+                       return 1
+               }
+               ;;
+
+       "68737173")
+               [ "$fw_part_size" != "7929856" ] && {
+                       echo "Invalid image magic \"$magic_long\" for $fw_part_size bytes"
+                       return 1
+               }
+               ;;
+       esac
+
+       return 0
+}
+
 platform_check_image() {
        local board=$(ar71xx_board_name)
        local magic="$(get_magic_word "$1")"
@@ -116,22 +171,33 @@ platform_check_image() {
        case "$board" in
        all0315n | \
        all0258n | \
-       cap4200ag)
+       cap324 | \
+       cap4200ag | \
+       cr3000 |\
+       cr5000)
                platform_check_image_allnet "$1" && return 0
                return 1
                ;;
        alfa-ap96 | \
        alfa-nx | \
+       arduino-yun | \
        ap113 | \
        ap121 | \
        ap121-mini | \
        ap136-010 | \
        ap136-020 | \
        ap135-020 | \
+       ap147-010 | \
+       ap152 | \
        ap96 | \
+       bxu2000n-2-a1 | \
        db120 | \
+       dr344 | \
+       f9k1115v2 |\
        hornet-ub | \
-       bxu2000n-2-a1 | \
+       mr12 | \
+       mr16 | \
+       wpj558 | \
        zcn-1523h-2 | \
        zcn-1523h-5)
                [ "$magic_long" != "68737173" -a "$magic_long" != "19852003" ] && {
@@ -143,40 +209,69 @@ platform_check_image() {
        ap81 | \
        ap83 | \
        ap132 | \
+       c-55 | \
+       cf-e316n-v2 | \
+       dgl-5500-a1 |\
+       dhp-1565-a1 |\
        dir-505-a1 | \
        dir-600-a1 | \
        dir-615-c1 | \
+       dir-615-e1 | \
        dir-615-e4 | \
+       dir-615-i1 | \
        dir-825-c1 | \
        dir-835-a1 | \
+       dlan-hotspot | \
+       dlan-pro-500-wp | \
+       dlan-pro-1200-ac | \
        dragino2 | \
+       epg5000 | \
+       esr1750 | \
+       esr900 | \
        ew-dorin | \
        ew-dorin-router | \
+       gl-ar150 | \
+       gl-ar300 | \
+       gl-domino | \
+       hiwifi-hc6361 | \
        hornet-ub-x2 | \
        mzk-w04nu | \
        mzk-w300nh | \
        tew-632brp | \
        tew-712br | \
        tew-732br | \
+       tew-823dru | \
        wrt400n | \
+       airgateway | \
+       airgatewaypro | \
        airrouter | \
        bullet-m | \
+       loco-m-xw | \
        nanostation-m | \
        rocket-m | \
+       rocket-m-xw | \
+       rocket-m-ti | \
+       nanostation-m-xw | \
        rw2458n | \
+       wpj531 | \
        wndap360 | \
+       wpj342 | \
+       wpj344 | \
        wzr-hp-g300nh2 | \
        wzr-hp-g300nh | \
        wzr-hp-g450h | \
        wzr-hp-ag300h | \
+       wzr-450hp2 | \
        whr-g301n | \
        whr-hp-g300n | \
        whr-hp-gn | \
        wlae-ag300n | \
        nbg460n_550n_550nh | \
        unifi | \
+       unifiac | \
        unifi-outdoor | \
-       carambola2 )
+       carambola2 | \
+       weio )
                [ "$magic" != "2705" ] && {
                        echo "Invalid image type."
                        return 1
@@ -184,6 +279,12 @@ platform_check_image() {
                return 0
                ;;
 
+       cpe510)
+               tplink_pharos_check_image "$1" && return 0
+               return 1
+               ;;
+
+       bsb | \
        dir-825-b1 | \
        tew-673gru)
                dir825b_check_image "$1" && return 0
@@ -195,6 +296,7 @@ platform_check_image() {
                return 1
                ;;
 
+       qihoo-c301 | \
        mynet-n600 | \
        mynet-n750)
                [ "$magic_long" != "5ea3a417" ] && {
@@ -210,19 +312,42 @@ platform_check_image() {
 
                return 0;
                ;;
+       mr1750 | \
        mr600 | \
        mr600v2 | \
+       mr900 | \
+       mr900v2 | \
        om2p | \
+       om2pv2 | \
        om2p-hs | \
-       om2p-lc)
+       om2p-hsv2 | \
+       om2p-lc | \
+       om5p | \
+       om5p-an | \
+       om5p-ac | \
+       om5p-acv2)
                platform_check_image_openmesh "$magic_long" "$1" && return 0
                return 1
                ;;
 
+       antminer-s1 | \
+       antminer-s3 | \
+       antrouter-r1 | \
+       archer-c5 | \
        archer-c7 | \
+       el-m150 | \
+       el-mini | \
+       gl-inet | \
+       mc-mac1200r | \
+       minibox-v1 |\
+       omy-x1 |\
+       onion-omega | \
        oolite | \
+       smart-300 | \
+       tellstick-znet-lite | \
        tl-mr10u | \
        tl-mr11u | \
+       tl-mr12u | \
        tl-mr13u | \
        tl-mr3020 | \
        tl-mr3040 | \
@@ -231,44 +356,64 @@ platform_check_image() {
        tl-mr3220-v2 | \
        tl-mr3420 | \
        tl-mr3420-v2 | \
+       tl-wa701nd-v2 | \
+       tl-wa7210n-v2 | \
        tl-wa7510n | \
        tl-wa750re | \
        tl-wa850re | \
+       tl-wa860re | \
        tl-wa801nd-v2 | \
        tl-wa901nd | \
        tl-wa901nd-v2 | \
        tl-wa901nd-v3 | \
+       tl-wdr3320-v2 | \
        tl-wdr3500 | \
        tl-wdr4300 | \
        tl-wdr4900-v2 | \
+       tl-wdr6500-v2 | \
        tl-wr703n | \
        tl-wr710n | \
        tl-wr720n-v3 | \
        tl-wr741nd | \
        tl-wr741nd-v4 | \
        tl-wr841n-v1 | \
+       tl-wa830re-v2 | \
        tl-wr841n-v7 | \
        tl-wr841n-v8 | \
        tl-wr841n-v9 | \
        tl-wr842n-v2 | \
        tl-wr941nd | \
+       tl-wr941nd-v5 | \
+       tl-wr941nd-v6 | \
        tl-wr1041n-v2 | \
        tl-wr1043nd | \
        tl-wr1043nd-v2 | \
        tl-wr2543n)
-               [ "$magic" != "0100" ] && {
+               local magic_ver="0100"
+
+               case "$board" in
+               tl-wdr6500-v2)
+                       magic_ver="0200"
+                       ;;
+               esac
+
+               [ "$magic" != "$magic_ver" ] && {
                        echo "Invalid image type."
                        return 1
                }
 
                local hwid
-               local imageid
+               local mid
+               local imagehwid
+               local imagemid
 
                hwid=$(tplink_get_hwid)
-               imageid=$(tplink_get_image_hwid "$1")
+               mid=$(tplink_get_mid)
+               imagehwid=$(tplink_get_image_hwid "$1")
+               imagemid=$(tplink_get_image_mid "$1")
 
-               [ "$hwid" != "$imageid" ] && {
-                       echo "Invalid image, hardware ID mismatch, hw:$hwid image:$imageid."
+               [ "$hwid" != "$imagehwid" -o "$mid" != "$imagemid" ] && {
+                       echo "Invalid image, hardware ID mismatch, hw:$hwid $mid image:$imagehwid $imagemid."
                        return 1
                }
 
@@ -282,6 +427,14 @@ platform_check_image() {
 
                return 0
                ;;
+
+       tube2h)
+               alfa_check_image "$1" && return 0
+               return 1
+               ;;
+
+       nbg6616 | \
+       unifi-outdoor-plus | \
        uap-pro)
                [ "$magic_long" != "19852003" ] && {
                        echo "Invalid image type."
@@ -290,7 +443,10 @@ platform_check_image() {
                return 0
                ;;
        wndr3700 | \
-       wnr612-v2)
+       wnr2000-v3 | \
+       wnr612-v2 | \
+       wnr1000-v2 | \
+       wpn824n)
                local hw_magic
 
                hw_magic="$(ar71xx_get_mtd_part_magic firmware)"
@@ -300,12 +456,24 @@ platform_check_image() {
                }
                return 0
                ;;
+       mr18)
+               merakinand_do_platform_check $board $1
+               return $?;
+               ;;
+       nbg6716 | \
+       r6100 | \
+       wndr3700v4 | \
+       wndr4300 )
+               nand_do_platform_check $board $1
+               return $?;
+               ;;
        routerstation | \
        routerstation-pro | \
        ls-sr71 | \
        pb42 | \
        pb44 | \
        all0305 | \
+       eap300v2 | \
        eap7660d | \
        ja76pf | \
        ja76pf2 | \
@@ -328,12 +496,43 @@ platform_check_image() {
                fi
                return 0
                ;;
+       wnr2000-v4)
+               [ "$magic_long" != "32303034" ] && {
+                       echo "Invalid image type."
+                       return 1
+               }
+               return 0
+               ;;
+       wnr2200)
+                [ "$magic_long" != "32323030" ] && {
+                        echo "Invalid image type."
+                        return 1
+                }
+                return 0
+                ;;
+
        esac
 
        echo "Sysupgrade is not yet supported on $board."
        return 1
 }
 
+platform_pre_upgrade() {
+       local board=$(ar71xx_board_name)
+
+       case "$board" in
+       nbg6716 | \
+       r6100 | \
+       wndr3700v4 | \
+       wndr4300 )
+               nand_do_upgrade "$1"
+               ;;
+       mr18)
+               merakinand_do_upgrade "$1"
+               ;;
+       esac
+}
+
 platform_do_upgrade() {
        local board=$(ar71xx_board_name)
 
@@ -360,6 +559,7 @@ platform_do_upgrade() {
        all0315n )
                platform_do_upgrade_allnet "0x9f080000" "$ARGV"
                ;;
+       eap300v2 |\
        cap4200ag)
                platform_do_upgrade_allnet "0xbf0a0000" "$ARGV"
                ;;
@@ -367,13 +567,23 @@ platform_do_upgrade() {
        tew-673gru)
                platform_do_upgrade_dir825b "$ARGV"
                ;;
+       mr1750 | \
        mr600 | \
        mr600v2 | \
+       mr900 | \
+       mr900v2 | \
        om2p | \
+       om2pv2 | \
        om2p-hs | \
-       om2p-lc)
+       om2p-hsv2 | \
+       om2p-lc | \
+       om5p | \
+       om5p-an | \
+       om5p-ac | \
+       om5p-acv2)
                platform_do_upgrade_openmesh "$ARGV"
                ;;
+       unifi-outdoor-plus | \
        uap-pro)
                MTD_CONFIG_ARGS="-s 0x180000"
                default_do_upgrade "$ARGV"