zerocopy
zerocopy
crate(源自 Fuchsia)提供了 trait 和宏,用于确保在字节序列和其他类型之间进行安全转换。
use zerocopy::{Immutable, IntoBytes}; #[repr(u32)] #[derive(Debug, Default, Immutable, IntoBytes)] enum RequestType { #[default] In = 0, Out = 1, Flush = 4, } #[repr(C)] #[derive(Debug, Default, Immutable, IntoBytes)] struct VirtioBlockRequest { request_type: RequestType, reserved: u32, sector: u64, } fn main() { let request = VirtioBlockRequest { request_type: RequestType::Flush, sector: 42, ..Default::default() }; assert_eq!( request.as_bytes(), &[4, 0, 0, 0, 0, 0, 0, 0, 42, 0, 0, 0, 0, 0, 0, 0] ); }
这不适用于 MMIO(因为它不使用易失性读取和写入),但在与硬件共享的结构(例如通过 DMA 传输或发送到外部接口)中进行操作时会很有用。
- 对于可以接受任何字节模式的类型,都可以实现
FromBytes
方法,因此可以对不受信任的字节序列进行安全转换。 - 如果尝试为这些类型派生
FromBytes
,都将会失败,因为RequestType
不会将所有可能的 u32 值用作判别标识,所以并非所有的字节模式都有效。 zerocopy::byteorder
提供了适用于字节顺序感知的数字基元类型。- 使用
src/bare-metal/useful-crates/zerocopy-example/
目录下的cargo run
运行该示例。(由于存在 crate 依赖项,无法在 Playground 中运行该示例。)