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.