From 716ca530e1c4515d8683c9d5be3d56b301758b66 Mon Sep 17 00:00:00 2001 From: James <> Date: Wed, 4 Nov 2015 11:49:21 +0000 Subject: trunk-47381 --- scripts/ubinize-image.sh | 114 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 114 insertions(+) create mode 100755 scripts/ubinize-image.sh (limited to 'scripts/ubinize-image.sh') diff --git a/scripts/ubinize-image.sh b/scripts/ubinize-image.sh new file mode 100755 index 0000000..b87cbb4 --- /dev/null +++ b/scripts/ubinize-image.sh @@ -0,0 +1,114 @@ +#!/bin/sh + +ubootenv="" +ubinize_param="" +kernel="" +rootfs="" +outfile="" +err="" + +get_magic_word() { + dd if=$1 bs=2 count=1 2>/dev/null | hexdump -v -n 2 -e '1/1 "%02x"' +} + +is_ubifs() { + if [ "$( get_magic_word $1 )" = "3118" ]; then + echo "1" + fi +} + +ubivol() { + volid=$1 + name=$2 + image=$3 + autoresize=$4 + echo "[$name]" + echo "mode=ubi" + echo "vol_id=$volid" + echo "vol_type=dynamic" + echo "vol_name=$name" + if [ "$image" ]; then + echo "image=$image" + else + echo "vol_size=1MiB" + fi + if [ "$autoresize" ]; then + echo "vol_flags=autoresize" + fi +} + +ubilayout() { + local vol_id=0 + local root_is_ubifs="$( is_ubifs "$2" )" + if [ "$1" = "ubootenv" ]; then + ubivol $vol_id ubootenv + vol_id=$(( $vol_id + 1 )) + ubivol $vol_id ubootenv2 + vol_id=$(( $vol_id + 1 )) + fi + if [ "$3" ]; then + ubivol $vol_id kernel "$3" + vol_id=$(( $vol_id + 1 )) + fi + ubivol $vol_id rootfs "$2" $root_is_ubifs + vol_id=$(( $vol_id + 1 )) + [ "$root_is_ubifs" ] || ubivol $vol_id rootfs_data "" 1 +} + +while [ "$1" ]; do + case "$1" in + "--uboot-env") + ubootenv="ubootenv" + shift + continue + ;; + "--kernel") + kernel="$2" + shift + shift + continue + ;; + "-"*) + ubinize_param="$@" + break + ;; + *) + if [ ! "$rootfs" ]; then + rootfs=$1 + shift + continue + fi + if [ ! "$outfile" ]; then + outfile=$1 + shift + continue + fi + ;; + esac +done + +if [ ! -r "$rootfs" -o ! -r "$kernel" -a ! "$outfile" ]; then + echo "syntax: $0 [--uboot-env] [--kernel kernelimage] rootfs out [ubinize opts]" + exit 1 +fi + +ubinize="$( which ubinize )" +if [ ! -x "$ubinize" ]; then + echo "ubinize tool not found or not usable" + exit 1 +fi + +ubinizecfg="$( mktemp 2> /dev/null )" +if [ -z "$ubinizecfg" ]; then + # try OSX signature + ubinizecfg="$( mktemp -t 'ubitmp' )" +fi +ubilayout "$ubootenv" "$rootfs" "$kernel" > "$ubinizecfg" + +cat "$ubinizecfg" +ubinize -o "$outfile" $ubinize_param "$ubinizecfg" +err="$?" +[ ! -e "$outfile" ] && err=2 +rm "$ubinizecfg" + +exit $err -- cgit v1.2.3