pub struct ErrorStatus(/* private fields */);
Expand description
Value of the Error Status Register (ESR).
See Intel SDM Vol. 3A, Ch. 7, Section 12.5.3, “Error Handling”.
Implementations§
Source§impl ErrorStatus
impl ErrorStatus
Sourcepub const SEND_CHECKSUM_ERROR: Pack32<bool, Self>
pub const SEND_CHECKSUM_ERROR: Pack32<bool, Self>
Set when the local APIC detects a checksum error for a message that it sent on the APIC bus.
Used only on P6 family and Pentium processors.
Sourcepub const RECV_CHECKSUM_ERROR: Pack32<bool, Self>
pub const RECV_CHECKSUM_ERROR: Pack32<bool, Self>
Set when the local APIC detects a checksum error for a message that it received on the APIC bus.
Used only on P6 family and Pentium processors.
Sourcepub const SEND_ACCEPT_ERROR: Pack32<bool, Self>
pub const SEND_ACCEPT_ERROR: Pack32<bool, Self>
Set when the local APIC detects that a message it sent was not accepted by any APIC on the APIC bus
Used only on P6 family and Pentium processors.
Sourcepub const RECV_ACCEPT_ERROR: Pack32<bool, Self>
pub const RECV_ACCEPT_ERROR: Pack32<bool, Self>
Set when the local APIC detects that a message it received was not accepted by any APIC on the APIC bus.
Used only on P6 family and Pentium processors.
Sourcepub const REDIRECTABLE_IPI: Pack32<bool, Self>
pub const REDIRECTABLE_IPI: Pack32<bool, Self>
Set when the local APIC detects an attempt to send an IPI with the lowest-priority delivery mode and the local APIC does not support the sending of such IPIs. This bit is used on some Intel Core and Intel Xeon processors.
Sourcepub const SEND_ILLEGAL_VECTOR: Pack32<bool, Self>
pub const SEND_ILLEGAL_VECTOR: Pack32<bool, Self>
Set when the local APIC detects an illegal vector (one in the range 0 to 15) in the message that it is sending. This occurs as the result of a write to the ICR (in both xAPIC and x2APIC modes) or to SELF IPI register (x2APIC mode only) with an illegal vector.
If the local APIC does not support the sending of lowest-priority IPIs and software writes the ICR to send a lowest-priority IPI with an illegal vector, the local APIC sets only the “redirectable IPI” error bit. The interrupt is not processed and hence the “Send Illegal Vector” bit is not set in the ESR.
Sourcepub const RECV_ILLEGAL_VECTOR: Pack32<bool, Self>
pub const RECV_ILLEGAL_VECTOR: Pack32<bool, Self>
Set when the local APIC detects an illegal vector (one in the range 0 to 15) in an interrupt message it receives or in an interrupt generated locally from the local vector table or via a self IPI. Such interrupts are not delivered to the processor; the local APIC will never set an IRR bit in the range 0 to 15.
Sourcepub const ILLEGAL_REGISTER_ACCESS: Pack32<bool, Self>
pub const ILLEGAL_REGISTER_ACCESS: Pack32<bool, Self>
Set when the local APIC is in xAPIC mode and software attempts
to access a register that is reserved in the processor’s
local-APIC register-address space; see Table 10-1. (The
local-APIC register-address spacemprises the 4 KBytes at the
physical address specified in the IA32_APIC_BASE
MSR.) Used only
on Intel Core, Intel Atom, Pentium 4, Intel Xeon, and P6 family
processors.
In x2APIC mode, software accesses the APIC registers using the
RDMSR
and WRMSR
instructions. Use of one of these
instructions to access a reserved register cause a
general-protection exception (see Section 10.12.1.3). They do
not set the “Illegal Register Access” bit in the ESR.
Sourcepub const fn from_bits(bits: u32) -> Self
pub const fn from_bits(bits: u32) -> Self
Constructs a new instance of Self
from the provided raw bits.
Sourcepub fn with<T>(self, field: Pack32<T, Self>, value: T) -> Self
pub fn with<T>(self, field: Pack32<T, Self>, value: T) -> Self
Packs the bit representation of value
into self
at the bit
range designated by field
, returning a new bitfield.
Sourcepub fn set<T>(&mut self, field: Pack32<T, Self>, value: T) -> &mut Self
pub fn set<T>(&mut self, field: Pack32<T, Self>, value: T) -> &mut Self
Packs the bit representation of value
into self
at the range
designated by field
, mutating self
in place.
Sourcepub fn get<T>(self, field: Pack32<T, Self>) -> T
pub fn get<T>(self, field: Pack32<T, Self>) -> T
Unpacks the bit range represented by field
from self
, and
converts it into a T
-typed value.
§Panics
This method panics if self
does not contain a valid bit
pattern for a T
-typed value, as determined by T
’s
FromBits::try_from_bits
implementation.
Sourcepub fn try_get<T>(self, field: Pack32<T, Self>) -> Result<T, T::Error>
pub fn try_get<T>(self, field: Pack32<T, Self>) -> Result<T, T::Error>
Unpacks the bit range represented by field
from self
and attempts to convert it into a T
-typed value.
§Returns
Ok(T)
if aT
-typed value could be constructed from the bits insrc
Err(T::Error)
ifsrc
does not contain a valid bit pattern for aT
-typed value, as determined byT
’s [FromBits::try_from_bits
implementation.
Sourcepub fn assert_valid()
pub fn assert_valid()
Asserts that all the packing specs for this type are valid.
This is intended to be used in unit tests.
Sourcepub fn display_ascii(&self) -> impl Display
pub fn display_ascii(&self) -> impl Display
Returns a value that formats this bitfield in a multi-line format, using only ASCII characters.
This is equivalent to formatting this bitfield using a {}
display specifier, but will never use Unicode box-drawing
characters, even when an upstream formatter uses the {:#}
fmt::Display
specifier. This is intended for use on platforms
where Unicode box drawing characters are never available.
Sourcepub fn display_unicode(&self) -> impl Display
pub fn display_unicode(&self) -> impl Display
Returns a value that formats this bitfield in a multi-line format, always using Unicode box-drawing characters.
This is equivalent to formatting this bitfield using a {:#}
format specifier, but will always use Unicode box-drawing
characters, even when an upstream formatter uses the {}
fmt::Display
specifier.
Trait Implementations§
Source§impl Binary for ErrorStatus
impl Binary for ErrorStatus
Source§impl Clone for ErrorStatus
impl Clone for ErrorStatus
Source§fn clone(&self) -> ErrorStatus
fn clone(&self) -> ErrorStatus
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more