From c3e0bfadbe7ffa557a9b6437082eb5082e8bce7b Mon Sep 17 00:00:00 2001 From: Ruslan Iusupov Date: Mon, 19 Feb 2024 11:12:11 +0100 Subject: [PATCH] Allow to discard unknown SD option --- src/sd.rs | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/src/sd.rs b/src/sd.rs index b3be746..8be5f33 100644 --- a/src/sd.rs +++ b/src/sd.rs @@ -326,6 +326,12 @@ impl SdHeader { #[inline] #[cfg(any(target_pointer_width = "32", target_pointer_width = "64"))] pub fn read(reader: &mut T) -> Result { + SdHeader::read_with_flag(reader, false) + } + + #[inline] + #[cfg(any(target_pointer_width = "32", target_pointer_width = "64"))] + pub fn read_with_flag(reader: &mut T, discard_unknown_option: bool) -> Result { const HEADER_LENGTH: usize = 1 + 3 + 4; // flags + rev + entries length let mut header_bytes: [u8; HEADER_LENGTH] = [0; HEADER_LENGTH]; reader.read_exact(&mut header_bytes)?; @@ -373,7 +379,7 @@ impl SdHeader { options.try_reserve((options_length as usize) / 4)?; while options_length > 0 { - let (read_bytes, option) = SdOption::read(reader)?; + let (read_bytes, option) = SdOption::read(reader, discard_unknown_option)?; options.push(option); options_length -= read_bytes as u32; } @@ -946,7 +952,7 @@ impl From for SdOption { impl SdOption { /// Read the value from a [`std::io::Read`] source. #[inline] - pub fn read(reader: &mut T) -> Result<(u16, Self), SdReadError> { + pub fn read(reader: &mut T, discard_unknown_option: bool) -> Result<(u16, Self), SdReadError> { use self::sd_options::*; use self::SdOption::*; use SdReadError::*; @@ -1065,7 +1071,7 @@ impl SdOption { }) } option_type => { - if discardable { + if discardable || discard_unknown_option { // skip unknown options payload if "discardable" // if length is greater then 1 then we need to skip the rest of the option // (note that we already read length 1 as this contains the "discardable"