From abaa6d0ac9c869208e462334b0fc6a988864b355 Mon Sep 17 00:00:00 2001 From: Dietmar Maurer Date: Sat, 2 Jan 2021 10:55:30 +0100 Subject: [PATCH] tape: decode TapeAlertFlags in cartridge-memory command --- src/tape/drive/mam.rs | 15 ++++++++++++--- src/tape/drive/mod.rs | 2 ++ 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/src/tape/drive/mam.rs b/src/tape/drive/mam.rs index 0986452a..c4f31155 100644 --- a/src/tape/drive/mam.rs +++ b/src/tape/drive/mam.rs @@ -9,7 +9,10 @@ use proxmox::tools::io::ReadExt; use crate::{ api2::types::MamAttribute, - tape::sgutils2::SgRaw, + tape::{ + tape_alert_flags::TapeAlertFlags, + sgutils2::SgRaw, + }, }; // Read Medium auxiliary memory attributes (MAM) @@ -32,7 +35,7 @@ enum MamFormat { static MAM_ATTRIBUTES: &'static [ (u16, u16, MamFormat, &'static str) ] = &[ (0x00_00, 8, MamFormat::DEC, "Remaining Capacity In Partition"), (0x00_01, 8, MamFormat::DEC, "Maximum Capacity In Partition"), - (0x00_02, 8, MamFormat::BINARY, "Tapealert Flags"), + (0x00_02, 8, MamFormat::DEC, "Tapealert Flags"), (0x00_03, 8, MamFormat::DEC, "Load Count"), (0x00_04, 8, MamFormat::DEC, "MAM Space Remaining"), (0x00_05, 8, MamFormat::ASCII, "Assigning Organization"), @@ -157,7 +160,13 @@ fn decode_mam_attributes(data: &[u8]) -> Result, Error> { } else if info.1 == 4 { format!("{}", u32::from_be_bytes(data[0..4].try_into()?)) } else if info.1 == 8 { - format!("{}", u64::from_be_bytes(data[0..8].try_into()?)) + if head_id == 2 { // Tape Alert Flags + let value = u64::from_be_bytes(data[0..8].try_into()?); + let flags = TapeAlertFlags::from_bits_truncate(value); + format!("{:?}", flags) + } else { + format!("{}", u64::from_be_bytes(data[0..8].try_into()?)) + } } else { unreachable!(); } diff --git a/src/tape/drive/mod.rs b/src/tape/drive/mod.rs index 6c1814f6..75a690bb 100644 --- a/src/tape/drive/mod.rs +++ b/src/tape/drive/mod.rs @@ -1,5 +1,7 @@ mod virtual_tape; mod linux_mtio; + +pub mod tape_alert_flags; pub mod linux_tape; mod mam;