ar71xx: add support for compex wpj344
[openwrt.git] / target / linux / ar71xx / base-files / lib / upgrade / platform.sh
index 1db72d8..1c349fe 100755 (executable)
@@ -70,6 +70,33 @@ 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"'
 }
@@ -153,9 +180,12 @@ platform_check_image() {
        ap136-020 | \
        ap135-020 | \
        ap96 | \
+       bxu2000n-2-a1 | \
        db120 | \
+       f9k1115v2 |\
        hornet-ub | \
-       bxu2000n-2-a1 | \
+       wpj344 | \
+       wpj558 | \
        zcn-1523h-2 | \
        zcn-1523h-5)
                [ "$magic_long" != "68737173" -a "$magic_long" != "19852003" ] && {
@@ -167,6 +197,7 @@ platform_check_image() {
        ap81 | \
        ap83 | \
        ap132 | \
+       dgl-5500-a1 |\
        dhp-1565-a1 |\
        dir-505-a1 | \
        dir-600-a1 | \
@@ -217,6 +248,11 @@ platform_check_image() {
                return 0
                ;;
 
+       cpe510)
+               tplink_pharos_check_image "$1" && return 0
+               return 1
+               ;;
+
        dir-825-b1 | \
        tew-673gru)
                dir825b_check_image "$1" && return 0
@@ -253,7 +289,8 @@ platform_check_image() {
        om2p-hs | \
        om2p-hsv2 | \
        om2p-lc | \
-       om5p)
+       om5p | \
+       om5p-an)
                platform_check_image_openmesh "$magic_long" "$1" && return 0
                return 1
                ;;
@@ -263,10 +300,12 @@ platform_check_image() {
        el-m150 | \
        el-mini | \
        gl-inet | \
+       mc-mac1200r | \
        oolite | \
        smart-300 | \
        tl-mr10u | \
        tl-mr11u | \
+       tl-mr12u | \
        tl-mr13u | \
        tl-mr3020 | \
        tl-mr3040 | \
@@ -275,6 +314,8 @@ platform_check_image() {
        tl-mr3220-v2 | \
        tl-mr3420 | \
        tl-mr3420-v2 | \
+       tl-wa701nd-v2 | \
+       tl-wa7210n-v2 | \
        tl-wa7510n | \
        tl-wa750re | \
        tl-wa850re | \
@@ -298,6 +339,7 @@ platform_check_image() {
        tl-wr841n-v9 | \
        tl-wr842n-v2 | \
        tl-wr941nd | \
+       tl-wr941nd-v5 | \
        tl-wr1041n-v2 | \
        tl-wr1043nd | \
        tl-wr1043nd-v2 | \
@@ -334,6 +376,7 @@ platform_check_image() {
                return 1
                ;;
 
+       unifi-outdoor-plus | \
        uap-pro)
                [ "$magic_long" != "19852003" ] && {
                        echo "Invalid image type."
@@ -343,7 +386,8 @@ platform_check_image() {
                ;;
        wndr3700 | \
        wnr2000-v3 | \
-       wnr612-v2)
+       wnr612-v2 | \
+       wnr1000-v2)
                local hw_magic
 
                hw_magic="$(ar71xx_get_mtd_part_magic firmware)"
@@ -354,6 +398,7 @@ platform_check_image() {
                return 0
                ;;
        nbg6716 | \
+       r6100 | \
        wndr3700v4 | \
        wndr4300 )
                nand_do_platform_check $board $1
@@ -445,9 +490,11 @@ platform_do_upgrade() {
        om2p-hs | \
        om2p-hsv2 | \
        om2p-lc | \
-       om5p)
+       om5p | \
+       om5p-an)
                platform_do_upgrade_openmesh "$ARGV"
                ;;
+       unifi-outdoor-plus | \
        uap-pro)
                MTD_CONFIG_ARGS="-s 0x180000"
                default_do_upgrade "$ARGV"