From 6b8413ce8b711784a2847ebdfc56478c9f772a01 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20F=2E=20R=2E=20A=2E=20Prado?= Date: Thu, 14 Mar 2024 13:46:24 -0400 Subject: [PATCH] partitioning: Add partattrs property to partition MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Add a 'partattrs' property to partitions. It allows the GPT partition attribute bits to be set for a partition. Notably this is needed to set bits 48 and 56, which are part of the GUID specific range, to allow a ChromeOS Kernel partition to be booted on Chromebooks. Signed-off-by: NĂ­colas F. R. A. Prado --- actions/image_partition_action.go | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/actions/image_partition_action.go b/actions/image_partition_action.go index 61ac62bb..3b684c62 100644 --- a/actions/image_partition_action.go +++ b/actions/image_partition_action.go @@ -58,6 +58,7 @@ a 32 bits hexadecimal number (e.g. '1234ABCD' without any dash separator). fsck: bool fsuuid: string partuuid: string + partattrs: list of partition attributes Mandatory properties: @@ -95,6 +96,16 @@ for partition. - flags -- list of additional flags for partition compatible with parted(8) 'set' command. +- partattrs -- list of GPT partition attribute bits to set, as defined in +https://uefi.org/specs/UEFI/2.10/05_GUID_Partition_Table_Format.html#defined-gpt-partition-entry-attributes. +Bit 0: "Required Partition", bit 1: "No Block IO Protocol", bit 2: "Legacy BIOS +Bootable". Bits 3-47 are reserved. Bits 48 - 63 are GUID specific. For example, +ChromeOS Kernel partitions (GUID=fe3a2a5d-4f32-41a7-b725-accc3285a309) use bit +56 for "successful boot" and bits 48-51 for "priority", where 0 means not +bootable, thus bits 56 and 48 need to be set through this property in order to +be able to boot a ChromeOS Kernel partition on a Chromebook, like so: +'partattrs: [56, 48]'. + - fsck -- if set to `false` -- then set fs_passno (man fstab) to 0 meaning no filesystem checks in boot time. By default is set to `true` allowing checks on boot. @@ -187,6 +198,7 @@ type Partition struct { Name string PartLabel string PartType string + PartAttrs []string PartUUID string Start string End string @@ -531,6 +543,13 @@ func (i ImagePartitionAction) Run(context *debos.DebosContext) error { } } + if p.PartAttrs != nil { + err = debos.Command{}.Run("sfdisk", "sfdisk", "--part-attrs", context.Image, fmt.Sprintf("%d", p.number), strings.Join(p.PartAttrs, ",")) + if err != nil { + return err + } + } + /* PartUUID will only be set for gpt partitions */ if len(p.PartUUID) > 0 { err = debos.Command{}.Run("sfdisk", "sfdisk", "--part-uuid", context.Image, fmt.Sprintf("%d", p.number), p.PartUUID)