pub struct Bist(/* private fields */);
Expand description
Built-In Self Test (BIST) register.
Implementations§
Source§impl Bist
impl Bist
Sourcepub const COMPLETION_CODE: Pack8<u8, Self>
pub const COMPLETION_CODE: Pack8<u8, Self>
The completion code set by running a built-in self test.
If the test completed successfully, this should be 0.
Sourcepub const START_BIST: Pack8<bool, Self>
pub const START_BIST: Pack8<bool, Self>
Start BIST
Set to 1 by the OS to start a BIST. This bit is reset when BIST completes. If BIST does not complete after 2 seconds the device should be failed by system software.
Sourcepub const BIST_CAPABLE: Pack8<bool, Self>
pub const BIST_CAPABLE: Pack8<bool, Self>
BIST Capable
If this is 1, the device supports BIST. If it is 0, this device does not support a built-in self test.
Sourcepub const fn from_bits(bits: u8) -> Self
pub const fn from_bits(bits: u8) -> Self
Constructs a new instance of Self
from the provided raw bits.
Sourcepub fn with<T>(self, field: Pack8<T, Self>, value: T) -> Self
pub fn with<T>(self, field: Pack8<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: Pack8<T, Self>, value: T) -> &mut Self
pub fn set<T>(&mut self, field: Pack8<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: Pack8<T, Self>) -> T
pub fn get<T>(self, field: Pack8<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: Pack8<T, Self>) -> Result<T, T::Error>
pub fn try_get<T>(self, field: Pack8<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.