|
|
@ -23,12 +23,31 @@ PREFIX="livecd.$PROJECT${SUBARCH:+-$SUBARCH}"
|
|
|
|
if [ "${IMAGEFORMAT:-}" = "ubuntu-image" ]; then
|
|
|
|
if [ "${IMAGEFORMAT:-}" = "ubuntu-image" ]; then
|
|
|
|
# Use ubuntu-image instead of live-build
|
|
|
|
# Use ubuntu-image instead of live-build
|
|
|
|
|
|
|
|
|
|
|
|
CHANNEL="${CHANNEL:-edge}"
|
|
|
|
if [ "$PROJECT" = "ubuntu-core"]; then
|
|
|
|
env SNAPPY_STORE_NO_CDN=1 \
|
|
|
|
CHANNEL="${CHANNEL:-edge}"
|
|
|
|
ubuntu-image -c "$CHANNEL" $UBUNTU_IMAGE_ARGS \
|
|
|
|
env SNAPPY_STORE_NO_CDN=1 \
|
|
|
|
-o "$PREFIX".img "$PREFIX".model-assertion
|
|
|
|
ubuntu-image snap -c "$CHANNEL" $UBUNTU_IMAGE_ARGS \
|
|
|
|
xz -0 -T4 "$PREFIX".img
|
|
|
|
-O output "$PREFIX".model-assertion
|
|
|
|
mv seed.manifest "$PREFIX".manifest
|
|
|
|
# XXX: currently we only have one image generated, but really
|
|
|
|
|
|
|
|
# we should be supporting more than one for models that
|
|
|
|
|
|
|
|
# define those.
|
|
|
|
|
|
|
|
mv output/*.img "$PREFIX".img
|
|
|
|
|
|
|
|
xz -0 -T4 "$PREFIX".img
|
|
|
|
|
|
|
|
mv output/seed.manifest "$PREFIX".manifest
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
# First we need to build the gadget tree
|
|
|
|
|
|
|
|
make -C "config/$PREFIX-gadget" ARCH=$ARCH SERIES=$SUITE
|
|
|
|
|
|
|
|
ubuntu-image classic $UBUNTU_IMAGE_ARGS \
|
|
|
|
|
|
|
|
-s $SUITE -p $PROJECT -a $ARCH --subarch $SUBARCH \
|
|
|
|
|
|
|
|
-O output config/$PREFIX-gadget/install
|
|
|
|
|
|
|
|
# XXX: currently we only have one image generated, but really
|
|
|
|
|
|
|
|
# we should be supporting more than one for models that
|
|
|
|
|
|
|
|
# define those.
|
|
|
|
|
|
|
|
mv output/*.img "$PREFIX".img
|
|
|
|
|
|
|
|
xz -0 -T4 "$PREFIX".img
|
|
|
|
|
|
|
|
mv output/filesystem.manifest "$PREFIX".manifest
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
exit 0
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
@ -550,7 +569,6 @@ if [ "$PROJECT" = "ubuntu-touch" ] || [ "$PROJECT" = "ubuntu-touch-custom" ]; th
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
# '--initramfs none' produces different manifest names.
|
|
|
|
# '--initramfs none' produces different manifest names.
|
|
|
|
# NB! we want stdout appended to the manifest, yet stderr to be printed on stdout
|
|
|
|
|
|
|
|
if [ -e "binary/$INITFS/filesystem.packages" ]; then
|
|
|
|
if [ -e "binary/$INITFS/filesystem.packages" ]; then
|
|
|
|
./config/snap-seed-parse "chroot/" "binary/${INITFS}/filesystem.packages"
|
|
|
|
./config/snap-seed-parse "chroot/" "binary/${INITFS}/filesystem.packages"
|
|
|
|
ln "binary/$INITFS/filesystem.packages" "$PREFIX.manifest"
|
|
|
|
ln "binary/$INITFS/filesystem.packages" "$PREFIX.manifest"
|
|
|
@ -864,36 +882,52 @@ if [ "$NUMFLAVOURS" = 1 ] && [ "$LB_LINUX_FLAVOURS" != "none" ]; then
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
if [ "$SUBARCH" = "ac100" ]; then
|
|
|
|
case $SUBARCH in
|
|
|
|
# create the md5sum and size files for which we are actually doing all this
|
|
|
|
ac100)
|
|
|
|
md5sum $PREFIX.rootfs.tar.gz >chroot/installer.md5
|
|
|
|
# create the md5sum and size files for which we are actually doing all this
|
|
|
|
wc -c $PREFIX.rootfs.tar.gz >chroot/installer.size
|
|
|
|
md5sum $PREFIX.rootfs.tar.gz >chroot/installer.md5
|
|
|
|
|
|
|
|
wc -c $PREFIX.rootfs.tar.gz >chroot/installer.size
|
|
|
|
|
|
|
|
|
|
|
|
INFO_DESC="$(lsb_release -d -s)"
|
|
|
|
INFO_DESC="$(lsb_release -d -s)"
|
|
|
|
INFO_STAMP=$(date +20%y%m%d-%H:%M)
|
|
|
|
INFO_STAMP=$(date +20%y%m%d-%H:%M)
|
|
|
|
|
|
|
|
|
|
|
|
echo "$INFO_DESC - $ARCH ($INFO_STAMP)" >chroot/media-info
|
|
|
|
echo "$INFO_DESC - $ARCH ($INFO_STAMP)" >chroot/media-info
|
|
|
|
|
|
|
|
|
|
|
|
# make sure update-initramfs feels cosy and warm in the environment
|
|
|
|
# make sure update-initramfs feels cosy and warm in the environment
|
|
|
|
lb chroot_proc install "$@"
|
|
|
|
lb chroot_proc install "$@"
|
|
|
|
lb chroot_sysfs install "$@"
|
|
|
|
lb chroot_sysfs install "$@"
|
|
|
|
lb chroot_devpts install "$@"
|
|
|
|
lb chroot_devpts install "$@"
|
|
|
|
|
|
|
|
|
|
|
|
# re-create initrd to contain the installer.md5 file
|
|
|
|
# re-create initrd to contain the installer.md5 file
|
|
|
|
Chroot chroot "env FLASH_KERNEL_SKIP=1 update-initramfs -k all -t -u -v"
|
|
|
|
Chroot chroot "env FLASH_KERNEL_SKIP=1 update-initramfs -k all -t -u -v"
|
|
|
|
|
|
|
|
|
|
|
|
# create boot.img
|
|
|
|
# create boot.img
|
|
|
|
Chroot chroot "abootimg --create /boot/installer-${KVERS}.img -f /boot/bootimg.cfg-$SUBARCH -r /boot/initrd.img-${KVERS} -k /boot/vmlinuz-${KVERS}"
|
|
|
|
Chroot chroot "abootimg --create /boot/installer-${KVERS}.img -f /boot/bootimg.cfg-$SUBARCH -r /boot/initrd.img-${KVERS} -k /boot/vmlinuz-${KVERS}"
|
|
|
|
|
|
|
|
|
|
|
|
# clean up
|
|
|
|
# clean up
|
|
|
|
lb chroot_devpts remove "$@"
|
|
|
|
lb chroot_devpts remove "$@"
|
|
|
|
lb chroot_sysfs remove "$@"
|
|
|
|
lb chroot_sysfs remove "$@"
|
|
|
|
lb chroot_proc remove "$@"
|
|
|
|
lb chroot_proc remove "$@"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cp "chroot/boot/installer-${KVERS}.img" "$PREFIX.bootimg-$FLAVOUR"
|
|
|
|
|
|
|
|
ln -sf "$PREFIX.bootimg-$FLAVOUR" "$PREFIX.bootimg"
|
|
|
|
|
|
|
|
;;
|
|
|
|
|
|
|
|
|
|
|
|
cp "chroot/boot/installer-${KVERS}.img" "$PREFIX.bootimg-$FLAVOUR"
|
|
|
|
raspi2|raspi3)
|
|
|
|
ln -sf "$PREFIX.bootimg-$FLAVOUR" "$PREFIX.bootimg"
|
|
|
|
# copy the kernel and initrd to a predictable directory for
|
|
|
|
|
|
|
|
# ubuntu-image consumption. In some cases, like in pi2/3
|
|
|
|
|
|
|
|
# u-boot, the bootloader needs to contain the kernel and initrd,
|
|
|
|
|
|
|
|
# so during rootfs build we copy it over to a directory that
|
|
|
|
|
|
|
|
# ubuntu-image looks for and shoves into the bootloader
|
|
|
|
|
|
|
|
# partition.
|
|
|
|
|
|
|
|
UBOOT_BOOT="image/boot/uboot"
|
|
|
|
|
|
|
|
|
|
|
|
fi
|
|
|
|
mkdir -p $UBOOT_BOOT
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cp $PREFIX.initrd $UBOOT_BOOT/initrd.img || true
|
|
|
|
|
|
|
|
cp $PREFIX.kernel $UBOOT_BOOT/vmlinuz || true
|
|
|
|
|
|
|
|
;;
|
|
|
|
|
|
|
|
esac
|
|
|
|
|
|
|
|
|
|
|
|
if [ "$PROJECT" = "ubuntu-touch" ] || [ "$PROJECT" = "ubuntu-touch-custom" ]; then
|
|
|
|
if [ "$PROJECT" = "ubuntu-touch" ] || [ "$PROJECT" = "ubuntu-touch-custom" ]; then
|
|
|
|
sourceslist="chroot/etc/apt/sources.list"
|
|
|
|
sourceslist="chroot/etc/apt/sources.list"
|
|
|
|