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, Bist>
pub const COMPLETION_CODE: Pack8<u8, Bist>
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, Bist>
pub const START_BIST: Pack8<bool, Bist>
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, Bist>
pub const BIST_CAPABLE: Pack8<bool, Bist>
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) -> Bist
pub const fn from_bits(bits: u8) -> Bist
Constructs a new instance of Self
from the provided raw bits.
Sourcepub fn with<T>(self, field: Pack8<T, Bist>, value: T) -> Bist
pub fn with<T>(self, field: Pack8<T, Bist>, value: T) -> Bist
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, Bist>, value: T) -> &mut Bist
pub fn set<T>(&mut self, field: Pack8<T, Bist>, value: T) -> &mut Bist
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, Bist>) -> T
pub fn get<T>(self, field: Pack8<T, Bist>) -> 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, Bist>,
) -> Result<T, <T as FromBits<u8>>::Error>
pub fn try_get<T>( self, field: Pack8<T, Bist>, ) -> Result<T, <T as FromBits<u8>>::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§
impl Copy for Bist
impl Eq for Bist
impl StructuralPartialEq for Bist
Auto Trait Implementations§
impl Freeze for Bist
impl RefUnwindSafe for Bist
impl Send for Bist
impl Sync for Bist
impl Unpin for Bist
impl UnwindSafe for Bist
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CheckedAs for T
impl<T> CheckedAs for T
Source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
Source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
Source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.