diff options
author | Patrick Ohly <patrick.ohly@intel.com> | 2015-09-03 20:42:32 +0200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-09-06 15:26:25 +0100 |
commit | 6d7bcd4df5722f3ccebbbf73361838cb0a5dc0ee (patch) | |
tree | 71567c46291b06559731d451466d7d6cfb59a279 | |
parent | 5d79814b0b9d4d0348dc36c0d9e003e4ba0bd367 (diff) | |
download | poky-6d7bcd4df5722f3ccebbbf73361838cb0a5dc0ee.tar.gz |
boot loader: support root=UUID
As mentioned when introducing the VM images
(https://bugzilla.yoctoproject.org/show_bug.cgi?id=7374), the
resulting images only work when the image is mounted as a disk that
results in the hard-coded path (/dev/sda in the current
default). Using the file system UUID to find the rootfs is more
flexible.
To enable this for boot-direct.bbclass and thus image-vm.bbclass (aka
FSTYPEs vdi/vmdk/qcow2), set SYSLINUX_ROOT =
"root=UUID=<<uuid-of-rootfs>>". The rootfs image must use an ext file
system.
The special string will get replaced in the APPEND line with the
actual UUID when the boot loader (grub-efi, syslinux or gummiboot)
writes the boot loader configuration files. At that time, the rootfs
image has already been created and its UUID can be extracted using
"tune2fs -l", which also should be available because the
e2fsprogs-native tools were needed to create the image in the first
place.
(From OE-Core rev: 1e29d77d0d33ee216b43022439876863f0db39bb)
Signed-off-by: Patrick Ohly <patrick.ohly@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta/classes/fs-uuid.bbclass | 24 | ||||
-rw-r--r-- | meta/classes/grub-efi.bbclass | 4 | ||||
-rw-r--r-- | meta/classes/gummiboot.bbclass | 4 | ||||
-rw-r--r-- | meta/classes/syslinux.bbclass | 5 |
4 files changed, 36 insertions, 1 deletions
diff --git a/meta/classes/fs-uuid.bbclass b/meta/classes/fs-uuid.bbclass new file mode 100644 index 0000000000..bd2613cf10 --- /dev/null +++ b/meta/classes/fs-uuid.bbclass | |||
@@ -0,0 +1,24 @@ | |||
1 | # Extract UUID from ${ROOTFS}, which must have been built | ||
2 | # by the time that this function gets called. Only works | ||
3 | # on ext file systems and depends on tune2fs. | ||
4 | def get_rootfs_uuid(d): | ||
5 | import subprocess | ||
6 | rootfs = d.getVar('ROOTFS', True) | ||
7 | output = subprocess.check_output(['tune2fs', '-l', rootfs]) | ||
8 | for line in output.split('\n'): | ||
9 | if line.startswith('Filesystem UUID:'): | ||
10 | uuid = line.split()[-1] | ||
11 | bb.note('UUID of %s: %s' % (rootfs, uuid)) | ||
12 | return uuid | ||
13 | bb.fatal('Could not determine filesystem UUID of %s' % rootfs) | ||
14 | |||
15 | # Replace the special <<uuid-of-rootfs>> inside a string (like the | ||
16 | # root= APPEND string in a syslinux.cfg or gummiboot entry) with the | ||
17 | # actual UUID of the rootfs. Does nothing if the special string | ||
18 | # is not used. | ||
19 | def replace_rootfs_uuid(d, string): | ||
20 | UUID_PLACEHOLDER = '<<uuid-of-rootfs>>' | ||
21 | if UUID_PLACEHOLDER in string: | ||
22 | uuid = get_rootfs_uuid(d) | ||
23 | string = string.replace(UUID_PLACEHOLDER, uuid) | ||
24 | return string | ||
diff --git a/meta/classes/grub-efi.bbclass b/meta/classes/grub-efi.bbclass index 6d58d48704..4ddc2bb125 100644 --- a/meta/classes/grub-efi.bbclass +++ b/meta/classes/grub-efi.bbclass | |||
@@ -26,6 +26,9 @@ GRUB_OPTS ?= "serial --unit=0 --speed=115200 --word=8 --parity=no --stop=1" | |||
26 | 26 | ||
27 | EFIDIR = "/EFI/BOOT" | 27 | EFIDIR = "/EFI/BOOT" |
28 | 28 | ||
29 | # Need UUID utility code. | ||
30 | inherit fs-uuid | ||
31 | |||
29 | efi_populate() { | 32 | efi_populate() { |
30 | # DEST must be the root of the image so that EFIDIR is not | 33 | # DEST must be the root of the image so that EFIDIR is not |
31 | # nested under a top level directory. | 34 | # nested under a top level directory. |
@@ -129,6 +132,7 @@ python build_efi_cfg() { | |||
129 | initrd = localdata.getVar('INITRD', True) | 132 | initrd = localdata.getVar('INITRD', True) |
130 | 133 | ||
131 | if append: | 134 | if append: |
135 | append = replace_rootfs_uuid(d, append) | ||
132 | cfgfile.write('%s' % (append)) | 136 | cfgfile.write('%s' % (append)) |
133 | cfgfile.write(' %s' % btype[1]) | 137 | cfgfile.write(' %s' % btype[1]) |
134 | cfgfile.write('\n') | 138 | cfgfile.write('\n') |
diff --git a/meta/classes/gummiboot.bbclass b/meta/classes/gummiboot.bbclass index dae19775c3..3d9c08bbc9 100644 --- a/meta/classes/gummiboot.bbclass +++ b/meta/classes/gummiboot.bbclass | |||
@@ -15,6 +15,9 @@ GUMMIBOOT_CFG ?= "${S}/loader.conf" | |||
15 | GUMMIBOOT_ENTRIES ?= "" | 15 | GUMMIBOOT_ENTRIES ?= "" |
16 | GUMMIBOOT_TIMEOUT ?= "10" | 16 | GUMMIBOOT_TIMEOUT ?= "10" |
17 | 17 | ||
18 | # Need UUID utility code. | ||
19 | inherit fs-uuid | ||
20 | |||
18 | efi_populate() { | 21 | efi_populate() { |
19 | DEST=$1 | 22 | DEST=$1 |
20 | 23 | ||
@@ -108,6 +111,7 @@ python build_efi_cfg() { | |||
108 | lb = "install-efi" | 111 | lb = "install-efi" |
109 | entrycfg.write('options LABEL=%s ' % lb) | 112 | entrycfg.write('options LABEL=%s ' % lb) |
110 | if append: | 113 | if append: |
114 | append = replace_rootfs_uuid(d, append) | ||
111 | entrycfg.write('%s' % append) | 115 | entrycfg.write('%s' % append) |
112 | entrycfg.write('\n') | 116 | entrycfg.write('\n') |
113 | entrycfg.close() | 117 | entrycfg.close() |
diff --git a/meta/classes/syslinux.bbclass b/meta/classes/syslinux.bbclass index d6498d98bb..44ef9a9176 100644 --- a/meta/classes/syslinux.bbclass +++ b/meta/classes/syslinux.bbclass | |||
@@ -34,6 +34,9 @@ ISO_BOOTCAT = "isolinux/boot.cat" | |||
34 | MKISOFS_OPTIONS = "-no-emul-boot -boot-load-size 4 -boot-info-table" | 34 | MKISOFS_OPTIONS = "-no-emul-boot -boot-load-size 4 -boot-info-table" |
35 | APPEND_prepend = " ${SYSLINUX_ROOT} " | 35 | APPEND_prepend = " ${SYSLINUX_ROOT} " |
36 | 36 | ||
37 | # Need UUID utility code. | ||
38 | inherit fs-uuid | ||
39 | |||
37 | syslinux_populate() { | 40 | syslinux_populate() { |
38 | DEST=$1 | 41 | DEST=$1 |
39 | BOOTDIR=$2 | 42 | BOOTDIR=$2 |
@@ -177,7 +180,7 @@ python build_syslinux_cfg () { | |||
177 | cfgfile.write('initrd=/initrd ') | 180 | cfgfile.write('initrd=/initrd ') |
178 | 181 | ||
179 | cfgfile.write('LABEL=%s '% (label)) | 182 | cfgfile.write('LABEL=%s '% (label)) |
180 | 183 | append = replace_rootfs_uuid(d, append) | |
181 | cfgfile.write('%s %s\n' % (append, btype[1])) | 184 | cfgfile.write('%s %s\n' % (append, btype[1])) |
182 | else: | 185 | else: |
183 | cfgfile.write('APPEND %s\n' % btype[1]) | 186 | cfgfile.write('APPEND %s\n' % btype[1]) |