[PATCH v3 04/11] base-files: upgrade: add get_image_dd()
Philip Prindeville
philipp at redfish-solutions.com
Tue Nov 10 12:15:37 EST 2020
Reviewed-By: Philip Prindeville <philipp at redfish-solutions.com>
> On Nov 10, 2020, at 6:45 AM, Yousong Zhou <yszhou4tech at gmail.com> wrote:
>
> This is mainly to handle stderr message "Broken pipe", "F+P records
> in/out" by common pattern "xcat | dd .."
>
> Ref: https://bugs.openwrt.org/index.php?do=details&task_id=3140
> Reported-by: Philip Prindeville <philipp at redfish-solutions.com>
> Signed-off-by: Yousong Zhou <yszhou4tech at gmail.com>
> ---
> package/base-files/files/lib/upgrade/common.sh | 11 +++++++++++
> 1 file changed, 11 insertions(+)
>
> diff --git a/package/base-files/files/lib/upgrade/common.sh b/package/base-files/files/lib/upgrade/common.sh
> index 5eb7b23a83..a5c27dc2fb 100644
> --- a/package/base-files/files/lib/upgrade/common.sh
> +++ b/package/base-files/files/lib/upgrade/common.sh
> @@ -106,6 +106,17 @@ get_image() { # <source> [ <command> ]
> $cmd <"$from"
> }
>
> +get_image_dd() {
> + local from="$1"; shift
> +
> + (
> + exec 3>&2
> + ( exec 3>&2; get_image "$from" 2>&1 1>&3 | grep -v -F ' Broken pipe' ) 2>&1 1>&3 \
> + | ( exec 3>&2; dd "$@" 2>&1 1>&3 | grep -v -E ' records (in|out)') 2>&1 1>&3
> + exec 3>&-
> + )
> +}
> +
> get_magic_word() {
> (get_image "$@" | dd bs=2 count=1 | hexdump -v -n 2 -e '1/1 "%02x"') 2>/dev/null
> }
More information about the openwrt-devel
mailing list