From 84da578380f39a5b394ac778e34d3f61182f406c Mon Sep 17 00:00:00 2001 From: "Gary.Wzl" Date: Mon, 28 Aug 2017 11:24:51 +0800 Subject: [PATCH 1/3] Add IMAGETYPE to support classic image creation by ubuntu-image. --- live-build/auto/build | 14 ++++++--- live-build/auto/config | 66 +++++++++++++++++++++++++----------------- 2 files changed, 50 insertions(+), 30 deletions(-) diff --git a/live-build/auto/build b/live-build/auto/build index 5c7b88ce..978d2fe0 100755 --- a/live-build/auto/build +++ b/live-build/auto/build @@ -16,11 +16,17 @@ if [ -z "${PROJECT:-}" ]; then fi if [ "${IMAGEFORMAT:-}" = "ubuntu-image" ]; then - # Use ubuntu-image instead of live-build - env SNAPPY_STORE_NO_CDN=1 \ - ubuntu-image -c edge \ + if [ "${IMAGETYPE:-}" = "classic" ]; then + # Use ubuntu-image instead of live-build + OPTS="${PROJECT:+--project=$PROJECT} ${SUITE:+--suite=$SUITE} ${ARCH:+--arch=$ARCH} ${SUBPROJECT:+--subproject=$SUBPROJECT} ${SUBARCH:+--subarch=$SUBARCH} ${PROPOSED:+--with-proposed=$PROPOSED} ${IMAGEFORMAT:+--image-format=$IMAGEFORMAT} ${EXTRA_PPAS:+--extra-ppas=$EXTRA_PPAS}" + ubuntu-image classic $OPTS gadget_tree + else + # Use ubuntu-image instead of live-build + env SNAPPY_STORE_NO_CDN=1 \ + ubuntu-image snap -c edge \ -o livecd."$PROJECT".img livecd."$PROJECT".model-assertion - xz -0 -T4 livecd."$PROJECT".img + xz -0 -T4 livecd."$PROJECT".img + fi exit 0 fi diff --git a/live-build/auto/config b/live-build/auto/config index 3f504463..8d350ad3 100755 --- a/live-build/auto/config +++ b/live-build/auto/config @@ -153,34 +153,48 @@ case $IMAGEFORMAT in ;; ubuntu-image) - case "$ARCH+${SUBARCH:-}" in - amd64+*) - MODEL=pc-amd64 ;; - i386+*) - MODEL=pc-i386 ;; - arm64+snapdragon) - MODEL=dragonboard ;; - armhf+raspi2) - MODEL=pi2 ;; - armhf+raspi3) - MODEL=pi3 ;; - armhf+cm3) - MODEL=cm3 ;; - *) - echo "Model $ARCH+${SUBARCH:-} unknown to livecd-rootfs" >&2 - exit 1 + case $IMAGETYPE in + classic) + echo "IMAGEFORMAT=$IMAGEFORMAT" >> config/common + # TODO livecd-rootfs needs to take a branch URI for the gadget as input, + # stage it, and pass it to ubuntu-image, where do we get it? + + # Fake finished configuration for lb build + mkdir -p .build + touch .build/config + exit 0 + ;; + *) # backport compatibility for core image creation. + case "$ARCH+${SUBARCH:-}" in + amd64+*) + MODEL=pc-amd64 ;; + i386+*) + MODEL=pc-i386 ;; + arm64+snapdragon) + MODEL=dragonboard ;; + armhf+raspi2) + MODEL=pi2 ;; + armhf+raspi3) + MODEL=pi3 ;; + armhf+cm3) + MODEL=cm3 ;; + *) + echo "Model $ARCH+${SUBARCH:-} unknown to livecd-rootfs" >&2 + exit 1 + ;; + esac + echo "IMAGEFORMAT=$IMAGEFORMAT" >> config/common + # Store model assertion in top dir to get it picked up later as a build artifact + env SNAPPY_STORE_NO_CDN=1 snap known --remote model series=16 model="$MODEL" brand-id=canonical > livecd."$PROJECT".model-assertion + echo "Configured ubuntu-image for the following model assertion:" + cat livecd."$PROJECT".model-assertion + echo "----------------------------------------------------------" + # Fake finished configuration for lb build + mkdir -p .build + touch .build/config + exit 0 ;; esac - echo "IMAGEFORMAT=$IMAGEFORMAT" >> config/common - # Store model assertion in top dir to get it picked up later as a build artifact - env SNAPPY_STORE_NO_CDN=1 snap known --remote model series=16 model="$MODEL" brand-id=canonical > livecd."$PROJECT".model-assertion - echo "Configured ubuntu-image for the following model assertion:" - cat livecd."$PROJECT".model-assertion - echo "----------------------------------------------------------" - # Fake finished configuration for lb build - mkdir -p .build - touch .build/config - exit 0 ;; *) From eb76178ab5698dd011ae760cc20ed10c949e6200 Mon Sep 17 00:00:00 2001 From: "Gary.Wzl" Date: Mon, 28 Aug 2017 15:14:54 +0800 Subject: [PATCH 2/3] Support to only generate rootfs via variable (GENERATE_ROOTFS_ONLY). --- live-build/auto/build | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/live-build/auto/build b/live-build/auto/build index 978d2fe0..d5b8a87e 100755 --- a/live-build/auto/build +++ b/live-build/auto/build @@ -235,10 +235,16 @@ EOF (cd chroot && find usr/share/doc -maxdepth 1 -type d | xargs du -s | sort -nr) echo END docdirs - lb binary "$@" - touch binary.success + if [ -z "${GENERATE_ROOTFS_ONLY:-}" ]; then + lb binary "$@" + touch binary.success + fi ) 2>&1 | tee binary.log +if [ ! -z "${GENERATE_ROOTFS_ONLY:-}" ] && [ "${GENERATE_ROOTFS_ONLY}" != "false" ]; then + exit 0 +fi + # bash has trouble with the build.sh sourcing arrangement at the top of this # file, so we use this cheap-and-cheerful approach rather than the more # correct 'set -o pipefail'. From 228ed7c87b21cfd6521aa4a83bcd41d6a995d374 Mon Sep 17 00:00:00 2001 From: "Gary.Wzl" Date: Mon, 18 Sep 2017 09:38:20 +0800 Subject: [PATCH 3/3] Remove 'IMAGETYPE' and 'IMAGEFORMAT' bits per the suggestions. --- live-build/auto/build | 14 +++------ live-build/auto/config | 66 +++++++++++++++++------------------------- 2 files changed, 30 insertions(+), 50 deletions(-) diff --git a/live-build/auto/build b/live-build/auto/build index d5b8a87e..156f7789 100755 --- a/live-build/auto/build +++ b/live-build/auto/build @@ -16,17 +16,11 @@ if [ -z "${PROJECT:-}" ]; then fi if [ "${IMAGEFORMAT:-}" = "ubuntu-image" ]; then - if [ "${IMAGETYPE:-}" = "classic" ]; then - # Use ubuntu-image instead of live-build - OPTS="${PROJECT:+--project=$PROJECT} ${SUITE:+--suite=$SUITE} ${ARCH:+--arch=$ARCH} ${SUBPROJECT:+--subproject=$SUBPROJECT} ${SUBARCH:+--subarch=$SUBARCH} ${PROPOSED:+--with-proposed=$PROPOSED} ${IMAGEFORMAT:+--image-format=$IMAGEFORMAT} ${EXTRA_PPAS:+--extra-ppas=$EXTRA_PPAS}" - ubuntu-image classic $OPTS gadget_tree - else - # Use ubuntu-image instead of live-build - env SNAPPY_STORE_NO_CDN=1 \ - ubuntu-image snap -c edge \ + # Use ubuntu-image instead of live-build + env SNAPPY_STORE_NO_CDN=1 \ + ubuntu-image -c edge \ -o livecd."$PROJECT".img livecd."$PROJECT".model-assertion - xz -0 -T4 livecd."$PROJECT".img - fi + xz -0 -T4 livecd."$PROJECT".img exit 0 fi diff --git a/live-build/auto/config b/live-build/auto/config index 8d350ad3..3f504463 100755 --- a/live-build/auto/config +++ b/live-build/auto/config @@ -153,48 +153,34 @@ case $IMAGEFORMAT in ;; ubuntu-image) - case $IMAGETYPE in - classic) - echo "IMAGEFORMAT=$IMAGEFORMAT" >> config/common - # TODO livecd-rootfs needs to take a branch URI for the gadget as input, - # stage it, and pass it to ubuntu-image, where do we get it? - - # Fake finished configuration for lb build - mkdir -p .build - touch .build/config - exit 0 - ;; - *) # backport compatibility for core image creation. - case "$ARCH+${SUBARCH:-}" in - amd64+*) - MODEL=pc-amd64 ;; - i386+*) - MODEL=pc-i386 ;; - arm64+snapdragon) - MODEL=dragonboard ;; - armhf+raspi2) - MODEL=pi2 ;; - armhf+raspi3) - MODEL=pi3 ;; - armhf+cm3) - MODEL=cm3 ;; - *) - echo "Model $ARCH+${SUBARCH:-} unknown to livecd-rootfs" >&2 - exit 1 - ;; - esac - echo "IMAGEFORMAT=$IMAGEFORMAT" >> config/common - # Store model assertion in top dir to get it picked up later as a build artifact - env SNAPPY_STORE_NO_CDN=1 snap known --remote model series=16 model="$MODEL" brand-id=canonical > livecd."$PROJECT".model-assertion - echo "Configured ubuntu-image for the following model assertion:" - cat livecd."$PROJECT".model-assertion - echo "----------------------------------------------------------" - # Fake finished configuration for lb build - mkdir -p .build - touch .build/config - exit 0 + case "$ARCH+${SUBARCH:-}" in + amd64+*) + MODEL=pc-amd64 ;; + i386+*) + MODEL=pc-i386 ;; + arm64+snapdragon) + MODEL=dragonboard ;; + armhf+raspi2) + MODEL=pi2 ;; + armhf+raspi3) + MODEL=pi3 ;; + armhf+cm3) + MODEL=cm3 ;; + *) + echo "Model $ARCH+${SUBARCH:-} unknown to livecd-rootfs" >&2 + exit 1 ;; esac + echo "IMAGEFORMAT=$IMAGEFORMAT" >> config/common + # Store model assertion in top dir to get it picked up later as a build artifact + env SNAPPY_STORE_NO_CDN=1 snap known --remote model series=16 model="$MODEL" brand-id=canonical > livecd."$PROJECT".model-assertion + echo "Configured ubuntu-image for the following model assertion:" + cat livecd."$PROJECT".model-assertion + echo "----------------------------------------------------------" + # Fake finished configuration for lb build + mkdir -p .build + touch .build/config + exit 0 ;; *)