1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
use { crate::Stripe, byteorder::LE, static_assertions::const_assert_eq, zerocopy::{AsBytes, FromBytes, Unaligned, U16, U32, U64}, }; /// This structure contains the mapping from a virtualized usable byte range within the backing /// storage to a set of one or more stripes on individual backing devices. In addition to the /// mapping, hints on optimal I/O parameters for this chunk. It is associated with CHUNK_ITEM items. /// /// Although the structure definition only contains one stripe member, CHUNK_ITEM items contain as /// many struct btrfs_stripe structures as specified in the num_stripes and sub_stripes fields. #[derive(Copy, Clone, Debug, AsBytes, FromBytes, Unaligned)] #[repr(C, packed)] pub struct Chunk { /// The size of this chunk, in bytes. pub length: U64<LE>, /// The object ID of the root referencing this chunk. This is always the ID of an extent root. pub owner: U64<LE>, /// The replication stripe length. pub stripe_len: U64<LE>, /// Flags indicating allocation type and replication policy. pub r#type: U64<LE>, /// The optimal I/O alignment for this chunk. pub io_align: U32<LE>, /// The optimal I/O width for this chunk. pub io_width: U32<LE>, /// The minimal I/O size for this chunk. pub sector_size: U32<LE>, /// The number of replication stripes. pub num_stripes: U16<LE>, /// The number of sub-stripes. This is only used for RAID-10. pub sub_stripes: U16<LE>, /// The first of one or more stripes that map to device extents. pub stripe: Stripe, } const_assert_eq!(std::mem::size_of::<Chunk>(), 80);