From 5d7eb13fbc30b9233c12cfff3db892412f4b93b5 Mon Sep 17 00:00:00 2001 From: Andrew Gunnerson Date: Tue, 10 Dec 2024 23:58:36 -0500 Subject: [PATCH] Fix crash when ignoring warning about missing preinit device MagiskRootPatcher was previously assuming that there is a preinit device value if the Magisk version requires it. Signed-off-by: Andrew Gunnerson --- avbroot/src/patch/boot.rs | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/avbroot/src/patch/boot.rs b/avbroot/src/patch/boot.rs index afa2160..13ca970 100644 --- a/avbroot/src/patch/boot.rs +++ b/avbroot/src/patch/boot.rs @@ -4,6 +4,7 @@ use std::{ cmp::Ordering, collections::{HashMap, HashSet}, + fmt::Write, fs::File, io::{self, BufRead, BufReader, Cursor, Read, Seek}, num::ParseIntError, @@ -497,10 +498,9 @@ impl BootImagePatch for MagiskRootPatcher { magisk_config.push_str("RECOVERYMODE=false\n"); if Self::VER_PREINIT_DEVICE.contains(&self.version) { - magisk_config.push_str(&format!( - "PREINITDEVICE={}\n", - self.preinit_device.as_ref().unwrap(), - )); + if let Some(device) = &self.preinit_device { + write!(&mut magisk_config, "PREINITDEVICE={device}\n").unwrap(); + } } // Magisk normally saves the original SHA1 digest in its config file. It @@ -510,7 +510,7 @@ impl BootImagePatch for MagiskRootPatcher { magisk_config.push_str("SHA1=0000000000000000000000000000000000000000\n"); if Self::VER_RANDOM_SEED.contains(&self.version) { - magisk_config.push_str(&format!("RANDOMSEED={:#x}\n", self.random_seed)); + write!(&mut magisk_config, "RANDOMSEED={:#x}\n", self.random_seed).unwrap(); } trace!("Magisk config: {magisk_config:?}");