underhill_config

Enum Vtl2SettingsErrorCode

Source
pub enum Vtl2SettingsErrorCode {
Show 37 variants InternalFailure, JsonFormatError, NoVmbusServer, UnsupportedSchemaVersion, InvalidInstanceId, ProtobufFormatError, UnsupportedSchemaNamespace, EmptyNamespaceChunk, StorageCannotAddRemoveControllerAtRuntime, StorageLunLocationExceedsMaxLimits, StorageLunLocationDuplicated, StorageUnsupportedDeviceType, StorageCannotFindVtl2Device, EmptyDriveNotAllowed, StorageCannotOpenVtl2Device, StorageScsiControllerNotFound, StorageAttachDiskFailed, StorageRmDiskFailed, StorageControllerGuidAlreadyExists, StorageScsiControllerExceedsMaxLimits, StorageInvalidVendorId, StorageInvalidProductId, StorageInvalidProductRevisionLevel, StorageIdeChannelNotProvided, StorageIdeChannelExceedsMaxLimits, StorageIdeLocationExceedsMaxLimits, StorageIdeChannelInvalidConfiguration, StripedStorageCannotChangeControllerAtRuntime, StorageInvalidPhysicalDiskCount, StorageCannotModifyIdeAtRuntime, StorageInvalidControllerType, StorageInvalidDeviceId, StorageChangeMediaFailed, StorageInvalidNtfsFormatGuid, NetworkingModifyNicFailed, NetworkingAddNicFailed, NetworkingRemoveNicFailed,
}
Expand description

The error codes used for failures when parsing or acting on a VTL2 settings document from the host.

These are used to provide an identifier that the host can match on, as well as some error categorization. Additional (string) error context can be provided in Vtl2SettingsErrorInfo.

This table is in the form name => (component, category). component and category must be elements in the Component and EscalationCategory enums, respectively.

Note that the values of name, component, and category are encoded into a form sent to the host, and so changing them for an error may be a breaking change.

Specifically, they are encoded into a string as category.name. The astute reader will note that the component is not actually used in the error message, or anywhere. FUTURE: remove the component, or include it as a separate field in the JSON.

In any case, the Rust-assigned discriminant values are not used in error messages and do not need to be stable.

Variants§

§

InternalFailure

Underhill internal failure

§

JsonFormatError

Invalid JSON format

§

NoVmbusServer

VM Bus server is not configured

§

UnsupportedSchemaVersion

Unsupported schema version

§

InvalidInstanceId

Invalid vmbus instance ID

§

ProtobufFormatError

Invalid protobuf format

§

UnsupportedSchemaNamespace

Unsupported schema namespace

§

EmptyNamespaceChunk

Empty namespace chunk

§

StorageCannotAddRemoveControllerAtRuntime

Change storage controller at runtime

§

StorageLunLocationExceedsMaxLimits

SCSI LUN exceeds max limits (64)

§

StorageLunLocationDuplicated

SCSI LUN location duplicated in configuration

§

StorageUnsupportedDeviceType

Unsupported device type in configuration

§

StorageCannotFindVtl2Device

Cannot find NVMe device namespace /dev/nvmen

§

EmptyDriveNotAllowed

Hard drive cannot be empty

§

StorageCannotOpenVtl2Device

Cannot open VTL2 block device

§

StorageScsiControllerNotFound

Cannot find a given SCSI controller

§

StorageAttachDiskFailed

Failed to attack a disk to a controller

§

StorageRmDiskFailed

Failed to remove a disk from a controller

§

StorageControllerGuidAlreadyExists

Storage controller already exists

§

StorageScsiControllerExceedsMaxLimits

SCSI controller exceeds max limits (4)

§

StorageInvalidVendorId

Invalid vendor ID

§

StorageInvalidProductId

Invalid product ID

§

StorageInvalidProductRevisionLevel

Invalid product revision level

§

StorageIdeChannelNotProvided

IDE channel is not provided

§

StorageIdeChannelExceedsMaxLimits

IDE channel exceeds max limits (0 or 1)

§

StorageIdeLocationExceedsMaxLimits

IDE location exceeds max limits (0 or 1)

§

StorageIdeChannelInvalidConfiguration

IDE configuration is invalid

§

StripedStorageCannotChangeControllerAtRuntime

Cannot change storage controller with striped devices at runtime

§

StorageInvalidPhysicalDiskCount

Invalid physical disk count

§

StorageCannotModifyIdeAtRuntime

Cannot modify IDE devices at runtime

§

StorageInvalidControllerType

Invalid controller type

§

StorageInvalidDeviceId

Invalid vendor ID

§

StorageChangeMediaFailed

Failed to change media on a controller

§

StorageInvalidNtfsFormatGuid

Invalid NTFS format guid

§

NetworkingModifyNicFailed

Failed to modify NIC

§

NetworkingAddNicFailed

Failed to add NIC

§

NetworkingRemoveNicFailed

Failed to remove NIC

Trait Implementations§

Source§

impl Clone for Vtl2SettingsErrorCode

Source§

fn clone(&self) -> Vtl2SettingsErrorCode

Returns a copy of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Vtl2SettingsErrorCode

Source§

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

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

impl PartialEq for Vtl2SettingsErrorCode

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · 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 Vtl2SettingsErrorCode

Source§

fn serialize<S: Serializer>(&self, ser: S) -> Result<S::Ok, S::Error>

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

impl Copy for Vtl2SettingsErrorCode

Source§

impl StructuralPartialEq for Vtl2SettingsErrorCode

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, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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.

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.
§

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