Skip to main content

MemoryManagerRangeAuthority

Struct MemoryManagerRangeAuthority 

Source
pub struct MemoryManagerRangeAuthority { /* private fields */ }
Expand description

MemoryManagerRangeAuthority

Substrate-specific range authority policy helper for MemoryManager IDs.

This helper records policy and diagnostic authority ranges only. It never mutates the allocation ledger, and it does not allocate or reserve durable stable-memory slots. Durable allocation remains the generic ledger mapping from stable key to allocation slot.

When used through the default runtime registry, registered ranges are authoritative generic policy and are checked before caller-supplied crate::AllocationPolicy. Frameworks that want their own policy to own application space should avoid registering ranges for that space.

Implementations§

Source§

impl MemoryManagerRangeAuthority

Source

pub const fn new() -> Self

Create an empty MemoryManager range authority policy.

Source

pub fn from_records( records: Vec<MemoryManagerAuthorityRecord>, ) -> Result<Self, MemoryManagerRangeAuthorityError>

Build a range authority from diagnostic records.

Records are validated with the same rules as the builder methods and stored in ascending range order.

Source

pub fn reserve( self, range: MemoryManagerIdRange, authority: impl Into<String>, ) -> Result<Self, MemoryManagerRangeAuthorityError>

Add a reserved authority range.

Reserved is a policy authority mode. It does not allocate every ID in the range and does not write to the allocation ledger.

Source

pub fn reserve_ids( self, start: u8, end: u8, authority: impl Into<String>, ) -> Result<Self, MemoryManagerRangeAuthorityError>

Add a reserved authority range from inclusive ID bounds.

Reserved is a policy authority mode. It does not allocate every ID in the range and does not write to the allocation ledger.

Source

pub fn reserve_with_purpose( self, range: MemoryManagerIdRange, authority: impl Into<String>, purpose: Option<String>, ) -> Result<Self, MemoryManagerRangeAuthorityError>

Add a reserved authority range with a diagnostic purpose.

Reserved is a policy authority mode. It does not allocate every ID in the range and does not write to the allocation ledger.

Source

pub fn reserve_ids_with_purpose( self, start: u8, end: u8, authority: impl Into<String>, purpose: Option<String>, ) -> Result<Self, MemoryManagerRangeAuthorityError>

Add a reserved authority range from inclusive ID bounds with a diagnostic purpose.

Reserved is a policy authority mode. It does not allocate every ID in the range and does not write to the allocation ledger.

Source

pub fn allow( self, range: MemoryManagerIdRange, authority: impl Into<String>, ) -> Result<Self, MemoryManagerRangeAuthorityError>

Add an allowed authority range.

Allowed is a policy authority mode. It does not allocate any ID in the range and does not write to the allocation ledger.

Source

pub fn allow_ids( self, start: u8, end: u8, authority: impl Into<String>, ) -> Result<Self, MemoryManagerRangeAuthorityError>

Add an allowed authority range from inclusive ID bounds.

Allowed is a policy authority mode. It does not allocate any ID in the range and does not write to the allocation ledger.

Source

pub fn allow_with_purpose( self, range: MemoryManagerIdRange, authority: impl Into<String>, purpose: Option<String>, ) -> Result<Self, MemoryManagerRangeAuthorityError>

Add an allowed authority range with a diagnostic purpose.

Allowed is a policy authority mode. It does not allocate any ID in the range and does not write to the allocation ledger.

Source

pub fn allow_ids_with_purpose( self, start: u8, end: u8, authority: impl Into<String>, purpose: Option<String>, ) -> Result<Self, MemoryManagerRangeAuthorityError>

Add an allowed authority range from inclusive ID bounds with a diagnostic purpose.

Allowed is a policy authority mode. It does not allocate any ID in the range and does not write to the allocation ledger.

Source

pub fn validate_slot_authority( &self, slot: &AllocationSlotDescriptor, expected_authority: &str, ) -> Result<&MemoryManagerAuthorityRecord, MemoryManagerRangeAuthorityError>

Validate that slot belongs to expected_authority.

Source

pub fn validate_slot_authority_mode( &self, slot: &AllocationSlotDescriptor, expected_authority: &str, expected_mode: MemoryManagerRangeMode, ) -> Result<&MemoryManagerAuthorityRecord, MemoryManagerRangeAuthorityError>

Validate that slot belongs to expected_authority with expected_mode.

Source

pub fn validate_id_authority( &self, id: u8, expected_authority: &str, ) -> Result<&MemoryManagerAuthorityRecord, MemoryManagerRangeAuthorityError>

Validate that id belongs to expected_authority.

Source

pub fn validate_id_authority_mode( &self, id: u8, expected_authority: &str, expected_mode: MemoryManagerRangeMode, ) -> Result<&MemoryManagerAuthorityRecord, MemoryManagerRangeAuthorityError>

Validate that id belongs to expected_authority with expected_mode.

Source

pub fn authority_for_id( &self, id: u8, ) -> Result<Option<&MemoryManagerAuthorityRecord>, MemoryManagerRangeAuthorityError>

Return the authority record that governs id, if any.

Source

pub fn authorities(&self) -> &[MemoryManagerAuthorityRecord]

Ordered non-overlapping authority records.

This is the stable diagnostic/export surface for the authority table. Records are returned in ascending range order and do not imply ledger allocation state.

Source

pub fn validate_complete_coverage( &self, target: MemoryManagerIdRange, ) -> Result<(), MemoryManagerRangeAuthorityError>

Validate that authority records exactly and contiguously cover target.

All records must be inside target, and together they must form a gap-free partition. This checks policy table coverage only and never changes allocation ledger state.

Trait Implementations§

Source§

impl Clone for MemoryManagerRangeAuthority

Source§

fn clone(&self) -> MemoryManagerRangeAuthority

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for MemoryManagerRangeAuthority

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for MemoryManagerRangeAuthority

Source§

fn default() -> MemoryManagerRangeAuthority

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for MemoryManagerRangeAuthority

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl PartialEq for MemoryManagerRangeAuthority

Source§

fn eq(&self, other: &MemoryManagerRangeAuthority) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for MemoryManagerRangeAuthority

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for MemoryManagerRangeAuthority

Source§

impl StructuralPartialEq for MemoryManagerRangeAuthority

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,