mediatek: add Zyxel EX5601-T0 with uboot custom partition
[openwrt/staging/hauke.git] / target / linux / mediatek / filogic / base-files / lib / upgrade / platform.sh
index 11c2c5c66439de82be5e5b3fe9a13d82b3a6e3e9..c31946f0725af7065779c6445a75f4145b92239c 100755 (executable)
@@ -1,6 +1,6 @@
 REQUIRE_IMAGE_METADATA=1
 
-redmi_ax6000_initial_setup()
+xiaomi_initial_setup()
 {
        # initialize UBI and setup uboot-env if it's running on initramfs
        [ "$(rootfs_type)" = "tmpfs" ] || return 0
@@ -35,14 +35,29 @@ redmi_ax6000_initial_setup()
        fw_setenv flag_boot_success 1
        fw_setenv flag_try_sys1_failed 8
        fw_setenv flag_try_sys2_failed 8
-       fw_setenv mtdparts "nmbm0:1024k(bl2),256k(Nvram),256k(Bdata),2048k(factory),2048k(fip),256k(crash),256k(crash_log),30720k(ubi),30720k(ubi1),51200k(overlay)"
+
+       local board=$(board_name)
+       case "$board" in
+       xiaomi,mi-router-wr30u-stock)
+               fw_setenv mtdparts "nmbm0:1024k(bl2),256k(Nvram),256k(Bdata),2048k(factory),2048k(fip),256k(crash),256k(crash_log),34816k(ubi),34816k(ubi1),32768k(overlay),12288k(data),256k(KF)"
+               ;;
+       xiaomi,redmi-router-ax6000-stock)
+               fw_setenv mtdparts "nmbm0:1024k(bl2),256k(Nvram),256k(Bdata),2048k(factory),2048k(fip),256k(crash),256k(crash_log),30720k(ubi),30720k(ubi1),51200k(overlay)"
+               ;;
+       esac
 }
 
 platform_do_upgrade() {
        local board=$(board_name)
 
        case "$board" in
-       asus,tuf-ax4200)
+       acer,predator-w6)
+               CI_KERNPART="kernel"
+               CI_ROOTPART="rootfs"
+               emmc_do_upgrade "$1"
+               ;;
+       asus,tuf-ax4200|\
+       asus,tuf-ax6000)
                CI_UBIPART="UBI_DEV"
                CI_KERNPART="linux"
                nand_do_upgrade "$1"
@@ -67,26 +82,58 @@ platform_do_upgrade() {
                        ;;
                esac
                ;;
+       cmcc,rax3000m)
+               case "$(cmdline_get_var root)" in
+               /dev/mmc*)
+                       CI_KERNPART="production"
+                       emmc_do_upgrade "$1"
+                       ;;
+               *)
+                       CI_KERNPART="fit"
+                       nand_do_upgrade "$1"
+                       ;;
+               esac
+               ;;
        cudy,wr3000-v1)
                default_do_upgrade "$1"
                ;;
+       glinet,gl-mt6000)
+               CI_KERNPART="kernel"
+               CI_ROOTPART="rootfs"
+               emmc_do_upgrade "$1"
+               ;;
        mercusys,mr90x-v1)
                CI_UBIPART="ubi0"
                nand_do_upgrade "$1"
                ;;
+       ubnt,unifi-6-plus)
+               CI_KERNPART="kernel0"
+               EMMC_ROOT_DEV="$(cmdline_get_var root)"
+               emmc_do_upgrade "$1"
+               ;;
+       h3c,magic-nx30-pro|\
+       jcg,q30-pro|\
+       mediatek,mt7981-rfb|\
        qihoo,360t7|\
        tplink,tl-xdr4288|\
        tplink,tl-xdr6086|\
        tplink,tl-xdr6088|\
+       xiaomi,mi-router-wr30u-ubootmod|\
        xiaomi,redmi-router-ax6000-ubootmod)
                CI_KERNPART="fit"
                nand_do_upgrade "$1"
                ;;
+       xiaomi,mi-router-wr30u-stock|\
        xiaomi,redmi-router-ax6000-stock)
                CI_KERN_UBIPART=ubi_kernel
                CI_ROOT_UBIPART=ubi
                nand_do_upgrade "$1"
                ;;
+        zyxel,ex5601-t0-ubootmod)
+               CI_KERNPART="fit"
+               CI_ROOTPART="ubi_rootfs"
+                nand_do_upgrade "$1"
+                ;;
        *)
                nand_do_upgrade "$1"
                ;;
@@ -102,7 +149,8 @@ platform_check_image() {
        [ "$#" -gt 1 ] && return 1
 
        case "$board" in
-       bananapi,bpi-r3)
+       bananapi,bpi-r3|\
+       cmcc,rax3000m)
                [ "$magic" != "d00dfeed" ] && {
                        echo "Invalid image type."
                        return 1
@@ -120,13 +168,18 @@ platform_check_image() {
 
 platform_copy_config() {
        case "$(board_name)" in
-       bananapi,bpi-r3)
+       bananapi,bpi-r3|\
+       cmcc,rax3000m)
                case "$(cmdline_get_var root)" in
                /dev/mmc*)
                        emmc_copy_config
                        ;;
                esac
                ;;
+       glinet,gl-mt6000|\
+       ubnt,unifi-6-plus)
+               emmc_copy_config
+               ;;
        esac
 }
 
@@ -134,8 +187,9 @@ platform_pre_upgrade() {
        local board=$(board_name)
 
        case "$board" in
+       xiaomi,mi-router-wr30u-stock|\
        xiaomi,redmi-router-ax6000-stock)
-               redmi_ax6000_initial_setup
+               xiaomi_initial_setup
                ;;
        esac
 }