diff --git a/target/linux/qualcommax/ipq807x/base-files/lib/upgrade/platform.sh b/target/linux/qualcommax/ipq807x/base-files/lib/upgrade/platform.sh index 3bfeb1366b2..1bc71efdb50 100644 --- a/target/linux/qualcommax/ipq807x/base-files/lib/upgrade/platform.sh +++ b/target/linux/qualcommax/ipq807x/base-files/lib/upgrade/platform.sh @@ -109,6 +109,8 @@ tplink_do_upgrade() { } linksys_mx_do_upgrade() { + local setenv_script="/tmp/fw_env_upgrade" + CI_UBIPART="rootfs" boot_part="$(fw_printenv -n boot_part)" if [ -n "$UPGRADE_OPT_USE_CURR_PART" ]; then @@ -118,15 +120,30 @@ linksys_mx_do_upgrade() { fi else if [ "$boot_part" -eq "1" ]; then - fw_setenv boot_part 2 + echo "boot_part 2" >> $setenv_script CI_KERNPART="alt_kernel" CI_UBIPART="alt_rootfs" else - fw_setenv boot_part 1 + echo "boot_part 1" >> $setenv_script fi fi - fw_setenv boot_part_ready 3 - fw_setenv auto_recovery yes + + boot_part_ready="$(fw_printenv -n boot_part_ready)" + if [ "$boot_part_ready" -ne "3" ]; then + echo "boot_part_ready 3" >> $setenv_script + fi + + auto_recovery="$(fw_printenv -n auto_recovery)" + if [ "$auto_recovery" != "yes" ]; then + echo "auto_recovery yes" >> $setenv_script + fi + + if [ -f "$setenv_script" ]; then + fw_setenv -s $setenv_script || { + echo "failed to update U-Boot environment" + return 1 + } + fi nand_do_upgrade "$1" }