add D-link DGL-5500 A1 support
[openwrt/openwrt.git] / target / linux / ar71xx / base-files / lib / upgrade / platform.sh
index de831b2eaeca4a6832321b6efa47b57dcdd658a1..2e5b0dd90ab8aacbab211387ce81bd12899d17e7 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"'
 }
@@ -167,6 +194,8 @@ platform_check_image() {
        ap81 | \
        ap83 | \
        ap132 | \
+       dgl-5500-a1 |\
+       dhp-1565-a1 |\
        dir-505-a1 | \
        dir-600-a1 | \
        dir-615-c1 | \
@@ -176,6 +205,7 @@ platform_check_image() {
        dir-835-a1 | \
        dragino2 | \
        esr1750 | \
+       esr900 | \
        ew-dorin | \
        ew-dorin-router | \
        hiwifi-hc6361 | \
@@ -189,6 +219,7 @@ platform_check_image() {
        airgateway | \
        airrouter | \
        bullet-m | \
+       loco-m-xw | \
        nanostation-m | \
        rocket-m | \
        nanostation-m-xw | \
@@ -198,6 +229,7 @@ platform_check_image() {
        wzr-hp-g300nh | \
        wzr-hp-g450h | \
        wzr-hp-ag300h | \
+       wzr-450hp2 | \
        whr-g301n | \
        whr-hp-g300n | \
        whr-hp-gn | \
@@ -213,6 +245,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
@@ -224,6 +261,7 @@ platform_check_image() {
                return 1
                ;;
 
+       qihoo-c301 | \
        mynet-n600 | \
        mynet-n750)
                [ "$magic_long" != "5ea3a417" ] && {
@@ -241,6 +279,8 @@ platform_check_image() {
                ;;
        mr600 | \
        mr600v2 | \
+       mr900 | \
+       mr900v2 | \
        om2p | \
        om2pv2 | \
        om2p-hs | \
@@ -251,11 +291,13 @@ platform_check_image() {
                return 1
                ;;
 
+       archer-c5 | \
        archer-c7 | \
        el-m150 | \
        el-mini | \
        gl-inet | \
        oolite | \
+       smart-300 | \
        tl-mr10u | \
        tl-mr11u | \
        tl-mr13u | \
@@ -345,6 +387,7 @@ platform_check_image() {
                return 0
                ;;
        nbg6716 | \
+       r6100 | \
        wndr3700v4 | \
        wndr4300 )
                nand_do_platform_check $board $1
@@ -379,6 +422,14 @@ platform_check_image() {
                fi
                return 0
                ;;
+    wnr2000-v4)
+               [ "$magic_long" != "32303034" ] && {
+                       echo "Invalid image type."
+                       return 1
+               }
+               return 0
+               ;;
+
        esac
 
        echo "Sysupgrade is not yet supported on $board."
@@ -421,6 +472,8 @@ platform_do_upgrade() {
                ;;
        mr600 | \
        mr600v2 | \
+       mr900 | \
+       mr900v2 | \
        om2p | \
        om2pv2 | \
        om2p-hs | \