Struct NamespaceFaultConfig

Source
pub struct NamespaceFaultConfig {
    pub recv_changed_namespace: Receiver<NamespaceChange>,
}
Expand description

A fault config to trigger spurious namespace change notifications from the controller.

The fault controller listens on the provided channel for notifications containing a u32 value representing the NSID (Namespace Identifier) that has changed. This does not actually modify the namespace; instead, it triggers the controller to process a namespace change notification. The fault is modeled as an RPC, which the controller completes once it has processed the change and sent the corresponding Asynchronous Event Notification (AEN). As per NVMe spec: If multiple namespace changes are notified, only the first triggers an AEN. Subsequent changes do not trigger additional AENs until the driver issues a GET_LOG_PAGE command. For implementation simplicity, namespace fault is not gated by the fault_active flag. Since only test code can send notifications on the fault channel, it is safe to bypass this check.

§Example

Send a namespace change notification for NSID 1 and wait for it to be processed.

use mesh::CellUpdater;
use nvme_resources::fault::NamespaceChange;
use nvme_resources::fault::FaultConfiguration;
use nvme_resources::fault::NamespaceFaultConfig;
use nvme_resources::NvmeFaultControllerHandle;
use guid::Guid;
use mesh::rpc::RpcSend;

pub async fn send_namespace_change_fault() {
    let mut fault_start_updater = CellUpdater::new(false);
    let (ns_change_send, ns_change_recv) = mesh::channel::<NamespaceChange>();
    let fault_configuration = FaultConfiguration::new(fault_start_updater.cell())
        .with_namespace_fault(
            NamespaceFaultConfig::new(ns_change_recv),
        );
    // Complete setup
    let fault_controller_handle = NvmeFaultControllerHandle {
        subsystem_id: Guid::new_random(),
        msix_count: 10,
        max_io_queues: 10,
        namespaces: vec![
            // Define `NamespaceDefinitions` here
        ],
        fault_config: fault_configuration,
    };

    // Send the namespace change notification and await processing.
    ns_change_send.call(NamespaceChange::ChangeNotification, 1).await.unwrap();
}

Fields§

§recv_changed_namespace: Receiver<NamespaceChange>

Receiver for changed namespace notifications

Implementations§

Source§

impl NamespaceFaultConfig

Source

pub fn new(recv_changed_namespace: Receiver<NamespaceChange>) -> Self

Creates a new NamespaceFaultConfig with a fresh channel.

Trait Implementations§

Source§

impl DefaultEncoding for NamespaceFaultConfig

Source§

type Encoding = TableEncoder

The encoding to use for the serialization. Read more
Source§

impl<'encoding> StructDecodeMetadata<'encoding, Resource> for NamespaceFaultConfig

Source§

const DECODERS: &'static [ErasedDecoderEntry]

The list of decoder vtables.
Source§

impl StructEncodeMetadata<Resource> for NamespaceFaultConfig

Source§

const ENCODERS: &'static [ErasedEncoderEntry]

The list of encoder vtables.
Source§

impl StructMetadata for NamespaceFaultConfig

Source§

const NUMBERS: &'static [u32]

The field numbers for each field.
Source§

const OFFSETS: &'static [usize]

The byte offset to each field within the struct.

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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.

§

impl<T> MeshField for T
where T: DefaultEncoding, <T as DefaultEncoding>::Encoding: FieldEncode<T, Resource> + for<'a> FieldDecode<'a, T, Resource> + Send + Sync,

§

type Encoding = <T as DefaultEncoding>::Encoding

§

impl<T> MeshPayload for T
where T: DefaultEncoding + Any + Send + 'static, <T as DefaultEncoding>::Encoding: MessageEncode<T, Resource> + for<'a> MessageDecode<'a, T, Resource> + FieldEncode<T, Resource> + for<'a> FieldDecode<'a, T, Resource> + Send + Sync,

§

type Encoding = <T as DefaultEncoding>::Encoding

§

impl<T> SerializeMessage for T
where T: 'static + MeshPayload + Send,

§

type Concrete = T

The underlying concrete message type.
§

fn compute_message_size(&mut self, sizer: MessageSizer<'_>)

Computes the message size, as in [MessageEncode::compute_message_size].
§

fn write_message(self, writer: MessageWriter<'_, '_, Resource>)

Writes the message, as in [MessageEncode::write_message].
§

fn extract(self) -> <T as SerializeMessage>::Concrete

Extract the concrete message.
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.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more