Macro map_field

Source
macro_rules! map_field {
    ($abstract_ptr:ident.$($place:ident).+) => { ... };
}
Expand description

Provides safe field projection for abstract pointers referencing structs.

§Examples

Accessing a struct field:

use sel4_abstract_ptr::{AbstractPtr, map_field};

struct Example { field_1: u32, field_2: u8, }
let mut value = Example { field_1: 15, field_2: 255 };
let ptr = unsafe { AbstractPtr::new((&mut value).into()) };

// construct an abstract reference to a field
let field_2 = map_field!(ptr.field_2);
assert_eq!(field_2.read(), 255);

Creating AbstractPtrs to unaligned field in packed structs is not allowed:

use sel4_abstract_ptr::{AbstractPtr, map_field};

#[repr(packed)]
struct Example { field_1: u8, field_2: usize, }
let mut value = Example { field_1: 15, field_2: 255 };
let ptr = unsafe { AbstractPtr::new((&mut value).into()) };

// Constructing an abstract reference to an unaligned field doesn't compile.
let field_2 = map_field!(ptr.field_2);