From e43e4481eaad91247f2f67782b223e73904694b0 Mon Sep 17 00:00:00 2001 From: Zhouqi Jiang Date: Thu, 31 Oct 2024 16:20:39 +0800 Subject: [PATCH] rfel: identify chip from fel version id field Signed-off-by: Zhouqi Jiang --- rfel/src/main.rs | 30 +++++++++++++++++++++++++----- 1 file changed, 25 insertions(+), 5 deletions(-) diff --git a/rfel/src/main.rs b/rfel/src/main.rs index 41f41be..9ebd190 100644 --- a/rfel/src/main.rs +++ b/rfel/src/main.rs @@ -41,7 +41,7 @@ fn main() { let mut interface = device.claim_interface(0).expect("open USB interface 0"); let fel = Fel::open_usb_interface(&mut interface).expect("open usb interface as an FEL device"); let version = fel.get_version(); - println!("{:?}", version); + println!("{:x?}", version); } struct Fel<'a> { @@ -214,14 +214,34 @@ struct Version { pad: [u8; 8], } +impl Version { + /// Get chip from version. + fn chip(self) -> Option { + match self.id { + 0x00185900 => Some(Chip::D1), + _ => None, + } + } +} + impl fmt::Debug for Version { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { - f.debug_map() - .entry(&"magic", &String::from_utf8_lossy(&self.magic)) - .entry(&"id", &self.id) - .entry(&"dflag", &self.dflag) + let mut map = f.debug_map(); + map.entry(&"magic", &String::from_utf8_lossy(&self.magic)); + match self.chip() { + Some(chip) => map.entry(&"chip", &chip), + None => map.entry(&"id", &self.id) + }; + map.entry(&"dflag", &self.dflag) .entry(&"dlength", &self.dlength) .entry(&"scratchpad", &self.scratchpad) .finish() } } + +#[derive(Debug)] +#[repr(u32)] +enum Chip { + /// D1-H, D1s or F133 chip. + D1 = 0x00185900, +}