ipq40xx: add support for FritzBox 7530
[openwrt/openwrt.git] / target / linux / ipq40xx / base-files / lib / upgrade / platform.sh
index 52aa2321e3e2d4988771c6008d5c1fa0823a653b..9a2c13cf4db014e11e3b62ca8cbc519dbc406975 100644 (file)
@@ -29,14 +29,43 @@ EOF
        return 0;
 }
 
+zyxel_do_upgrade() {
+       local tar_file="$1"
+
+       local board_dir=$(tar tf $tar_file | grep -m 1 '^sysupgrade-.*/$')
+       board_dir=${board_dir%/}
+
+       tar Oxf $tar_file ${board_dir}/kernel | mtd write - kernel
+
+       if [ "$SAVE_CONFIG" -eq 1 ]; then
+               tar Oxf $tar_file ${board_dir}/root | mtd -j "$CONF_TAR" write - rootfs
+       else
+               tar Oxf $tar_file ${board_dir}/root | mtd write - rootfs
+       fi
+}
+
 platform_do_upgrade() {
        case "$(board_name)" in
+       8dev,jalapeno |\
+       alfa-network,ap120c-ac |\
+       avm,fritzbox-7530 |\
+       qxwlan,e2600ac-c2)
+               nand_do_upgrade "$ARGV"
+               ;;
+       asus,map-ac2200)
+               CI_KERNPART="linux"
+               nand_do_upgrade "$1"
+               ;;
        asus,rt-ac58u)
                CI_UBIPART="UBI_DEV"
                CI_KERNPART="linux"
                nand_do_upgrade "$1"
                ;;
-       openmesh,a42)
+       linksys,ea6350v3)
+               platform_do_upgrade_linksys "$ARGV"
+               ;;
+       openmesh,a42 |\
+       openmesh,a62)
                PART_NAME="inactive"
                platform_do_upgrade_openmesh "$ARGV"
                ;;
@@ -44,6 +73,9 @@ platform_do_upgrade() {
                CI_KERNPART="part.safe"
                nand_do_upgrade "$1"
                ;;
+       zyxel,nbg6617)
+               zyxel_do_upgrade "$1"
+               ;;
        *)
                default_do_upgrade "$ARGV"
                ;;
@@ -52,6 +84,16 @@ platform_do_upgrade() {
 
 platform_nand_pre_upgrade() {
        case "$(board_name)" in
+       alfa-network,ap120c-ac)
+               part="$(awk -F 'ubi.mtd=' '{printf $2}' /proc/cmdline | sed -e 's/ .*$//')"
+               if [ "$part" = "rootfs1" ]; then
+                       fw_setenv active 2 || exit 1
+                       CI_UBIPART="rootfs2"
+               else
+                       fw_setenv active 1 || exit 1
+                       CI_UBIPART="rootfs1"
+               fi
+               ;;
        asus,rt-ac58u)
                CI_UBIPART="UBI_DEV"
                CI_KERNPART="linux"
@@ -61,9 +103,3 @@ platform_nand_pre_upgrade() {
                ;;
        esac
 }
-
-blink_led() {
-       . /etc/diag.sh; set_state upgrade
-}
-
-append sysupgrade_pre_upgrade blink_led