mirror of
				https://git.launchpad.net/livecd-rootfs
				synced 2025-10-26 06:24:06 +00:00 
			
		
		
		
	Merge lp:~rbalint/livecd-rootfs/minimize-unminimize-xenial
This commit is contained in:
		
						commit
						aee9079732
					
				
							
								
								
									
										27
									
								
								debian/changelog
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										27
									
								
								debian/changelog
									
									
									
									
										vendored
									
									
								
							| @ -12,11 +12,36 @@ livecd-rootfs (2.408.19) UNRELEASED; urgency=medium | |||||||
|     downstream. |     downstream. | ||||||
|   * Also nuke the sleep / udevadm settle calls in the process, which should |   * Also nuke the sleep / udevadm settle calls in the process, which should | ||||||
|     never be required and slow down the builds. |     never be required and slow down the builds. | ||||||
|  |   * Begin adding support for a project-independent 'minimized' subproject, | ||||||
|  |     which (ironically) omits ubuntu-minimal in favor of using only the minbase | ||||||
|  |     package set. | ||||||
|  |   * Export the subproject into config/chroot and config/binary, so that this | ||||||
|  |     information is available to per-project hooks that need to be | ||||||
|  |     subproject-aware (e.g., to skip steps when SUBPROJECT=minimized) | ||||||
|  |   * Make the 999-cpc-fixes.chroot subproject-aware, so we don't try to | ||||||
|  |     locale-gen | ||||||
|  |   * In a cloud environment, we can rely on the kernel being able to boot the | ||||||
|  |     root filesystem directly, without an initramfs; enable this when building | ||||||
|  |     minimized. | ||||||
|  |   * If we're using SUBPROJECT=minimized, and tzdata is not installed, remove | ||||||
|  |     files that have been left behind.  This is a workaround for a bug that | ||||||
|  |     should be fixed in tzdata. | ||||||
|  |   * Fix a reference to an undefined variable in a script that's set -u. | ||||||
|  |   * Use /bin/sh, not /bin/bash, for autopkgtest. | ||||||
| 
 | 
 | ||||||
