summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--meta/classes/fs-uuid.bbclass24
-rw-r--r--meta/classes/grub-efi.bbclass4
-rw-r--r--meta/classes/gummiboot.bbclass4
-rw-r--r--meta/classes/syslinux.bbclass5
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.
4def 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.
19def 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
27EFIDIR = "/EFI/BOOT" 27EFIDIR = "/EFI/BOOT"
28 28
29# Need UUID utility code.
30inherit fs-uuid
31
29efi_populate() { 32efi_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"
15GUMMIBOOT_ENTRIES ?= "" 15GUMMIBOOT_ENTRIES ?= ""
16GUMMIBOOT_TIMEOUT ?= "10" 16GUMMIBOOT_TIMEOUT ?= "10"
17 17
18# Need UUID utility code.
19inherit fs-uuid
20
18efi_populate() { 21efi_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"
34MKISOFS_OPTIONS = "-no-emul-boot -boot-load-size 4 -boot-info-table" 34MKISOFS_OPTIONS = "-no-emul-boot -boot-load-size 4 -boot-info-table"
35APPEND_prepend = " ${SYSLINUX_ROOT} " 35APPEND_prepend = " ${SYSLINUX_ROOT} "
36 36
37# Need UUID utility code.
38inherit fs-uuid
39
37syslinux_populate() { 40syslinux_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])