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>
This commit is contained in:
		| @@ -2,59 +2,24 @@ REQUIRE_IMAGE_METADATA=1 | ||||
| RAMFS_COPY_BIN='fw_printenv fw_setenv blockdev' | ||||
| 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() { | ||||
| 	local board=$(board_name) | ||||
| 	local file_type=$(identify $1) | ||||
|  | ||||
| 	case "$board" in | ||||
| 	bananapi,bpi-r64) | ||||
| 		local rootdev=$(get_rootdev) | ||||
| 		local fitpart=$(get_partition $rootdev production) | ||||
| 		[ "$fitpart" ] || exit 1 | ||||
| 		export_bootdevice | ||||
| 		export_partdevice rootdev 0 | ||||
| 		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 | ||||
| 		blockdev --rereadpt /dev/$rootdev | ||||
| 		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) | ||||
| 		local magic="$(get_magic_long "$1")" | ||||
| @@ -113,11 +78,9 @@ platform_check_image() { | ||||
|  | ||||
| platform_copy_config_mmc() { | ||||
| 	[ -e "$UPGRADE_BACKUP" ] || return | ||||
| 	local rootdev=$(cat /tmp/sysupgrade.rootdev) | ||||
| 	blockdev --rereadpt /dev/$rootdev | ||||
| 	local datadev=$(get_partition $rootdev rootfs_data) | ||||
| 	[ "$datadev" ] || echo "no rootfs_data partition, cannot keep configuration." >&2 | ||||
| 	dd if="$UPGRADE_BACKUP" of=/dev/$datadev | ||||
| 	local datapart=$(cat /tmp/sysupgrade.datapart) | ||||
| 	[ "$datapart" ] || echo "no rootfs_data partition, cannot keep configuration." >&2 | ||||
| 	dd if="$UPGRADE_BACKUP" of=/dev/$datapart | ||||
| 	sync | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Daniel Golle
					Daniel Golle