2019-01-23 21:20:55 -06:00
|
|
|
linksys_get_target_firmware() {
|
mtd: base-files: Unify dual-firmware devices (Linksys)
Consistently handle boot-count reset and upgrade across
ipq40xx, ipq806x, kirkwood, mvebu
Dual-firmware devices often utilize a specific MTD partition
to record the number of times the boot loader has initiated boot.
Most of these devices are NAND, typically with a 2k erase size.
When this code was ported to the ipq40xx platform, the device in hand
used NOR for this partition, with a 16-byte "record" size. As the
implementation of `mtd resetbc` is by-platform, the hard-coded nature
of this change prevented proper operation of a NAND-based device.
* Unified the "NOR" variant with the rest of the Linksys variants
* Added logging to indicate success and failure
* Provided a meaningful return value for scripting
* "Protected" the use of `mtd resetbc` in start-up scripts so that
failure does not end the boot sequence
* Moved Linksys-specific actions into common `/etc/init.d/bootcount`
For upgrade, these devices need to determine which partition to flash,
as well as set certain U-Boot envirnment variables to change the next
boot to the newly flashed version.
* Moved upgrade-related environment changes out of bootcount
* Combined multiple flashes of environment into single one
* Current-partition detection now handles absence of `boot_part`
Runtime-tested: Linksys EA8300
Signed-off-by: Jeff Kletsky <git-commits@allycomm.com>
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
[checkpatch.pl fixes, traded split strings for 80+ chars per line]
2019-04-10 08:28:01 -07:00
|
|
|
local cur_boot_part mtd_ubi0
|
|
|
|
|
2019-06-15 14:40:56 -07:00
|
|
|
cur_boot_part="$(/usr/sbin/fw_printenv -n boot_part)"
|
|
|
|
if [ -z "${cur_boot_part}" ]; then
|
mtd: base-files: Unify dual-firmware devices (Linksys)
Consistently handle boot-count reset and upgrade across
ipq40xx, ipq806x, kirkwood, mvebu
Dual-firmware devices often utilize a specific MTD partition
to record the number of times the boot loader has initiated boot.
Most of these devices are NAND, typically with a 2k erase size.
When this code was ported to the ipq40xx platform, the device in hand
used NOR for this partition, with a 16-byte "record" size. As the
implementation of `mtd resetbc` is by-platform, the hard-coded nature
of this change prevented proper operation of a NAND-based device.
* Unified the "NOR" variant with the rest of the Linksys variants
* Added logging to indicate success and failure
* Provided a meaningful return value for scripting
* "Protected" the use of `mtd resetbc` in start-up scripts so that
failure does not end the boot sequence
* Moved Linksys-specific actions into common `/etc/init.d/bootcount`
For upgrade, these devices need to determine which partition to flash,
as well as set certain U-Boot envirnment variables to change the next
boot to the newly flashed version.
* Moved upgrade-related environment changes out of bootcount
* Combined multiple flashes of environment into single one
* Current-partition detection now handles absence of `boot_part`
Runtime-tested: Linksys EA8300
Signed-off-by: Jeff Kletsky <git-commits@allycomm.com>
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
[checkpatch.pl fixes, traded split strings for 80+ chars per line]
2019-04-10 08:28:01 -07:00
|
|
|
mtd_ubi0=$(cat /sys/devices/virtual/ubi/ubi0/mtd_num)
|
2019-06-15 14:40:56 -07:00
|
|
|
case "$(grep -E "^mtd${mtd_ubi0}:" /proc/mtd | cut -d '"' -f 2)" in
|
mtd: base-files: Unify dual-firmware devices (Linksys)
Consistently handle boot-count reset and upgrade across
ipq40xx, ipq806x, kirkwood, mvebu
Dual-firmware devices often utilize a specific MTD partition
to record the number of times the boot loader has initiated boot.
Most of these devices are NAND, typically with a 2k erase size.
When this code was ported to the ipq40xx platform, the device in hand
used NOR for this partition, with a 16-byte "record" size. As the
implementation of `mtd resetbc` is by-platform, the hard-coded nature
of this change prevented proper operation of a NAND-based device.
* Unified the "NOR" variant with the rest of the Linksys variants
* Added logging to indicate success and failure
* Provided a meaningful return value for scripting
* "Protected" the use of `mtd resetbc` in start-up scripts so that
failure does not end the boot sequence
* Moved Linksys-specific actions into common `/etc/init.d/bootcount`
For upgrade, these devices need to determine which partition to flash,
as well as set certain U-Boot envirnment variables to change the next
boot to the newly flashed version.
* Moved upgrade-related environment changes out of bootcount
* Combined multiple flashes of environment into single one
* Current-partition detection now handles absence of `boot_part`
Runtime-tested: Linksys EA8300
Signed-off-by: Jeff Kletsky <git-commits@allycomm.com>
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
[checkpatch.pl fixes, traded split strings for 80+ chars per line]
2019-04-10 08:28:01 -07:00
|
|
|
kernel|rootfs)
|
|
|
|
cur_boot_part=1
|
|
|
|
;;
|
|
|
|
alt_kernel|alt_rootfs)
|
|
|
|
cur_boot_part=2
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
>&2 printf "Current boot_part='%s' selected from ubi0/mtd_num='%s'" \
|
|
|
|
"${cur_boot_part}" "${mtd_ubi0}"
|
2019-01-23 21:20:55 -06:00
|
|
|
fi
|
|
|
|
|
mtd: base-files: Unify dual-firmware devices (Linksys)
Consistently handle boot-count reset and upgrade across
ipq40xx, ipq806x, kirkwood, mvebu
Dual-firmware devices often utilize a specific MTD partition
to record the number of times the boot loader has initiated boot.
Most of these devices are NAND, typically with a 2k erase size.
When this code was ported to the ipq40xx platform, the device in hand
used NOR for this partition, with a 16-byte "record" size. As the
implementation of `mtd resetbc` is by-platform, the hard-coded nature
of this change prevented proper operation of a NAND-based device.
* Unified the "NOR" variant with the rest of the Linksys variants
* Added logging to indicate success and failure
* Provided a meaningful return value for scripting
* "Protected" the use of `mtd resetbc` in start-up scripts so that
failure does not end the boot sequence
* Moved Linksys-specific actions into common `/etc/init.d/bootcount`
For upgrade, these devices need to determine which partition to flash,
as well as set certain U-Boot envirnment variables to change the next
boot to the newly flashed version.
* Moved upgrade-related environment changes out of bootcount
* Combined multiple flashes of environment into single one
* Current-partition detection now handles absence of `boot_part`
Runtime-tested: Linksys EA8300
Signed-off-by: Jeff Kletsky <git-commits@allycomm.com>
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
[checkpatch.pl fixes, traded split strings for 80+ chars per line]
2019-04-10 08:28:01 -07:00
|
|
|
# OEM U-Boot for EA6350v3 and EA8300; bootcmd=
|
|
|
|
# if test $auto_recovery = no;
|
|
|
|
# then bootipq;
|
|
|
|
# elif test $boot_part = 1;
|
|
|
|
# then run bootpart1;
|
|
|
|
# else run bootpart2;
|
|
|
|
# fi
|
2019-01-23 21:20:55 -06:00
|
|
|
|
2019-06-15 14:40:56 -07:00
|
|
|
case "$cur_boot_part" in
|
mtd: base-files: Unify dual-firmware devices (Linksys)
Consistently handle boot-count reset and upgrade across
ipq40xx, ipq806x, kirkwood, mvebu
Dual-firmware devices often utilize a specific MTD partition
to record the number of times the boot loader has initiated boot.
Most of these devices are NAND, typically with a 2k erase size.
When this code was ported to the ipq40xx platform, the device in hand
used NOR for this partition, with a 16-byte "record" size. As the
implementation of `mtd resetbc` is by-platform, the hard-coded nature
of this change prevented proper operation of a NAND-based device.
* Unified the "NOR" variant with the rest of the Linksys variants
* Added logging to indicate success and failure
* Provided a meaningful return value for scripting
* "Protected" the use of `mtd resetbc` in start-up scripts so that
failure does not end the boot sequence
* Moved Linksys-specific actions into common `/etc/init.d/bootcount`
For upgrade, these devices need to determine which partition to flash,
as well as set certain U-Boot envirnment variables to change the next
boot to the newly flashed version.
* Moved upgrade-related environment changes out of bootcount
* Combined multiple flashes of environment into single one
* Current-partition detection now handles absence of `boot_part`
Runtime-tested: Linksys EA8300
Signed-off-by: Jeff Kletsky <git-commits@allycomm.com>
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
[checkpatch.pl fixes, traded split strings for 80+ chars per line]
2019-04-10 08:28:01 -07:00
|
|
|
1)
|
|
|
|
fw_setenv -s - <<-EOF
|
|
|
|
boot_part 2
|
|
|
|
auto_recovery yes
|
|
|
|
EOF
|
|
|
|
printf "alt_kernel"
|
|
|
|
return
|
|
|
|
;;
|
|
|
|
2)
|
|
|
|
fw_setenv -s - <<-EOF
|
|
|
|
boot_part 1
|
|
|
|
auto_recovery yes
|
|
|
|
EOF
|
|
|
|
printf "kernel"
|
|
|
|
return
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
return
|
|
|
|
;;
|
|
|
|
esac
|
2019-01-23 21:20:55 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
linksys_get_root_magic() {
|
|
|
|
(get_image "$@" | dd skip=786432 bs=4 count=1 | hexdump -v -n 4 -e '1/1 "%02x"') 2>/dev/null
|
|
|
|
}
|
|
|
|
|
|
|
|
platform_do_upgrade_linksys() {
|
|
|
|
local magic_long="$(get_magic_long "$1")"
|
|
|
|
|
2019-06-15 14:40:56 -07:00
|
|
|
local rm_oem_fw_vols="squashfs ubifs" # from OEM [alt_]rootfs UBI
|
|
|
|
local vol
|
|
|
|
|
2019-01-23 21:20:55 -06:00
|
|
|
mkdir -p /var/lock
|
|
|
|
local part_label="$(linksys_get_target_firmware)"
|
|
|
|
touch /var/lock/fw_printenv.lock
|
|
|
|
|
2019-06-15 14:40:56 -07:00
|
|
|
if [ -z "$part_label" ]; then
|
2019-01-23 21:20:55 -06:00
|
|
|
echo "cannot find target partition"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2019-06-15 14:40:56 -07:00
|
|
|
local target_mtd=$(find_mtd_part "$part_label")
|
2019-01-23 21:20:55 -06:00
|
|
|
|
|
|
|
[ "$magic_long" = "73797375" ] && {
|
|
|
|
CI_KERNPART="$part_label"
|
|
|
|
if [ "$part_label" = "kernel" ]; then
|
|
|
|
CI_UBIPART="rootfs"
|
|
|
|
else
|
|
|
|
CI_UBIPART="alt_rootfs"
|
|
|
|
fi
|
|
|
|
|
2019-06-15 14:40:56 -07:00
|
|
|
local mtdnum="$(find_mtd_index "$CI_UBIPART")"
|
2019-01-23 21:20:55 -06:00
|
|
|
if [ ! "$mtdnum" ]; then
|
|
|
|
echo "cannot find ubi mtd partition $CI_UBIPART"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
2019-06-15 14:40:56 -07:00
|
|
|
local ubidev="$(nand_find_ubi "$CI_UBIPART")"
|
2019-01-23 21:20:55 -06:00
|
|
|
if [ ! "$ubidev" ]; then
|
|
|
|
ubiattach -m "$mtdnum"
|
|
|
|
sync
|
2019-06-15 14:40:56 -07:00
|
|
|
ubidev="$(nand_find_ubi "$CI_UBIPART")"
|
2019-01-23 21:20:55 -06:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$ubidev" ]; then
|
2019-06-15 14:40:56 -07:00
|
|
|
for vol in $rm_oem_fw_vols; do
|
|
|
|
ubirmvol "/dev/$ubidev" -N "$vol" 2>/dev/null
|
|
|
|
done
|
2019-01-23 21:20:55 -06:00
|
|
|
fi
|
|
|
|
|
|
|
|
# complete std upgrade
|
|
|
|
nand_upgrade_tar "$1"
|
|
|
|
}
|
2019-06-15 14:40:56 -07:00
|
|
|
|
2019-01-23 21:20:55 -06:00
|
|
|
[ "$magic_long" = "27051956" ] && {
|
|
|
|
# This magic is for a uImage (which is a sysupgrade image)
|
|
|
|
# check firmwares' rootfs types
|
2019-06-15 14:40:56 -07:00
|
|
|
local oldroot="$(linksys_get_root_magic "$target_mtd")"
|
2019-01-23 21:20:55 -06:00
|
|
|
local newroot="$(linksys_get_root_magic "$1")"
|
|
|
|
|
2019-06-15 14:40:56 -07:00
|
|
|
if [ "$newroot" = "55424923" ] && [ "$oldroot" = "55424923" ]; then
|
2019-01-23 21:20:55 -06:00
|
|
|
# we're upgrading from a firmware with UBI to one with UBI
|
|
|
|
# erase everything to be safe
|
2019-06-15 14:40:56 -07:00
|
|
|
# - Is that really needed? Won't remove (or comment) the if,
|
|
|
|
# because it may be needed in a future device.
|
2019-01-23 21:20:55 -06:00
|
|
|
#mtd erase $part_label
|
|
|
|
#get_image "$1" | mtd -n write - $part_label
|
|
|
|
echo "writing \"$1\" UBI image to \"$part_label\" (UBI)..."
|
2019-06-15 14:40:56 -07:00
|
|
|
get_image "$1" | mtd write - "$part_label"
|
2019-01-23 21:20:55 -06:00
|
|
|
else
|
|
|
|
echo "writing \"$1\" image to \"$part_label\""
|
2019-06-15 14:40:56 -07:00
|
|
|
get_image "$1" | mtd write - "$part_label"
|
2019-01-23 21:20:55 -06:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
}
|