pub struct Status { /* private fields */ }
Expand description
Pci device status.
Implementations§
source§impl Status
impl Status
sourcepub const DETECTED_PARITY_ERROR: Self = _
pub const DETECTED_PARITY_ERROR: Self = _
This bit will be set to 1 whenever the device detects a parity error, even if parity error handling is disabled.
sourcepub const SIGNALLED_SYSTEM_ERROR: Self = _
pub const SIGNALLED_SYSTEM_ERROR: Self = _
This bit will be set to 1 whenever the device asserts SERR#.
sourcepub const RECEIVED_MASTER_ABORT: Self = _
pub const RECEIVED_MASTER_ABORT: Self = _
This bit will be set to 1, by a master device, whenever its transaction (except for Special Cycle transactions) is terminated with Master-Abort.
sourcepub const RECEIVED_TARGET_ABORT: Self = _
pub const RECEIVED_TARGET_ABORT: Self = _
This bit will be set to 1, by a master device, whenever its transaction is terminated with Target-Abort.
sourcepub const SIGNALLED_TARGET_ABORT: Self = _
pub const SIGNALLED_TARGET_ABORT: Self = _
This bit will be set to 1 whenever a target device terminates a transaction with Target-Abort.
sourcepub const DEVSEL_TIMING: Self = _
pub const DEVSEL_TIMING: Self = _
Read only bits that represent the slowest time that a device will assert DEVSEL# for any bus command except Configuration Space read and writes. Where a value of 0x00 represents fast timing, a value of 0x01 represents medium timing, and a value of 0x02 represents slow timing.
sourcepub const MASTER_DATA_PARITY_ERROR: Self = _
pub const MASTER_DATA_PARITY_ERROR: Self = _
This bit is only set when the following conditions are met. The bus agent asserted PERR# on a read or observed an assertion of PERR# on a write, the agent setting the bit acted as the bus master for the operation in which the error occurred, and bit 6 of the Command register (Parity Error Response bit) is set to 1.
sourcepub const FAST_BACK_TO_BACK_CAPABLE: Self = _
pub const FAST_BACK_TO_BACK_CAPABLE: Self = _
If set to 1 the device can accept fast back-to-back transactions that are not from the same agent; otherwise, transactions can only be accepted from the same agent.
sourcepub const MHZ66_CAPABLE: Self = _
pub const MHZ66_CAPABLE: Self = _
If set to 1 the device is capable of running at 66 MHz; otherwise, the device runs at 33 MHz.
sourcepub const CAPABILITIES_LIST: Self = _
pub const CAPABILITIES_LIST: Self = _
If set to 1 the device implements the pointer for a New Capabilities Linked list at offset 0x34; otherwise, the linked list is not available.
sourcepub const INTERRUPT_STATUS: Self = _
pub const INTERRUPT_STATUS: Self = _
Represents the state of the device’s INTx# signal. If set to 1 and bit 10 of the Command register (Interrupt Disable bit) is set to 0 the signal will be asserted; otherwise, the signal will be ignored
sourcepub const fn from_bits(bits: u16) -> Option<Self>
pub const fn from_bits(bits: u16) -> Option<Self>
Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.
sourcepub const fn from_bits_truncate(bits: u16) -> Self
pub const fn from_bits_truncate(bits: u16) -> Self
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
sourcepub const unsafe fn from_bits_unchecked(bits: u16) -> Self
pub const unsafe fn from_bits_unchecked(bits: u16) -> Self
Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).
Safety
The caller of the bitflags!
macro can chose to allow or
disallow extra bits for their bitflags type.
The caller of from_bits_unchecked()
has to ensure that
all bits correspond to a defined flag or that extra bits
are valid for this bitflags type.
sourcepub const fn intersects(&self, other: Self) -> bool
pub const fn intersects(&self, other: Self) -> bool
Returns true
if there are flags common to both self
and other
.
sourcepub const fn contains(&self, other: Self) -> bool
pub const fn contains(&self, other: Self) -> bool
Returns true
if all of the flags in other
are contained within self
.
sourcepub fn set(&mut self, other: Self, value: bool)
pub fn set(&mut self, other: Self, value: bool)
Inserts or removes the specified flags depending on the passed value.
sourcepub const fn intersection(self, other: Self) -> Self
pub const fn intersection(self, other: Self) -> Self
Returns the intersection between the flags in self
and
other
.
Specifically, the returned set contains only the flags which are
present in both self
and other
.
This is equivalent to using the &
operator (e.g.
ops::BitAnd
), as in flags & other
.
sourcepub const fn union(self, other: Self) -> Self
pub const fn union(self, other: Self) -> Self
Returns the union of between the flags in self
and other
.
Specifically, the returned set contains all flags which are
present in either self
or other
, including any which are
present in both (see Self::symmetric_difference
if that
is undesirable).
This is equivalent to using the |
operator (e.g.
ops::BitOr
), as in flags | other
.
sourcepub const fn difference(self, other: Self) -> Self
pub const fn difference(self, other: Self) -> Self
Returns the difference between the flags in self
and other
.
Specifically, the returned set contains all flags present in
self
, except for the ones present in other
.
It is also conceptually equivalent to the “bit-clear” operation:
flags & !other
(and this syntax is also supported).
This is equivalent to using the -
operator (e.g.
ops::Sub
), as in flags - other
.
sourcepub const fn symmetric_difference(self, other: Self) -> Self
pub const fn symmetric_difference(self, other: Self) -> Self
Returns the symmetric difference between the flags
in self
and other
.
Specifically, the returned set contains the flags present which
are present in self
or other
, but that are not present in
both. Equivalently, it contains the flags present in exactly
one of the sets self
and other
.
This is equivalent to using the ^
operator (e.g.
ops::BitXor
), as in flags ^ other
.
sourcepub const fn complement(self) -> Self
pub const fn complement(self) -> Self
Returns the complement of this set of flags.
Specifically, the returned set contains all the flags which are
not set in self
, but which are allowed for this type.
Alternatively, it can be thought of as the set difference
between Self::all()
and self
(e.g. Self::all() - self
)
This is equivalent to using the !
operator (e.g.
ops::Not
), as in !flags
.
Trait Implementations§
source§impl BitAndAssign<Status> for Status
impl BitAndAssign<Status> for Status
source§fn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
Disables all flags disabled in the set.
source§impl BitOrAssign<Status> for Status
impl BitOrAssign<Status> for Status
source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
source§impl BitXorAssign<Status> for Status
impl BitXorAssign<Status> for Status
source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
source§impl Extend<Status> for Status
impl Extend<Status> for Status
source§fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one
)§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one
)source§impl Ord for Status
impl Ord for Status
source§impl PartialOrd<Status> for Status
impl PartialOrd<Status> for Status
source§impl SubAssign<Status> for Status
impl SubAssign<Status> for Status
source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.