ar71xx: add support for Compex WPJ342
[openwrt/openwrt.git] / target / linux / ar71xx / base-files / lib / upgrade / platform.sh
index b5ba47fb7687c96571300b1857ab4593462cb74f..86375a9acce557f132398dbfa322dbedba0a30f7 100755 (executable)
@@ -66,6 +66,10 @@ 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"'
 }
@@ -167,12 +171,16 @@ 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 | \
@@ -180,9 +188,11 @@ platform_check_image() {
        ap136-020 | \
        ap135-020 | \
        ap147-010 | \
+       ap152 | \
        ap96 | \
        bxu2000n-2-a1 | \
        db120 | \
+       dr344 | \
        f9k1115v2 |\
        hornet-ub | \
        mr12 | \
@@ -199,6 +209,7 @@ platform_check_image() {
        ap81 | \
        ap83 | \
        ap132 | \
+       c-55 | \
        cf-e316n-v2 | \
        dgl-5500-a1 |\
        dhp-1565-a1 |\
@@ -210,6 +221,7 @@ platform_check_image() {
        dir-615-i1 | \
        dir-825-c1 | \
        dir-835-a1 | \
+       dlan-hotspot | \
        dlan-pro-500-wp | \
        dlan-pro-1200-ac | \
        dragino2 | \
@@ -218,6 +230,9 @@ platform_check_image() {
        esr900 | \
        ew-dorin | \
        ew-dorin-router | \
+       gl-ar150 | \
+       gl-ar300 | \
+       gl-domino | \
        hiwifi-hc6361 | \
        hornet-ub-x2 | \
        mzk-w04nu | \
@@ -225,8 +240,10 @@ platform_check_image() {
        tew-632brp | \
        tew-712br | \
        tew-732br | \
+       tew-823dru | \
        wrt400n | \
        airgateway | \
+       airgatewaypro | \
        airrouter | \
        bullet-m | \
        loco-m-xw | \
@@ -238,6 +255,7 @@ platform_check_image() {
        rw2458n | \
        wpj531 | \
        wndap360 | \
+       wpj342 | \
        wpj344 | \
        wzr-hp-g300nh2 | \
        wzr-hp-g300nh | \
@@ -250,8 +268,10 @@ platform_check_image() {
        wlae-ag300n | \
        nbg460n_550n_550nh | \
        unifi | \
+       unifiac | \
        unifi-outdoor | \
-       carambola2 )
+       carambola2 | \
+       weio )
                [ "$magic" != "2705" ] && {
                        echo "Invalid image type."
                        return 1
@@ -303,22 +323,28 @@ platform_check_image() {
        om2p-hsv2 | \
        om2p-lc | \
        om5p | \
-       om5p-an)
+       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 | \
@@ -358,6 +384,7 @@ platform_check_image() {
        tl-wr842n-v2 | \
        tl-wr941nd | \
        tl-wr941nd-v5 | \
+       tl-wr941nd-v6 | \
        tl-wr1041n-v2 | \
        tl-wr1043nd | \
        tl-wr1043nd-v2 | \
@@ -376,13 +403,17 @@ platform_check_image() {
                }
 
                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
                }
 
@@ -402,6 +433,7 @@ platform_check_image() {
                return 1
                ;;
 
+       nbg6616 | \
        unifi-outdoor-plus | \
        uap-pro)
                [ "$magic_long" != "19852003" ] && {
@@ -413,7 +445,8 @@ platform_check_image() {
        wndr3700 | \
        wnr2000-v3 | \
        wnr612-v2 | \
-       wnr1000-v2)
+       wnr1000-v2 | \
+       wpn824n)
                local hw_magic
 
                hw_magic="$(ar71xx_get_mtd_part_magic firmware)"
@@ -423,6 +456,10 @@ platform_check_image() {
                }
                return 0
                ;;
+       mr18)
+               merakinand_do_platform_check $board $1
+               return $?;
+               ;;
        nbg6716 | \
        r6100 | \
        wndr3700v4 | \
@@ -459,13 +496,20 @@ platform_check_image() {
                fi
                return 0
                ;;
-    wnr2000-v4)
+       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
 
@@ -483,6 +527,9 @@ platform_pre_upgrade() {
        wndr4300 )
                nand_do_upgrade "$1"
                ;;
+       mr18)
+               merakinand_do_upgrade "$1"
+               ;;
        esac
 }
 
@@ -531,7 +578,9 @@ platform_do_upgrade() {
        om2p-hsv2 | \
        om2p-lc | \
        om5p | \
-       om5p-an)
+       om5p-an | \
+       om5p-ac | \
+       om5p-acv2)
                platform_do_upgrade_openmesh "$ARGV"
                ;;
        unifi-outdoor-plus | \