Struct BlockDeviceFlag
pub struct BlockDeviceFlag(/* private fields */);Implementations§
§impl DeviceFlag
impl DeviceFlag
pub const READONLY: DeviceFlag
pub const READONLY: DeviceFlag
All writes to the block device will fail.
pub const REMOVABLE: DeviceFlag
pub const REMOVABLE: DeviceFlag
The block device may be removed from the device during operation.
pub const TRIM_SUPPORT: DeviceFlag
pub const TRIM_SUPPORT: DeviceFlag
The device provides trim support.
pub const FUA_SUPPORT: DeviceFlag
pub const FUA_SUPPORT: DeviceFlag
The device provides Force Unit Access (FUA) support.
If this bit is unset, and a request is sent with the FORCE_ACCESS option set, the device will simulate a FUA by executing a device flush after the request completes (but before responding to the client). Clients are strongly encouraged to probe for FUA support and avoid usage of FORCE_ACCESS without device support, since this is expensive.
pub const ZSTD_DECOMPRESSION_SUPPORT: DeviceFlag
pub const ZSTD_DECOMPRESSION_SUPPORT: DeviceFlag
The device provides zstd decompression support.
pub const BARRIER_SUPPORT: DeviceFlag
pub const BARRIER_SUPPORT: DeviceFlag
The device provides Barrier support.
If this bit is unset, and a request is sent with the PRE_BARRIER option set, the device will simulate a barrier by executing a device flush before the request is submitted. Clients are strongly encouraged to probe for barrier support and avoid usage of PRE_BARRIER without device support, since this is expensive.
§impl DeviceFlag
impl DeviceFlag
pub const fn empty() -> DeviceFlag
pub const fn empty() -> DeviceFlag
Get a flags value with all bits unset.
pub const fn all() -> DeviceFlag
pub const fn all() -> DeviceFlag
Get a flags value with all known bits set.
pub const fn bits(&self) -> u32
pub const fn bits(&self) -> u32
Get the underlying bits value.
The returned value is exactly the bits set in this flags value.
pub const fn from_bits(bits: u32) -> Option<DeviceFlag>
pub const fn from_bits(bits: u32) -> Option<DeviceFlag>
Convert from a bits value.
This method will return None if any unknown bits are set.
pub const fn from_bits_truncate(bits: u32) -> DeviceFlag
pub const fn from_bits_truncate(bits: u32) -> DeviceFlag
Convert from a bits value, unsetting any unknown bits.
pub const fn from_bits_retain(bits: u32) -> DeviceFlag
pub const fn from_bits_retain(bits: u32) -> DeviceFlag
Convert from a bits value exactly.
pub fn from_name(name: &str) -> Option<DeviceFlag>
pub fn from_name(name: &str) -> Option<DeviceFlag>
Get a flags value with the bits of a flag with the given name set.
This method will return None if name is empty or doesn’t
correspond to any named flag.
pub const fn intersects(&self, other: DeviceFlag) -> bool
pub const fn intersects(&self, other: DeviceFlag) -> bool
Whether any set bits in a source flags value are also set in a target flags value.
pub const fn contains(&self, other: DeviceFlag) -> bool
pub const fn contains(&self, other: DeviceFlag) -> bool
Whether all set bits in a source flags value are also set in a target flags value.
pub fn insert(&mut self, other: DeviceFlag)
pub fn insert(&mut self, other: DeviceFlag)
The bitwise or (|) of the bits in two flags values.
pub fn remove(&mut self, other: DeviceFlag)
pub fn remove(&mut self, other: DeviceFlag)
The intersection of a source flags value with the complement of a target flags value (&!).
This method is not equivalent to self & !other when other has unknown bits set.
remove won’t truncate other, but the ! operator will.
pub fn toggle(&mut self, other: DeviceFlag)
pub fn toggle(&mut self, other: DeviceFlag)
The bitwise exclusive-or (^) of the bits in two flags values.
pub fn set(&mut self, other: DeviceFlag, value: bool)
pub fn set(&mut self, other: DeviceFlag, value: bool)
Call insert when value is true or remove when value is false.
pub const fn intersection(self, other: DeviceFlag) -> DeviceFlag
pub const fn intersection(self, other: DeviceFlag) -> DeviceFlag
The bitwise and (&) of the bits in two flags values.
pub const fn union(self, other: DeviceFlag) -> DeviceFlag
pub const fn union(self, other: DeviceFlag) -> DeviceFlag
The bitwise or (|) of the bits in two flags values.
pub const fn difference(self, other: DeviceFlag) -> DeviceFlag
pub const fn difference(self, other: DeviceFlag) -> DeviceFlag
The intersection of a source flags value with the complement of a target flags value (&!).
This method is not equivalent to self & !other when other has unknown bits set.
difference won’t truncate other, but the ! operator will.
pub const fn symmetric_difference(self, other: DeviceFlag) -> DeviceFlag
pub const fn symmetric_difference(self, other: DeviceFlag) -> DeviceFlag
The bitwise exclusive-or (^) of the bits in two flags values.
pub const fn complement(self) -> DeviceFlag
pub const fn complement(self) -> DeviceFlag
The bitwise negation (!) of the bits in a flags value, truncating the result.
§impl DeviceFlag
impl DeviceFlag
pub const fn iter(&self) -> Iter<DeviceFlag>
pub const fn iter(&self) -> Iter<DeviceFlag>
Yield a set of contained flags values.
Each yielded flags value will correspond to a defined named flag. Any unknown bits will be yielded together as a final flags value.
pub const fn iter_names(&self) -> IterNames<DeviceFlag>
pub const fn iter_names(&self) -> IterNames<DeviceFlag>
Yield a set of contained named flags values.
This method is like iter, except only yields bits in contained named flags.
Any unknown bits, or bits not corresponding to a contained flag will not be yielded.
Trait Implementations§
§impl Binary for DeviceFlag
impl Binary for DeviceFlag
§impl BitAnd for DeviceFlag
impl BitAnd for DeviceFlag
§fn bitand(self, other: DeviceFlag) -> DeviceFlag
fn bitand(self, other: DeviceFlag) -> DeviceFlag
The bitwise and (&) of the bits in two flags values.
§type Output = DeviceFlag
type Output = DeviceFlag
& operator.§impl BitAndAssign for DeviceFlag
impl BitAndAssign for DeviceFlag
§fn bitand_assign(&mut self, other: DeviceFlag)
fn bitand_assign(&mut self, other: DeviceFlag)
The bitwise and (&) of the bits in two flags values.
§impl BitOr for DeviceFlag
impl BitOr for DeviceFlag
§fn bitor(self, other: DeviceFlag) -> DeviceFlag
fn bitor(self, other: DeviceFlag) -> DeviceFlag
The bitwise or (|) of the bits in two flags values.
§type Output = DeviceFlag
type Output = DeviceFlag
| operator.§impl BitOrAssign for DeviceFlag
impl BitOrAssign for DeviceFlag
§fn bitor_assign(&mut self, other: DeviceFlag)
fn bitor_assign(&mut self, other: DeviceFlag)
The bitwise or (|) of the bits in two flags values.
§impl BitXor for DeviceFlag
impl BitXor for DeviceFlag
§fn bitxor(self, other: DeviceFlag) -> DeviceFlag
fn bitxor(self, other: DeviceFlag) -> DeviceFlag
The bitwise exclusive-or (^) of the bits in two flags values.
§type Output = DeviceFlag
type Output = DeviceFlag
^ operator.§impl BitXorAssign for DeviceFlag
impl BitXorAssign for DeviceFlag
§fn bitxor_assign(&mut self, other: DeviceFlag)
fn bitxor_assign(&mut self, other: DeviceFlag)
The bitwise exclusive-or (^) of the bits in two flags values.
§impl Clone for DeviceFlag
impl Clone for DeviceFlag
§fn clone(&self) -> DeviceFlag
fn clone(&self) -> DeviceFlag
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more§impl Debug for DeviceFlag
impl Debug for DeviceFlag
§impl<D> Decode<DeviceFlag, D> for DeviceFlagwhere
D: ResourceDialect,
impl<D> Decode<DeviceFlag, D> for DeviceFlagwhere
D: ResourceDialect,
§fn new_empty() -> DeviceFlag
fn new_empty() -> DeviceFlag
Self. The specific value does not matter,
since it will be overwritten by decode.§impl Default for DeviceFlag
impl Default for DeviceFlag
§fn default() -> DeviceFlag
fn default() -> DeviceFlag
§impl<D> Encode<DeviceFlag, D> for DeviceFlagwhere
D: ResourceDialect,
impl<D> Encode<DeviceFlag, D> for DeviceFlagwhere
D: ResourceDialect,
§impl Extend<DeviceFlag> for DeviceFlag
impl Extend<DeviceFlag> for DeviceFlag
§fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = DeviceFlag>,
fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = DeviceFlag>,
The bitwise or (|) of the bits in each flags value.
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one)Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one)§impl Flags for DeviceFlag
impl Flags for DeviceFlag
§const FLAGS: &'static [Flag<DeviceFlag>]
const FLAGS: &'static [Flag<DeviceFlag>]
§fn from_bits_retain(bits: u32) -> DeviceFlag
fn from_bits_retain(bits: u32) -> DeviceFlag
§fn contains_unknown_bits(&self) -> bool
fn contains_unknown_bits(&self) -> bool
true if any unknown bits are set.§fn from_bits_truncate(bits: Self::Bits) -> Self
fn from_bits_truncate(bits: Self::Bits) -> Self
§fn from_name(name: &str) -> Option<Self>
fn from_name(name: &str) -> Option<Self>
§fn iter_names(&self) -> IterNames<Self>
fn iter_names(&self) -> IterNames<Self>
§fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
§fn contains(&self, other: Self) -> boolwhere
Self: Sized,
fn contains(&self, other: Self) -> boolwhere
Self: Sized,
§fn insert(&mut self, other: Self)where
Self: Sized,
fn insert(&mut self, other: Self)where
Self: Sized,
|) of the bits in two flags values.§fn remove(&mut self, other: Self)where
Self: Sized,
fn remove(&mut self, other: Self)where
Self: Sized,
&!). Read more§fn toggle(&mut self, other: Self)where
Self: Sized,
fn toggle(&mut self, other: Self)where
Self: Sized,
^) of the bits in two flags values.§fn set(&mut self, other: Self, value: bool)where
Self: Sized,
fn set(&mut self, other: Self, value: bool)where
Self: Sized,
Flags::insert] when value is true or [Flags::remove] when value is false.§fn intersection(self, other: Self) -> Self
fn intersection(self, other: Self) -> Self
&) of the bits in two flags values.§fn difference(self, other: Self) -> Self
fn difference(self, other: Self) -> Self
&!). Read more§fn symmetric_difference(self, other: Self) -> Self
fn symmetric_difference(self, other: Self) -> Self
^) of the bits in two flags values.§fn complement(self) -> Self
fn complement(self) -> Self
!) of the bits in a flags value, truncating the result.§impl FromIterator<DeviceFlag> for DeviceFlag
impl FromIterator<DeviceFlag> for DeviceFlag
§fn from_iter<T>(iterator: T) -> DeviceFlagwhere
T: IntoIterator<Item = DeviceFlag>,
fn from_iter<T>(iterator: T) -> DeviceFlagwhere
T: IntoIterator<Item = DeviceFlag>,
The bitwise or (|) of the bits in each flags value.
§impl Hash for DeviceFlag
impl Hash for DeviceFlag
§impl IntoIterator for DeviceFlag
impl IntoIterator for DeviceFlag
§type Item = DeviceFlag
type Item = DeviceFlag
§type IntoIter = Iter<DeviceFlag>
type IntoIter = Iter<DeviceFlag>
§fn into_iter(self) -> <DeviceFlag as IntoIterator>::IntoIter
fn into_iter(self) -> <DeviceFlag as IntoIterator>::IntoIter
§impl LowerHex for DeviceFlag
impl LowerHex for DeviceFlag
§impl Not for DeviceFlag
impl Not for DeviceFlag
§fn not(self) -> DeviceFlag
fn not(self) -> DeviceFlag
The bitwise negation (!) of the bits in a flags value, truncating the result.
§type Output = DeviceFlag
type Output = DeviceFlag
! operator.§impl Octal for DeviceFlag
impl Octal for DeviceFlag
§impl Ord for DeviceFlag
impl Ord for DeviceFlag
§impl PartialEq for DeviceFlag
impl PartialEq for DeviceFlag
§impl PartialOrd for DeviceFlag
impl PartialOrd for DeviceFlag
§impl Sub for DeviceFlag
impl Sub for DeviceFlag
§fn sub(self, other: DeviceFlag) -> DeviceFlag
fn sub(self, other: DeviceFlag) -> DeviceFlag
The intersection of a source flags value with the complement of a target flags value (&!).
This method is not equivalent to self & !other when other has unknown bits set.
difference won’t truncate other, but the ! operator will.
§type Output = DeviceFlag
type Output = DeviceFlag
- operator.§impl SubAssign for DeviceFlag
impl SubAssign for DeviceFlag
§fn sub_assign(&mut self, other: DeviceFlag)
fn sub_assign(&mut self, other: DeviceFlag)
The intersection of a source flags value with the complement of a target flags value (&!).
This method is not equivalent to self & !other when other has unknown bits set.
difference won’t truncate other, but the ! operator will.
§impl TypeMarker for DeviceFlag
impl TypeMarker for DeviceFlag
§type Owned = DeviceFlag
type Owned = DeviceFlag
§fn inline_align(_context: Context) -> usize
fn inline_align(_context: Context) -> usize
§fn inline_size(_context: Context) -> usize
fn inline_size(_context: Context) -> usize
inline_align.Source§fn encode_is_copy() -> bool
fn encode_is_copy() -> bool
Self::Owned matches the FIDL wire
format and encoding requires no validation. When true, we can optimize
encoding arrays and vectors of Self::Owned to a single memcpy. Read moreSource§fn decode_is_copy() -> bool
fn decode_is_copy() -> bool
Self::Owned matches the FIDL wire
format and decoding requires no validation. When true, we can optimize
decoding arrays and vectors of Self::Owned to a single memcpy.§impl UpperHex for DeviceFlag
impl UpperHex for DeviceFlag
§impl ValueTypeMarker for DeviceFlag
impl ValueTypeMarker for DeviceFlag
§type Borrowed<'a> = DeviceFlag
type Borrowed<'a> = DeviceFlag
Encode<Self>
type cheaply obtainable from &Self::Owned. There are three cases: Read more§fn borrow(
value: &<DeviceFlag as TypeMarker>::Owned,
) -> <DeviceFlag as ValueTypeMarker>::Borrowed<'_>
fn borrow( value: &<DeviceFlag as TypeMarker>::Owned, ) -> <DeviceFlag as ValueTypeMarker>::Borrowed<'_>
&Self::Owned to Self::Borrowed.