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
use std::ops::Range; use crate::mapping::MappedRange; /// Block that owns a `Range` of the `Memory`. /// Implementor must ensure that there can't be any other blocks /// with overlapping range (either through type system or safety notes for unsafe functions). /// Provides access to safe memory range mapping. pub trait Block<B: gfx_hal::Backend> { /// Get memory properties of the block. fn properties(&self) -> gfx_hal::memory::Properties; /// Get raw memory object. fn memory(&self) -> &B::Memory; /// Get memory range owned by this block. fn range(&self) -> Range<u64>; /// Get size of the block. fn size(&self) -> u64 { let range = self.range(); range.end - range.start } /// Get mapping for the buffer range. /// Memory writes to the region performed by device become available for the host. fn map<'a>( &'a mut self, device: &B::Device, range: Range<u64>, ) -> Result<MappedRange<'a, B>, gfx_hal::device::MapError>; /// Release memory mapping. Must be called after successful `map` call. /// No-op if block is not mapped. fn unmap(&mut self, device: &B::Device); }