mediatek: add support for YunCore AX835
[openwrt/openwrt.git] / target / linux / mediatek / filogic / base-files / lib / upgrade / platform.sh
index f9f71a2b39119d2cb81d29225d06bc248b647288..517f4520e143c08d0bbcc73f8bb8e12a1c57d9ff 100755 (executable)
@@ -1,5 +1,16 @@
 REQUIRE_IMAGE_METADATA=1
 
+asus_initial_setup()
+{
+       # initialize UBI if it's running on initramfs
+       [ "$(rootfs_type)" = "tmpfs" ] || return 0
+
+       ubirmvol /dev/ubi0 -N rootfs
+       ubirmvol /dev/ubi0 -N rootfs_data
+       ubirmvol /dev/ubi0 -N jffs2
+       ubimkvol /dev/ubi0 -N jffs2 -s 0x3e000
+}
+
 xiaomi_initial_setup()
 {
        # initialize UBI and setup uboot-env if it's running on initramfs
@@ -38,6 +49,7 @@ xiaomi_initial_setup()
 
        local board=$(board_name)
        case "$board" in
+       xiaomi,mi-router-ax3000t|\
        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)"
                ;;
@@ -51,12 +63,18 @@ platform_do_upgrade() {
        local board=$(board_name)
 
        case "$board" in
-       acer,predator-w6)
+       acer,predator-w6|\
+       smartrg,sdg-8612|\
+       smartrg,sdg-8614|\
+       smartrg,sdg-8622|\
+       smartrg,sdg-8632)
                CI_KERNPART="kernel"
                CI_ROOTPART="rootfs"
                emmc_do_upgrade "$1"
                ;;
-       asus,tuf-ax4200)
+       asus,rt-ax59u|\
+       asus,tuf-ax4200|\
+       asus,tuf-ax6000)
                CI_UBIPART="UBI_DEV"
                CI_KERNPART="linux"
                nand_do_upgrade "$1"
@@ -81,29 +99,62 @@ platform_do_upgrade() {
                        ;;
                esac
                ;;
-       cudy,wr3000-v1)
+       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|\
+       yuncore,ax835)
                default_do_upgrade "$1"
                ;;
-       mercusys,mr90x-v1)
-               CI_UBIPART="ubi0"
-               nand_do_upgrade "$1"
+       glinet,gl-mt2500|\
+       glinet,gl-mt6000)
+               CI_KERNPART="kernel"
+               CI_ROOTPART="rootfs"
+               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-ax3000t-ubootmod|\
        xiaomi,mi-router-wr30u-ubootmod|\
        xiaomi,redmi-router-ax6000-ubootmod)
                CI_KERNPART="fit"
                nand_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"
+               ;;
+       xiaomi,mi-router-ax3000t|\
        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"
                ;;
@@ -119,7 +170,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
@@ -137,13 +189,20 @@ 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
                ;;
+       acer,predator-w6|\
+       glinet,gl-mt2500|\
+       glinet,gl-mt6000|\
+       ubnt,unifi-6-plus)
+               emmc_copy_config
+               ;;
        esac
 }
 
@@ -151,6 +210,12 @@ platform_pre_upgrade() {
        local board=$(board_name)
 
        case "$board" in
+       asus,rt-ax59u|\
+       asus,tuf-ax4200|\
+       asus,tuf-ax6000)
+               asus_initial_setup
+               ;;
+       xiaomi,mi-router-ax3000t|\
        xiaomi,mi-router-wr30u-stock|\
        xiaomi,redmi-router-ax6000-stock)
                xiaomi_initial_setup