scripts: ubinize-image.sh: fix on POSIX shell, allow custom images
authorDaniel Golle <daniel@makrotopia.org>
Fri, 16 Feb 2024 05:32:51 +0000 (05:32 +0000)
committerDaniel Golle <daniel@makrotopia.org>
Fri, 16 Feb 2024 05:32:51 +0000 (05:32 +0000)
Make sure ubinize-image.sh also works with more simple POSIX Shell and
allow creating complete custom images to be used as ARTIFACT/foo.img
and thereby allow including uImage.FIT, TF-A FIP and what ever else
is required on a specific board.

Fixes: 6c17d71973 ("scripts: ubinize-image.sh: support static volumes, make size optional")
Signed-off-by: Daniel Golle <daniel@makrotopia.org>
include/image-commands.mk
scripts/ubinize-image.sh

index 9ce97b17cfa4ccd5adb979e41162733dc9949433..8caeb1871c2cb268f47046aea841f6e6c14192fd 100644 (file)
@@ -138,11 +138,9 @@ UBI_NAND_SIZE_LIMIT = $(IMAGE_SIZE) - ($(NAND_SIZE)*20/1024 + 4*$(BLOCKSIZE))
 define Build/append-ubi
        sh $(TOPDIR)/scripts/ubinize-image.sh \
                $(if $(UBOOTENV_IN_UBI),--uboot-env) \
-               $(foreach part,$(UBINIZE_PARTS),--part $(part)) \
-               $(if $(findstring fit,$(1)), \
-               $(if $(KERNEL_IN_UBI),--part fit=$(IMAGE_KERNEL)), \
                $(if $(KERNEL_IN_UBI),--kernel $(IMAGE_KERNEL)) \
-               --rootfs $(IMAGE_ROOTFS)) \
+               $(foreach part,$(UBINIZE_PARTS),--part $(part)) \
+               --rootfs $(IMAGE_ROOTFS) \
                $@.tmp \
                -p $(BLOCKSIZE:%k=%KiB) -m $(PAGESIZE) \
                $(if $(SUBPAGESIZE),-s $(SUBPAGESIZE)) \
@@ -154,6 +152,18 @@ define Build/append-ubi
                $(call Build/check-size,$(UBI_NAND_SIZE_LIMIT)))
 endef
 
+define Build/ubinize-image
+       sh $(TOPDIR)/scripts/ubinize-image.sh \
+               $(if $(UBOOTENV_IN_UBI),--uboot-env) \
+               $(foreach part,$(UBINIZE_PARTS),--part $(part)) \
+               --part $(word 1,$(1))="$(BIN_DIR)/$(DEVICE_IMG_PREFIX)-$(word 2,$(1))" \
+               $@ \
+               -p $(BLOCKSIZE:%k=%KiB) -m $(PAGESIZE) \
+               $(if $(SUBPAGESIZE),-s $(SUBPAGESIZE)) \
+               $(if $(VID_HDR_OFFSET),-O $(VID_HDR_OFFSET)) \
+               $(UBINIZE_OPTS)
+endef
+
 define Build/ubinize-kernel
        cp $@ $@.tmp
        sh $(TOPDIR)/scripts/ubinize-image.sh \
index cd516e8afc5c2d3d6d839914d9579faaefc7dd85..06a6310980177a7104b067de5cb9becd06aa432b 100755 (executable)
@@ -12,10 +12,10 @@ err=""
 ubinize_seq=""
 
 ubivol() {
-       local volid=$1
-       local name=$2
-       local image=$3
-       local autoresize=$4
+       local volid="$1"
+       local name="$2"
+       local image="$3"
+       local autoresize="$4"
        local size="$5"
        local voltype="${6:-dynamic}"
        echo "[$name]"
@@ -36,16 +36,17 @@ ubivol() {
 
 ubilayout() {
        local vol_id=0
-       local rootsize=
-       local autoresize=
-       local rootfs_type="$( get_fs_type "$2" )"
+       local rootsize
+       local autoresize
+       local rootfs_type
        local voltype
 
+       rootfs_type="$( get_fs_type "$2" )"
        if [ "$1" = "ubootenv" ]; then
                ubivol $vol_id ubootenv
-               vol_id=$(( $vol_id + 1 ))
+               vol_id=$(( vol_id + 1 ))
                ubivol $vol_id ubootenv2
-               vol_id=$(( $vol_id + 1 ))
+               vol_id=$(( vol_id + 1 ))
        fi
        for part in $parts; do
                name="${part%%=*}"
@@ -55,9 +56,9 @@ ubilayout() {
                [ "$prev" = "$part" ] && part=
 
                image="${part%%=*}"
-               if [ "${image:0:1}" = ":" ]; then
+               if [ "${image#:}" != "$image" ]; then
                        voltype=static
-                       image="${image:1}"
+                       image="${image#:}"
                fi
                prev="$part"
                part="${part#*=}"
@@ -71,11 +72,11 @@ ubilayout() {
                fi
 
                ubivol $vol_id "$name" "$image" "" "${size}" "$voltype"
-               vol_id=$(( $vol_id + 1 ))
+               vol_id=$(( vol_id + 1 ))
        done
        if [ "$3" ]; then
                ubivol $vol_id kernel "$3"
-               vol_id=$(( $vol_id + 1 ))
+               vol_id=$(( vol_id + 1 ))
        fi
 
        if [ "$2" ]; then
@@ -91,7 +92,7 @@ ubilayout() {
                esac
                ubivol $vol_id rootfs "$2" "$autoresize" "$rootsize" dynamic
 
-               vol_id=$(( $vol_id + 1 ))
+               vol_id=$(( vol_id + 1 ))
                [ "$rootfs_type" = "ubifs" ] || ubivol $vol_id rootfs_data "" 1 dymamic
        fi
 }
@@ -128,7 +129,7 @@ while [ "$1" ]; do
                continue
                ;;
        "-"*)
-               ubinize_param="$@"
+               ubinize_param="$*"
                break
                ;;
        *)
@@ -141,7 +142,7 @@ while [ "$1" ]; do
        esac
 done
 
-if [ ! -r "$rootfs" -a ! -r "$kernel" -a ! "$outfile" ]; then
+if [ ! -r "$rootfs" ] && [ ! -r "$kernel" ] && [ ! "$parts" ] && [ ! "$outfile" ]; then
        echo "syntax: $0 [--uboot-env] [--part <name>=<file>] [--kernel kernelimage] [--rootfs rootfsimage] out [ubinize opts]"
        exit 1
 fi