From bacf0f55e3659ec1b711f5e942ff43e841f99271 Mon Sep 17 00:00:00 2001 From: Michael Marineau Date: Thu, 14 May 2015 14:55:49 -0700 Subject: [PATCH] disk_util: add support for experimental nspawn booting - Sets a read-only flag in the GPT so generic tools like nspawn can detect that /usr is supposed to be mounted read-only. - Adds a vm type that uses the standard x86_64 root volume type instead of our custom coreos-resize type. --- build_library/disk_layout.json | 7 +++++++ build_library/disk_util | 6 ++++++ build_library/vm_image_util.sh | 4 ++++ 3 files changed, 17 insertions(+) diff --git a/build_library/disk_layout.json b/build_library/disk_layout.json index 2a1f8827a9..a8803f977d 100644 --- a/build_library/disk_layout.json +++ b/build_library/disk_layout.json @@ -76,6 +76,13 @@ "blocks":"12943360" } }, + "nspawn":{ + "9":{ + "label":"ROOT", + "type":"4f68bce3-e8cd-4db1-96e7-fbcaf984b709", + "blocks":"12943360" + } + }, "azure":{ "9":{ "label":"ROOT", diff --git a/build_library/disk_util b/build_library/disk_util index 7c67bfa157..355e6a776b 100755 --- a/build_library/disk_util +++ b/build_library/disk_util @@ -678,6 +678,12 @@ def Tune2fsReadWrite(options, partition, disable_rw): image.seek(partition['first_byte'] + flag_offset) image.write(chr(flag_value)) + # bit 60 is 'read-only', TODO: support this in cgpt + # http://www.freedesktop.org/wiki/Specifications/DiscoverablePartitionsSpec/ + attr_cmd = "set" if disable_rw else "clear" + attr_arg = "--attributes=%s:%s:60" % (partition['num'], attr_cmd) + subprocess.check_call(['sgdisk', attr_arg, options.disk_image]) + def IsE2fsReadWrite(options, partition): """Returns True if FS is read-write, False if hack is active. diff --git a/build_library/vm_image_util.sh b/build_library/vm_image_util.sh index 7f7ba4b852..eb343f96c2 100644 --- a/build_library/vm_image_util.sh +++ b/build_library/vm_image_util.sh @@ -36,6 +36,7 @@ VALID_IMG_TYPES=( secure_demo niftycloud cloudsigma + nspawn ) #list of oem package names, minus the oem- prefix @@ -108,6 +109,9 @@ IMG_DEFAULT_BUNDLE_FORMAT= # Memory size to use in any config files IMG_DEFAULT_MEM=1024 +## systemd-nspawn +IMG_nspawn_DISK_LAYOUT=nspawn + ## qemu IMG_qemu_DISK_FORMAT=qcow2 IMG_qemu_DISK_LAYOUT=vm