mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-21 03:55:06 +00:00
mediatek: mt7622: improve sysupgrade on MMC
Use generic functions to acquire rootdev. Make sure to wipe rootfs_data in case of '-n'. Signed-off-by: Daniel Golle <daniel@makrotopia.org> Signed-off-by: maurerr <mariusd84@gmail.com>
This commit is contained in:
parent
63e31a38ac
commit
5aa8dc0a7b
@ -2,59 +2,24 @@ REQUIRE_IMAGE_METADATA=1
|
|||||||
RAMFS_COPY_BIN='fw_printenv fw_setenv blockdev'
|
RAMFS_COPY_BIN='fw_printenv fw_setenv blockdev'
|
||||||
RAMFS_COPY_DATA='/etc/fw_env.config /var/lock/fw_printenv.lock'
|
RAMFS_COPY_DATA='/etc/fw_env.config /var/lock/fw_printenv.lock'
|
||||||
|
|
||||||
get_cmdline_var() {
|
|
||||||
local var=$1
|
|
||||||
local cmdlinevar tmp
|
|
||||||
local cmdline="$(cat /proc/cmdline)"
|
|
||||||
|
|
||||||
for cmdlinevar in $cmdline; do
|
|
||||||
tmp=${cmdlinevar##${var}}
|
|
||||||
[ "=" = "${tmp:0:1}" ] && echo ${tmp:1}
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
get_rootdev() {
|
|
||||||
local rootvol rootdev
|
|
||||||
rootvol=$(get_cmdline_var root)
|
|
||||||
rootvol=$(basename $rootvol)
|
|
||||||
[ -e /sys/class/block/$rootvol ] || {
|
|
||||||
rootvol=${rootvol%%[0-9]}
|
|
||||||
[ -e /sys/class/block/$rootvol ] && echo $rootvol
|
|
||||||
rootvol=${rootvol%%p}
|
|
||||||
[ -e /sys/class/block/$rootvol ] && echo $rootvol
|
|
||||||
return
|
|
||||||
}
|
|
||||||
[ -e /sys/class/block/$rootvol/partition ] || {
|
|
||||||
echo $rootvol
|
|
||||||
return
|
|
||||||
}
|
|
||||||
rootdev=$(busybox readlink -f /sys/class/block/$rootvol)
|
|
||||||
rootdev=$(basename ${rootdev%%/${rootvol}})
|
|
||||||
[ -e /sys/class/block/$rootdev ] && echo $rootdev
|
|
||||||
}
|
|
||||||
|
|
||||||
get_partition() {
|
|
||||||
for partname in /sys/class/block/$1/*/name; do
|
|
||||||
[ "$(cat ${partname})" = "$2" ] && {
|
|
||||||
basename ${partname%%/name}
|
|
||||||
break
|
|
||||||
}
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
platform_do_upgrade() {
|
platform_do_upgrade() {
|
||||||
local board=$(board_name)
|
local board=$(board_name)
|
||||||
local file_type=$(identify $1)
|
local file_type=$(identify $1)
|
||||||
|
|
||||||
case "$board" in
|
case "$board" in
|
||||||
bananapi,bpi-r64)
|
bananapi,bpi-r64)
|
||||||
local rootdev=$(get_rootdev)
|
export_bootdevice
|
||||||
local fitpart=$(get_partition $rootdev production)
|
export_partdevice rootdev 0
|
||||||
[ "$fitpart" ] || exit 1
|
local fitpart=$(get_partition_by_name $rootdev "production")
|
||||||
|
[ "$fitpart" ] || return 1
|
||||||
dd if=/dev/zero of=/dev/$fitpart bs=4096 count=1 2>/dev/null
|
dd if=/dev/zero of=/dev/$fitpart bs=4096 count=1 2>/dev/null
|
||||||
blockdev --rereadpt /dev/$rootdev
|
blockdev --rereadpt /dev/$rootdev
|
||||||
get_image "$1" | dd of=/dev/$fitpart
|
get_image "$1" | dd of=/dev/$fitpart
|
||||||
echo $rootdev > /tmp/sysupgrade.rootdev
|
blockdev --rereadpt /dev/$rootdev
|
||||||
|
local datapart=$(get_partition_by_name $rootdev "rootfs_data")
|
||||||
|
[ "$datapart" ] || return 0
|
||||||
|
dd if=/dev/zero of=/dev/$datapart bs=4096 count=1 2>/dev/null
|
||||||
|
echo $datapart > /tmp/sysupgrade.datapart
|
||||||
;;
|
;;
|
||||||
buffalo,wsr-2533dhp2)
|
buffalo,wsr-2533dhp2)
|
||||||
local magic="$(get_magic_long "$1")"
|
local magic="$(get_magic_long "$1")"
|
||||||
@ -113,11 +78,9 @@ platform_check_image() {
|
|||||||
|
|
||||||
platform_copy_config_mmc() {
|
platform_copy_config_mmc() {
|
||||||
[ -e "$UPGRADE_BACKUP" ] || return
|
[ -e "$UPGRADE_BACKUP" ] || return
|
||||||
local rootdev=$(cat /tmp/sysupgrade.rootdev)
|
local datapart=$(cat /tmp/sysupgrade.datapart)
|
||||||
blockdev --rereadpt /dev/$rootdev
|
[ "$datapart" ] || echo "no rootfs_data partition, cannot keep configuration." >&2
|
||||||
local datadev=$(get_partition $rootdev rootfs_data)
|
dd if="$UPGRADE_BACKUP" of=/dev/$datapart
|
||||||
[ "$datadev" ] || echo "no rootfs_data partition, cannot keep configuration." >&2
|
|
||||||
dd if="$UPGRADE_BACKUP" of=/dev/$datadev
|
|
||||||
sync
|
sync
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user