|   [ Balint Reczey ] |   [ Balint Reczey ] | ||||||
|   * Mount using --make-rslave to ensure safe unmounts for rbind mounts |   * Mount using --make-rslave to ensure safe unmounts for rbind mounts | ||||||
|  |   * Drop man pages and most of the documentation from minimized images | ||||||
|  |     /usr/share/doc/*/copyright and changelog.Debian.gz files are still kept | ||||||
|  |   * Add unminimize script for reverting minimization on running system | ||||||
|  |   * Install ubuntu-minimal while unminimizing the system | ||||||
|  |   * Bump needed live-build version which can build images without initrd | ||||||
|  |   * Mention unminimize script in motd | ||||||
|  |   * Warn users that unminimize may fail reinstalling packages | ||||||
|  |   * Run autopkgtest for SUBPROJECT=minimized | ||||||
|  |   * When SUBPROJECT environment variable is not set assume it to be "" | ||||||
| 
 | 
 | ||||||
|  -- Victor Tapia <victor.tapia@canonical.com>  Tue, 19 Sep 2017 10:55:11 +0200 |  -- Balint Reczey <rbalint@ubuntu.com>  Tue, 03 Oct 2017 17:35:04 +0200 | ||||||
| 
 | 
 | ||||||
| livecd-rootfs (2.408.18) xenial; urgency=medium | livecd-rootfs (2.408.18) xenial; urgency=medium | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								debian/control
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								debian/control
									
									
									
									
										vendored
									
									
								
							| @ -8,7 +8,7 @@ Vcs-Bzr: lp:~ubuntu-core-dev/livecd-rootfs/xenial-proposed/ | |||||||
| 
 | 
 | ||||||
| Package: livecd-rootfs | Package: livecd-rootfs | ||||||
| Architecture: any | Architecture: any | ||||||
| Depends: ${misc:Depends}, debootstrap, rsync, python-minimal | python, procps, squashfs-tools (>= 1:3.3-1), grep-dctrl, lsb-release, lzma, e2fsprogs, germinate (>= 1.25.1), apt-utils, gnupg, live-build (>= 3.0~a57-1ubuntu12~), android-tools-fsutils [armhf], python3-software-properties | Depends: ${misc:Depends}, debootstrap, rsync, python-minimal | python, procps, squashfs-tools (>= 1:3.3-1), grep-dctrl, lsb-release, lzma, e2fsprogs, germinate (>= 1.25.1), apt-utils, gnupg, live-build (>= 3.0~a57-1ubuntu25.5~), android-tools-fsutils [armhf], python3-software-properties | ||||||
| Suggests: partimage | Suggests: partimage | ||||||
| Breaks: ubuntu-defaults-builder (<< 0.32) | Breaks: ubuntu-defaults-builder (<< 0.32) | ||||||
| Description: construction script for the livecd rootfs | Description: construction script for the livecd rootfs | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								debian/tests/control
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								debian/tests/control
									
									
									
									
										vendored
									
									
								
							| @ -1,3 +1,7 @@ | |||||||
| Tests: default-bootstraps | Tests: default-bootstraps | ||||||
| Depends: @, lsb-release | Depends: @, lsb-release | ||||||
| Restrictions: needs-root isolation-machine | Restrictions: needs-root isolation-machine | ||||||
|  | 
 | ||||||
|  | Tests: minimized | ||||||
|  | Depends: @, lsb-release | ||||||
|  | Restrictions: needs-root isolation-machine | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								debian/tests/default-bootstraps
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								debian/tests/default-bootstraps
									
									
									
									
										vendored
									
									
								
							| @ -30,6 +30,7 @@ ALL_TRIPLETS=" | |||||||
|  ubuntu-budgie-live:: |  ubuntu-budgie-live:: | ||||||
|  ubuntu-core:system-image:ubuntu-core |  ubuntu-core:system-image:ubuntu-core | ||||||
|  ubuntu-cpc::ubuntu-cpc |  ubuntu-cpc::ubuntu-cpc | ||||||
|  |  ubuntu-cpc:minimized:ubuntu-cpc | ||||||
|  ubuntu-desktop-next:system-image:ubuntu-desktop-next |  ubuntu-desktop-next:system-image:ubuntu-desktop-next | ||||||
|  ubuntu-desktop-next::ubuntu-desktop-next |  ubuntu-desktop-next::ubuntu-desktop-next | ||||||
|  ubuntu-dvd:: |  ubuntu-dvd:: | ||||||
|  | |||||||
							
								
								
									
										3
									
								
								debian/tests/minimized
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								debian/tests/minimized
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | |||||||
|  | #!/bin/sh | ||||||
|  | 
 | ||||||
|  | env SELECTED_TRIPLETS=ubuntu-cpc:minimized:ubuntu-cpc debian/tests/default-bootstraps | ||||||
| @ -31,6 +31,111 @@ Expire-Date: 0 | |||||||
| 
 | 
 | ||||||
| 	lb bootstrap "$@" | 	lb bootstrap "$@" | ||||||
| 
 | 
 | ||||||
|  | 	if [ "${SUBPROJECT:-}" = minimized ] \ | ||||||
|  | 	   && ! Chroot chroot dpkg -l tzdata 2>&1 |grep -q ^ii; then | ||||||
|  | 		# workaround for tzdata purge not removing these files | ||||||
|  | 		rm -f chroot/etc/localtime chroot/etc/timezone | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | 	if [ "${SUBPROJECT:-}" = minimized ]; then | ||||||
|  | 		# set up dpkg filters to skip installing docs on minimizedd system | ||||||
|  | 		mkdir -p chroot/etc/dpkg/dpkg.cfg.d | ||||||
|  | 		cat > chroot/etc/dpkg/dpkg.cfg.d/excludes <<EOF | ||||||
|  | # Drop all man pages | ||||||
|  | path-exclude=/usr/share/man/* | ||||||
|  | 
 | ||||||
|  | # Drop all documentation ... | ||||||
|  | path-exclude=/usr/share/doc/* | ||||||
|  | 
 | ||||||
|  | # ... except copyright files ... | ||||||
|  | path-include=/usr/share/doc/*/copyright | ||||||
|  | 
 | ||||||
