From 01db819714b328ea56d66ebaaedc42e15ec83f09 Mon Sep 17 00:00:00 2001 From: Richard Stephens Date: Sat, 13 Jan 2024 23:22:38 +0100 Subject: [PATCH] feat: flag to create pmbr marked as bootable (#132) We're using gptman to build a bootable disk image, that needs to boot on both BIOS and UEFI systems. We've found that some legacy BIOS systems don't consider a disk to be bootable unless the bootable flag is set on the [PMBR](https://www.rodsbooks.com/gdisk/bios.html). --- src/lib.rs | 35 ++++++++++++++++++++++++++++++++++- 1 file changed, 34 insertions(+), 1 deletion(-) diff --git a/src/lib.rs b/src/lib.rs index 878fb6b..fd106aa 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1231,15 +1231,48 @@ impl GPT { /// This function writes a protective MBR in the first sector of the disk /// starting at byte 446 and ending at byte 511. Any existing data will be overwritten. + /// + /// See also: [`Self::write_bootable_protective_mbr_into`]. pub fn write_protective_mbr_into(mut writer: &mut W, sector_size: u64) -> Result<()> + where + W: Write + Seek, + { + Self::write_protective_mbr_into_impl(&mut writer, sector_size, false) + } + + /// This function writes a protective MBR in the first sector of the disk + /// starting at byte 446 and ending at byte 511. Any existing data will be overwritten. + /// This function differs from [`Self::write_protective_mbr_into`] in that the partition in the + /// MBR partition table is marked as bootable. Some legacy BIOS systems do not consider a disk + /// to be bootable if there isn't an MBR partition marked as bootable in the MBR partition + /// table. + pub fn write_bootable_protective_mbr_into( + mut writer: &mut W, + sector_size: u64, + ) -> Result<()> + where + W: Write + Seek, + { + Self::write_protective_mbr_into_impl(&mut writer, sector_size, true) + } + + fn write_protective_mbr_into_impl( + mut writer: &mut W, + sector_size: u64, + bootable: bool, + ) -> Result<()> where W: Write + Seek, { let size = writer.seek(SeekFrom::End(0))? / sector_size - 1; writer.seek(SeekFrom::Start(446))?; // partition 1 + if bootable { + writer.write_all(&[0x80])?; + } else { + writer.write_all(&[0x00])?; + } writer.write_all(&[ - 0x00, // status 0x00, 0x02, 0x00, // CHS address of first absolute sector 0xee, // partition type 0xff, 0xff, 0xff, // CHS address of last absolute sector