Function presser::read_slice_at_offset_mut
source · pub unsafe fn read_slice_at_offset_mut<'a, T, S: Slab + ?Sized>(
slab: &'a mut S,
offset: usize,
len: usize
) -> Result<&'a mut [T], Error>Expand description
Reads a &mut [T] within slab at offset.
offsetis the offset, in bytes, after the start ofslabat which a[T; len]is placed.lenis the length of the returned slice, counted in elements ofT.
The function will return an error if:
offsetwithinslabis not properly aligned forToffsetis out of bounds of theslaboffset + size_of::<T> * lenis out of bounds of theslab
Safety
You must have previously fully-initialized a valid* [T; len] at the given offset into slab. If you want to fill an uninitialized
buffer with data, you should instead use any of the copy helper functions or one of the maybe_uninit_mut read functions.
Note that if you write through the returned reference, any padding bytes within the layout of T
(which for a repr(Rust) type is arbitrary and unknown) must thereafter be considered uninitialized
until you explicitly initialize them again. This means that if you write a T which contains
padding into slab, you must not, for example, try to read those bytes as &[u8] afterwards
(or as some other type which expects those bytes to be initialized), as you would then be
reading uninitialized memory, which is undefined behavior.
* Validity is a complex topic not to be taken lightly. See this rust reference page for more details.