|  | # ... and Debian changelogs | ||||||
|  | path-include=/usr/share/doc/*/changelog.Debian.* | ||||||
|  | EOF | ||||||
|  | 
 | ||||||
|  | 		# Remove docs installed by bootstrap | ||||||
|  | 		Chroot chroot dpkg-query -f '${binary:Package}\n' -W | Chroot chroot xargs apt-get install --reinstall | ||||||
|  | 
 | ||||||
|  |                 # Add unminimizer script which restores default image behavior | ||||||
|  |                 mkdir -p chroot/usr/local/sbin | ||||||
|  |                 cat > chroot/usr/local/sbin/unminimize <<'EOF' | ||||||
|  | #!/bin/sh | ||||||
|  | 
 | ||||||
|  | set -e | ||||||
|  | 
 | ||||||
|  | echo "This system was optimized for smaller footprint by reducing the available" | ||||||
|  | echo "installed documentation, removal of rarely used tools, and by other means." | ||||||
|  | echo "" | ||||||
|  | echo "This script reverts part of the optimization and makes documentation and" | ||||||
|  | echo "tools available again to match the familiar Ubuntu minimial system." | ||||||
|  | echo "" | ||||||
|  | echo "Be warned that reinstallation of packages may fail due to changes to the" | ||||||
|  | echo "system configuration, due to installation of 3rd party packages, or for" | ||||||
|  | echo "other reasons." | ||||||
|  | read -p "Would you like to continue? [y/N]" REPLY | ||||||
|  | echo    # (optional) move to a new line | ||||||
|  | if [ "$REPLY" != "y" ] && [ "$REPLY" != "Y" ] | ||||||
|  | then | ||||||
|  |     exit 1 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | if [ -f /etc/dpkg/dpkg.cfg.d/excludes ] || [ -f /etc/dpkg/dpkg.cfg.d/excludes.dpkg-tmp ]; then | ||||||
|  |     echo "Re-enabling installation of all documentation in dpkg..." | ||||||
|  |     if [ -f /etc/dpkg/dpkg.cfg.d/excludes ]; then | ||||||
|  |         mv /etc/dpkg/dpkg.cfg.d/excludes /etc/dpkg/dpkg.cfg.d/excludes.dpkg-tmp | ||||||
|  |     fi | ||||||
|  |     echo "Updating package list and upgrading packages..." | ||||||
|  |     apt-get update | ||||||
|  |     # apt-get upgrade asks for confirmation before upgrading packages to let the user stop here | ||||||
|  |     apt-get upgrade | ||||||
|  |     echo "Restoring system documentation..." | ||||||
|  |     echo "Reinstalling packages with files in /usr/share/man/ ..." | ||||||
|  |     # Reinstallation takes place in two steps because a single dpkg --verified | ||||||
|  |     # command generates very long parameter list for "xargs dpkg -S" and may go | ||||||
|  |     # over ARG_MAX. Since many packages have man pages the second download | ||||||
|  |     # handles a much smaller amount of packages. | ||||||
|  |     dpkg -S /usr/share/man/ |sed 's|, |\n|g;s|: [^:]*$||' | DEBIAN_FRONTEND=noninteractive xargs apt-get install --reinstall -y | ||||||
|  |     echo "Reinstalling packages with system documentation in /usr/share/doc/ .." | ||||||
|  |     # This step processes the packages which still have missing documentation | ||||||
|  |     dpkg --verify --verify-format rpm | awk '/..5......   \/usr\/share\/doc/ {print $2}' | sed 's|/[^/]*$||' | sort |uniq \ | ||||||
|  |          | xargs dpkg -S | sed 's|, |\n|g;s|: [^:]*$||' | uniq | DEBIAN_FRONTEND=noninteractive xargs apt-get install --reinstall -y | ||||||
|  |     if dpkg --verify --verify-format rpm | awk '/..5......   \/usr\/share\/doc/ {exit 1}'; then | ||||||
|  |         echo "Documentation has been restored successfully." | ||||||
|  |         rm /etc/dpkg/dpkg.cfg.d/excludes.dpkg-tmp | ||||||
|  |     else | ||||||
|  |         echo "There are still files missing from /usr/share/doc/:" | ||||||
|  |         dpkg --verify --verify-format rpm | awk '/..5......   \/usr\/share\/doc/ {print " " $2}' | ||||||
|  |         echo "You may want to try running this script again or you can remove" | ||||||
|  |         echo "/etc/dpkg/dpkg.cfg.d/excludes.dpkg-tmp and restore the files manually." | ||||||
|  |     fi | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | if ! dpkg-query --show --showformat='${db:Status-Status}\n' ubuntu-minimal 2> /dev/null | grep -q '^installed$'; then | ||||||
|  |     echo "Installing ubuntu-minimal package to provide the familiar Ubuntu minimal system..." | ||||||
|  |     DEBIAN_FRONTEND=noninteractive apt-get install -y ubuntu-minimal | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | # unminimization succeeded, there is no need to mention it in motd | ||||||
|  | rm -f /etc/update-motd.d/60-unminimize | ||||||
|  | 
 | ||||||
|  | EOF | ||||||
|  |                 chmod +x chroot/usr/local/sbin/unminimize | ||||||
|  |         fi | ||||||
|  | 
 | ||||||
|  | 	# inform users about the unminimize script | ||||||
|  | 	cat > "chroot/etc/update-motd.d/60-unminimize" << EOF | ||||||
|  | #!/bin/sh | ||||||
|  | # | ||||||
|  | # This file is not managed by a package.  If you no longer want to | ||||||
|  | # see this message you can safely remove the file. | ||||||
|  | echo "" | ||||||
|  | echo "This system does not provide part of the tools and documentation" | ||||||
|  | echo "which are available on standard Ubuntu systems." | ||||||
|  | echo "To make them available please run the "unminimize" command." | ||||||
|  | EOF | ||||||
|  | 
 | ||||||
|  | 	chmod +x chroot/etc/update-motd.d/60-unminimize | ||||||
| 	Chroot chroot "dpkg-divert --quiet --add \ | 	Chroot chroot "dpkg-divert --quiet --add \ | ||||||
| 		--divert /usr/sbin/update-initramfs.REAL --rename \ | 		--divert /usr/sbin/update-initramfs.REAL --rename \ | ||||||
| 		/usr/sbin/update-initramfs" | 		/usr/sbin/update-initramfs" | ||||||
| @ -249,7 +354,7 @@ elif [ -e binary-tar.tar.gz ]; then | |||||||
| 	cp -a binary-tar.tar.gz "$PREFIX.rootfs.tar.gz" | 	cp -a binary-tar.tar.gz "$PREFIX.rootfs.tar.gz" | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| if [ "$PROJECT:$SUBPROJECT" = "ubuntu-core:system-image" ]; then | if [ "$PROJECT:${SUBPROJECT:-}" = "ubuntu-core:system-image" ]; then | ||||||
|     if [ -e "binary/$INITFS/filesystem.dir" ]; then |     if [ -e "binary/$INITFS/filesystem.dir" ]; then | ||||||
|         rootfs="binary/$INITFS/filesystem.dir" |         rootfs="binary/$INITFS/filesystem.dir" | ||||||
| 
 | 
 | ||||||
| @ -297,7 +402,7 @@ fi | |||||||
| # ubuntu-core and ubuntu-desktop-next splits kernel stuff into a "device" tarball so | # ubuntu-core and ubuntu-desktop-next splits kernel stuff into a "device" tarball so | ||||||
| # at this point we reset it to "none" as all the work to extract it was done already | # at this point we reset it to "none" as all the work to extract it was done already | ||||||
| # in a binary hook | # in a binary hook | ||||||
| case $PROJECT:$SUBPROJECT in | case $PROJECT:${SUBPROJECT:-} in | ||||||
|         ubuntu-core:system-image|ubuntu-desktop-next:system-image) |         ubuntu-core:system-image|ubuntu-desktop-next:system-image) | ||||||
| 
 | 
 | ||||||
|     # create device tarball (for snappy only atm) |     # create device tarball (for snappy only atm) | ||||||
|  | |||||||
| @ -117,7 +117,7 @@ case $IMAGEFORMAT in | |||||||
| 	ext2|ext3|ext4) | 	ext2|ext3|ext4) | ||||||
| 		OPTS="${OPTS:+$OPTS }--initramfs none --chroot-filesystem $IMAGEFORMAT" | 		OPTS="${OPTS:+$OPTS }--initramfs none --chroot-filesystem $IMAGEFORMAT" | ||||||
| 		PREINSTALLED=true | 		PREINSTALLED=true | ||||||
| 		case $SUBPROJECT in | 		case ${SUBPROJECT:-} in | ||||||
| 			wubi) | 			wubi) | ||||||
| 				add_package install lupin-support | 				add_package install lupin-support | ||||||
| 				COMPONENTS='main restricted universe multiverse' | 				COMPONENTS='main restricted universe multiverse' | ||||||
| @ -196,6 +196,10 @@ HWE_X_PACKAGES="xserver-xorg-hwe-16.04 xserver-xorg-video-all-hwe-16.04 xserver- | |||||||
| HWE_KERNEL_FLAVOUR="generic-hwe-16.04" | HWE_KERNEL_FLAVOUR="generic-hwe-16.04" | ||||||
| HWE_SIGNED_KERNEL_PACKAGE="linux-signed-$HWE_KERNEL_FLAVOUR" | HWE_SIGNED_KERNEL_PACKAGE="linux-signed-$HWE_KERNEL_FLAVOUR" | ||||||
| 
 | 
 | ||||||
|  | if [ "${SUBPROJECT:-}" = minimized ]; then | ||||||
|  | 	OPTS="${OPTS:+$OPTS }--bootstrap-flavour=minimal" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
| case $PROJECT in | case $PROJECT in | ||||||
| 	ubuntu|ubuntu-dvd) | 	ubuntu|ubuntu-dvd) | ||||||
| 		HWE_BUILD="yes" | 		HWE_BUILD="yes" | ||||||
| @ -223,7 +227,7 @@ case $PROJECT in | |||||||
| 		#      CDIMAGE_PREINSTALLED is not passed from build.py | 		#      CDIMAGE_PREINSTALLED is not passed from build.py | ||||||
| 		#      and PREINSTALLED means something different. So | 		#      and PREINSTALLED means something different. So | ||||||
| 		#      we use SUBPROJECT to pass on the information | 		#      we use SUBPROJECT to pass on the information | ||||||
| 		if [ "$SUBPROJECT" = "system-image" ]; then | 		if [ "${SUBPROJECT:-}" = "system-image" ]; then | ||||||
| 			OPTS="${OPTS:+$OPTS }--linux-packages=linux-image" | 			OPTS="${OPTS:+$OPTS }--linux-packages=linux-image" | ||||||
| 		fi | 		fi | ||||||
| 		;; | 		;; | ||||||
| @ -477,7 +481,7 @@ case $PROJECT in | |||||||
| 		# SUBPROJECT, but it's a handy thing that launchpad-buildd | 		# SUBPROJECT, but it's a handy thing that launchpad-buildd | ||||||
| 		# already passes through to us that we weren't otherwise | 		# already passes through to us that we weren't otherwise | ||||||
| 		# using here. | 		# using here. | ||||||
| 		case $SUBPROJECT in | 		case ${SUBPROJECT:-} in | ||||||
| 		    ubuntu-rtm/dogfood) | 		    ubuntu-rtm/dogfood) | ||||||
| 			MIRROR=http://derived-archive.dogfood.content.paddev.net/ubuntu-rtm/ | 			MIRROR=http://derived-archive.dogfood.content.paddev.net/ubuntu-rtm/ | ||||||
| 			OPTS="${OPTS:+$OPTS }--apt-secure false" | 			OPTS="${OPTS:+$OPTS }--apt-secure false" | ||||||
| @ -495,8 +499,13 @@ case $PROJECT in | |||||||
| 		;; | 		;; | ||||||
| 
 | 
 | ||||||
| 	ubuntu-cpc) | 	ubuntu-cpc) | ||||||
| 		add_task install minimal standard cloud-image | 		if [ "${SUBPROJECT:-}" = minimized ]; then | ||||||
| 		add_package install ubuntu-minimal | 			add_task install cloud-image | ||||||
|  | 			add_package install sudo | ||||||
|  | 		else | ||||||
|  | 			add_task install minimal standard cloud-image | ||||||
|  | 			add_package install ubuntu-minimal | ||||||
|  | 		fi | ||||||
| 
 | 
 | ||||||
| 		BINARY_REMOVE_LINUX=false | 		BINARY_REMOVE_LINUX=false | ||||||
| 		OPTS="${OPTS:+$OPTS }--initramfs=none" | 		OPTS="${OPTS:+$OPTS }--initramfs=none" | ||||||
| @ -630,7 +639,7 @@ case $PROJECT in | |||||||
| 		;; | 		;; | ||||||
| esac | esac | ||||||
| 
 | 
 | ||||||
| case $SUBPROJECT in | case ${SUBPROJECT:-} in | ||||||
| 	wubi) | 	wubi) | ||||||
| 		add_binary_hook build-wubildr | 		add_binary_hook build-wubildr | ||||||
| 		;; | 		;; | ||||||
| @ -656,8 +665,10 @@ lb config noauto \ | |||||||
| 	"$@" | 	"$@" | ||||||
| 
 | 
 | ||||||
| echo "LB_CHROOT_HOOKS=\"$CHROOT_HOOKS\"" >> config/chroot | echo "LB_CHROOT_HOOKS=\"$CHROOT_HOOKS\"" >> config/chroot | ||||||
|  | echo "SUBPROJECT=\"${SUBPROJECT:-}\"" >> config/chroot | ||||||
| echo "LB_BINARY_HOOKS=\"$BINARY_HOOKS\"" >> config/binary | echo "LB_BINARY_HOOKS=\"$BINARY_HOOKS\"" >> config/binary | ||||||
| echo "BUILDSTAMP=\"$NOW\"" >> config/binary | echo "BUILDSTAMP=\"$NOW\"" >> config/binary | ||||||
|  | echo "SUBPROJECT=\"${SUBPROJECT:-}\"" >> config/binary | ||||||
| 
 | 
 | ||||||
| case $ARCH+$SUBARCH in | case $ARCH+$SUBARCH in | ||||||
| 	armhf+raspi2) | 	armhf+raspi2) | ||||||
| @ -772,7 +783,7 @@ EOF | |||||||
| 	      config/archives/proposed.list.binary | 	      config/archives/proposed.list.binary | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| case $PROJECT:$SUBPROJECT in | case $PROJECT:${SUBPROJECT:-} in | ||||||
| 	*-dvd:*) | 	*-dvd:*) | ||||||
| 		. config/bootstrap | 		. config/bootstrap | ||||||
| 
 | 
 | ||||||
| @ -858,7 +869,7 @@ EOF | |||||||
| 	fi | 	fi | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| case $SUBPROJECT in | case ${SUBPROJECT:-} in | ||||||
|     ubuntu-rtm|ubuntu-rtm/*) |     ubuntu-rtm|ubuntu-rtm/*) | ||||||
| 	# debootstrap doesn't know about ubuntu-rtm series directly.  Rather | 	# debootstrap doesn't know about ubuntu-rtm series directly.  Rather | ||||||
| 	# than having to teach it, we employ a few hacks to make it use the | 	# than having to teach it, we employ a few hacks to make it use the | ||||||
|  | |||||||
| @ -273,6 +273,11 @@ replace_grub_root_with_label() { | |||||||
|     # Instead, we want grub to use the cloudimg-rootfs labelled disk |     # Instead, we want grub to use the cloudimg-rootfs labelled disk | ||||||
|     CHROOT_ROOT="$1" |     CHROOT_ROOT="$1" | ||||||
| 
 | 
 | ||||||
|  |     # If boot by partuuid has been requested, don't override. | ||||||
|  |     if [ -f $CHROOT_ROOT/etc/default/grub.d/40-partuuid ] && \ | ||||||
|  |            grep -q ^GRUB_FORCE_PARTUUID= $CHROOT_ROOT/etc/default/grub.d/40-partuuid; then | ||||||
|  |         return 0 | ||||||
|  |     fi | ||||||
|     sed -i -e "s,root=[^ ]\+,root=LABEL=cloudimg-rootfs," \ |     sed -i -e "s,root=[^ ]\+,root=LABEL=cloudimg-rootfs," \ | ||||||
|         "$CHROOT_ROOT/boot/grub/grub.cfg" |         "$CHROOT_ROOT/boot/grub/grub.cfg" | ||||||
| } | } | ||||||
|  | |||||||
| @ -2,6 +2,8 @@ | |||||||
| 
 | 
 | ||||||
| . config/functions | . config/functions | ||||||
| 
 | 
 | ||||||
|  | . config/binary | ||||||
|  | 
 | ||||||
| BOOTPART_START= | BOOTPART_START= | ||||||
| BOOTPART_END= | BOOTPART_END= | ||||||
| BOOT_MOUNTPOINT= | BOOT_MOUNTPOINT= | ||||||
| @ -64,6 +66,8 @@ create_empty_partition "${disk_image}" "$ROOTPART" "$ROOTPART_START" -1 ext2 "$R | |||||||
| 
 | 
 | ||||||
| mount_image "${disk_image}" "$ROOTPART" | mount_image "${disk_image}" "$ROOTPART" | ||||||
| 
 | 
 | ||||||
|  | partuuid=$(blkid -s PARTUUID -o value "$rootfs_dev_mapper") | ||||||
|  | 
 | ||||||
| # Copy the chroot in to the disk | # Copy the chroot in to the disk | ||||||
| make_ext4_partition "${rootfs_dev_mapper}" | make_ext4_partition "${rootfs_dev_mapper}" | ||||||
| mkdir mountpoint | mkdir mountpoint | ||||||
| @ -111,6 +115,13 @@ if [ "${should_install_grub}" -eq 1 ]; then | |||||||
|         ${loop_device} |         ${loop_device} | ||||||
| 
 | 
 | ||||||
|     rm mountpoint/tmp/device.map |     rm mountpoint/tmp/device.map | ||||||
|  | 
 | ||||||
|  | 	if [ "${SUBPROJECT:-}" = minimized ] && [ -n "$partuuid" ]; then | ||||||
|  | 		echo "partuuid found for root device; forcing it in Grub" | ||||||
|  | 		mkdir -p mountpoint/etc/default/grub.d | ||||||
|  | 		echo "GRUB_FORCE_PARTUUID=$partuuid" >> mountpoint/etc/default/grub.d/40-force-partuuid | ||||||
|  | 		chroot mountpoint update-grub | ||||||
|  | 	fi | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| if [ "$ARCH" = "s390x" ]; then | if [ "$ARCH" = "s390x" ]; then | ||||||
|  | |||||||
| @ -61,6 +61,14 @@ install_grub() { | |||||||
|     efi_boot_dir="/boot/efi/EFI/BOOT" |     efi_boot_dir="/boot/efi/EFI/BOOT" | ||||||
|     chroot mountpoint mkdir -p "${efi_boot_dir}" |     chroot mountpoint mkdir -p "${efi_boot_dir}" | ||||||
| 
 | 
 | ||||||
|  |     if [ "${SUBPROJECT:-}" = minimized ] && [ -n "$partuuid" ]; then | ||||||
|  |         # FIXME: code duplicated between 032-disk-image.binary | ||||||
|  |         # and 033-disk-image-uefi.binary.  We want to fix this to not | ||||||
|  |         # have initramfs-tools installed at all on these images. | ||||||
|  |         echo "partuuid found for root device; omitting initrd" | ||||||
|  |         echo "GRUB_FORCE_PARTUUID=$partuuid" >> mountpoint/etc/default/grub.d/40-force-partuuid | ||||||
|  |     fi | ||||||
|  | 
 | ||||||
|     chroot mountpoint apt-get -y update |     chroot mountpoint apt-get -y update | ||||||
| 
 | 
 | ||||||
|     # The modules below only make sense on non-Secure Boot UEFI systems. |     # The modules below only make sense on non-Secure Boot UEFI systems. | ||||||
| @ -132,6 +140,8 @@ create_empty_disk_image "${disk_image}" | |||||||
| create_partitions "${disk_image}" | create_partitions "${disk_image}" | ||||||
| mount_image "${disk_image}" 1 | mount_image "${disk_image}" 1 | ||||||
| 
 | 
 | ||||||
|  | partuuid=$(blkid -s PARTUUID -o value "$rootfs_dev_mapper") | ||||||
|  | 
 | ||||||
| # Copy the chroot in to the disk | # Copy the chroot in to the disk | ||||||
| make_ext4_partition "${rootfs_dev_mapper}" | make_ext4_partition "${rootfs_dev_mapper}" | ||||||
| mkdir mountpoint | mkdir mountpoint | ||||||
|  | |||||||
| @ -3,6 +3,8 @@ rootd="${1:-/}" | |||||||
| root_fs_label=cloudimg-rootfs | root_fs_label=cloudimg-rootfs | ||||||
| set -ex | set -ex | ||||||
| 
 | 
 | ||||||
|  | . /root/config/chroot | ||||||
|  | 
 | ||||||
| CLOUD_IMG_STR="# CLOUD_IMG: This file was created/modified by the Cloud Image build process" | CLOUD_IMG_STR="# CLOUD_IMG: This file was created/modified by the Cloud Image build process" | ||||||
| 
 | 
 | ||||||
| LANG=C | LANG=C | ||||||
| @ -87,7 +89,9 @@ _xchroot "${rootd}" sh -c 'sed -i "/^127.0.1.1/d" /etc/hosts' | |||||||
| _xchroot "${rootd}" sh -c 'rm -f /etc/ssh/ssh_host_[rd]sa_key*' | _xchroot "${rootd}" sh -c 'rm -f /etc/ssh/ssh_host_[rd]sa_key*' | ||||||
| 
 | 
 | ||||||
| ## -------------- | ## -------------- | ||||||
| _xchroot "${rootd}" locale-gen en_US.utf8 | if [ "${SUBPROJECT:-}" != minimized ]; then | ||||||
|  | 	_xchroot "${rootd}" locale-gen en_US.utf8 | ||||||
|  | fi | ||||||
| 
 | 
 | ||||||
| ## -------------- | ## -------------- | ||||||
| # set cloud-init to be on | # set cloud-init to be on | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user