Skip to main content

HcrEl2

Struct HcrEl2 

Source
pub struct HcrEl2(/* private fields */);
Expand description

HCR_EL2 system register value.

Implementations§

Source§

impl HcrEl2

Source

pub const VM: Self

VM bit.

Source

pub const SWIO: Self

SWIO bit.

Source

pub const PTW: Self

PTW bit.

Source

pub const FMO: Self

FMO bit.

Source

pub const IMO: Self

IMO bit.

Source

pub const AMO: Self

AMO bit.

Source

pub const VF: Self

VF bit.

Source

pub const VI: Self

VI bit.

Source

pub const VSE: Self

VSE bit.

Source

pub const FB: Self

FB bit.

Source

pub const DC: Self

DC bit.

Source

pub const TWI: Self

TWI bit.

Source

pub const TWE: Self

TWE bit.

Source

pub const TID0: Self

TID0 bit.

Source

pub const TID1: Self

TID1 bit.

Source

pub const TID2: Self

TID2 bit.

Source

pub const TID3: Self

TID3 bit.

Source

pub const TSC: Self

TSC bit.

Source

pub const TIDCP: Self

TIDCP bit.

Source

pub const TACR: Self

TACR bit.

Source

pub const TSW: Self

TSW bit.

Source

pub const TPCP: Self

TPCP bit.

Source

pub const TPU: Self

TPU bit.

Source

pub const TTLB: Self

TTLB bit.

Source

pub const TVM: Self

TVM bit.

Source

pub const TGE: Self

Trap general exceptions to EL2.

Source

pub const TDZ: Self

TDZ bit.

Source

pub const HCD: Self

HCD bit.

Source

pub const TRVM: Self

TRVM bit.

Source

pub const RW: Self

RW bit.

Source

pub const CD: Self

CD bit.

Source

pub const ID: Self

ID bit.

Source

pub const E2H: Self

E2H bit.

Source

pub const TLOR: Self

TLOR bit.

Source

pub const TERR: Self

TERR bit.

Source

pub const TEA: Self

TEA bit.

Source

pub const APK: Self

APK bit.

Source

pub const API: Self

API bit.

Source

pub const NV: Self

NV bit.

Source

pub const NV1: Self

NV1 bit.

Source

pub const AT: Self

AT bit.

Source

pub const NV2: Self

NV2 bit.

Source

pub const FWB: Self

FWB bit.

Source

pub const FIEN: Self

FIEN bit.

Source

pub const GPF: Self

GPF bit.

Source

pub const TID4: Self

TID4 bit.

Source

pub const TICAB: Self

TICAB bit.

Source

pub const AMVOFFEN: Self

AMVOFFEN bit.

Source

pub const TOCU: Self

TOCU bit.

Source

pub const ENSCXT: Self

EnSCXT bit.

Source

pub const TTLBIS: Self

TTLBIS bit.

Source

pub const TTLBOS: Self

TTLBOS bit.

Source

pub const ATA: Self

ATA bit.

Source

pub const DCT: Self

DCT bit.

Source

pub const TID5: Self

TID5 bit.

Source

pub const TWEDEN: Self

TWEDEn bit.

Source§

impl HcrEl2

Source

pub const fn empty() -> Self

Get a flags value with all bits unset.

Source

pub const fn all() -> Self

Get a flags value with all known bits set.

Source

pub const fn bits(&self) -> u64

Get the underlying bits value.

The returned value is exactly the bits set in this flags value.

Source

pub const fn from_bits(bits: u64) -> Option<Self>

Convert from a bits value.

This method will return None if any unknown bits are set.

Source

pub const fn from_bits_truncate(bits: u64) -> Self

Convert from a bits value, unsetting any unknown bits.

Source

pub const fn from_bits_retain(bits: u64) -> Self

Convert from a bits value exactly.

Source

pub fn from_name(name: &str) -> Option<Self>

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.

Source

pub const fn is_empty(&self) -> bool

Whether all bits in this flags value are unset.

Source

pub const fn is_all(&self) -> bool

Whether all known bits in this flags value are set.

Source

pub const fn intersects(&self, other: Self) -> bool

Whether any set bits in a source flags value are also set in a target flags value.

Source

pub const fn contains(&self, other: Self) -> bool

Whether all set bits in a source flags value are also set in a target flags value.

Source

pub fn insert(&mut self, other: Self)

The bitwise or (|) of the bits in two flags values.

Source

pub fn remove(&mut self, other: Self)

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.

Source

pub fn toggle(&mut self, other: Self)

The bitwise exclusive-or (^) of the bits in two flags values.

Source

pub fn set(&mut self, other: Self, value: bool)

Call insert when value is true or remove when value is false.

Source

pub const fn intersection(self, other: Self) -> Self

The bitwise and (&) of the bits in two flags values.

Source

pub const fn union(self, other: Self) -> Self

The bitwise or (|) of the bits in two flags values.

Source

pub const fn difference(self, other: Self) -> Self

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.

Source

pub const fn symmetric_difference(self, other: Self) -> Self

The bitwise exclusive-or (^) of the bits in two flags values.

Source

pub const fn complement(self) -> Self

The bitwise negation (!) of the bits in a flags value, truncating the result.

Source§

impl HcrEl2

Source

pub const fn iter(&self) -> Iter<HcrEl2>

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.

Source

pub const fn iter_names(&self) -> IterNames<HcrEl2>

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.

Source§

impl HcrEl2

Source

pub const VM_SHIFT: u32 = 0

Available on crate feature el2 only.

Offset of the VM field.

Source

pub const SWIO_SHIFT: u32 = 1

Available on crate feature el2 only.

Offset of the SWIO field.

Source

pub const PTW_SHIFT: u32 = 2

Available on crate feature el2 only.

Offset of the PTW field.

Source

pub const FMO_SHIFT: u32 = 3

Available on crate feature el2 only.

Offset of the FMO field.

Source

pub const IMO_SHIFT: u32 = 4

Available on crate feature el2 only.

Offset of the IMO field.

Source

pub const AMO_SHIFT: u32 = 5

Available on crate feature el2 only.

Offset of the AMO field.

Source

pub const VF_SHIFT: u32 = 6

Available on crate feature el2 only.

Offset of the VF field.

Source

pub const VI_SHIFT: u32 = 7

Available on crate feature el2 only.

Offset of the VI field.

Source

pub const VSE_SHIFT: u32 = 8

Available on crate feature el2 only.

Offset of the VSE field.

Source

pub const FB_SHIFT: u32 = 9

Available on crate feature el2 only.

Offset of the FB field.

Source

pub const BSU_SHIFT: u32 = 10

Available on crate feature el2 only.

Offset of the BSU field.

Source

pub const BSU_MASK: u64 = 0b11

Available on crate feature el2 only.

Mask for the BSU field.

Source

pub const DC_SHIFT: u32 = 12

Available on crate feature el2 only.

Offset of the DC field.

Source

pub const TWI_SHIFT: u32 = 13

Available on crate feature el2 only.

Offset of the TWI field.

Source

pub const TWE_SHIFT: u32 = 14

Available on crate feature el2 only.

Offset of the TWE field.

Source

pub const TID0_SHIFT: u32 = 15

Available on crate feature el2 only.

Offset of the TID0 field.

Source

pub const TID1_SHIFT: u32 = 16

Available on crate feature el2 only.

Offset of the TID1 field.

Source

pub const TID2_SHIFT: u32 = 17

Available on crate feature el2 only.

Offset of the TID2 field.

Source

pub const TID3_SHIFT: u32 = 18

Available on crate feature el2 only.

Offset of the TID3 field.

Source

pub const TSC_SHIFT: u32 = 19

Available on crate feature el2 only.

Offset of the TSC field.

Source

pub const TIDCP_SHIFT: u32 = 20

Available on crate feature el2 only.

Offset of the TIDCP field.

Source

pub const TACR_SHIFT: u32 = 21

Available on crate feature el2 only.

Offset of the TACR field.

Source

pub const TSW_SHIFT: u32 = 22

Available on crate feature el2 only.

Offset of the TSW field.

Source

pub const TPCP_SHIFT: u32 = 23

Available on crate feature el2 only.

Offset of the TPCP field.

Source

pub const TPU_SHIFT: u32 = 24

Available on crate feature el2 only.

Offset of the TPU field.

Source

pub const TTLB_SHIFT: u32 = 25

Available on crate feature el2 only.

Offset of the TTLB field.

Source

pub const TVM_SHIFT: u32 = 26

Available on crate feature el2 only.

Offset of the TVM field.

Source

pub const TGE_SHIFT: u32 = 27

Available on crate feature el2 only.

Offset of the TGE field.

Source

pub const TDZ_SHIFT: u32 = 28

Available on crate feature el2 only.

Offset of the TDZ field.

Source

pub const HCD_SHIFT: u32 = 29

Available on crate feature el2 only.

Offset of the HCD field.

Source

pub const TRVM_SHIFT: u32 = 30

Available on crate feature el2 only.

Offset of the TRVM field.

Source

pub const RW_SHIFT: u32 = 31

Available on crate feature el2 only.

Offset of the RW field.

Source

pub const CD_SHIFT: u32 = 32

Available on crate feature el2 only.

Offset of the CD field.

Source

pub const ID_SHIFT: u32 = 33

Available on crate feature el2 only.

Offset of the ID field.

Source

pub const E2H_SHIFT: u32 = 34

Available on crate feature el2 only.

Offset of the E2H field.

Source

pub const TLOR_SHIFT: u32 = 35

Available on crate feature el2 only.

Offset of the TLOR field.

Source

pub const TERR_SHIFT: u32 = 36

Available on crate feature el2 only.

Offset of the TERR field.

Source

pub const TEA_SHIFT: u32 = 37

Available on crate feature el2 only.

Offset of the TEA field.

Source

pub const APK_SHIFT: u32 = 40

Available on crate feature el2 only.

Offset of the APK field.

Source

pub const API_SHIFT: u32 = 41

Available on crate feature el2 only.

Offset of the API field.

Source

pub const NV_SHIFT: u32 = 42

Available on crate feature el2 only.

Offset of the NV field.

Source

pub const NV1_SHIFT: u32 = 43

Available on crate feature el2 only.

Offset of the NV1 field.

Source

pub const AT_SHIFT: u32 = 44

Available on crate feature el2 only.

Offset of the AT field.

Source

pub const NV2_SHIFT: u32 = 45

Available on crate feature el2 only.

Offset of the NV2 field.

Source

pub const FWB_SHIFT: u32 = 46

Available on crate feature el2 only.

Offset of the FWB field.

Source

pub const FIEN_SHIFT: u32 = 47

Available on crate feature el2 only.

Offset of the FIEN field.

Source

pub const GPF_SHIFT: u32 = 48

Available on crate feature el2 only.

Offset of the GPF field.

Source

pub const TID4_SHIFT: u32 = 49

Available on crate feature el2 only.

Offset of the TID4 field.

Source

pub const TICAB_SHIFT: u32 = 50

Available on crate feature el2 only.

Offset of the TICAB field.

Source

pub const AMVOFFEN_SHIFT: u32 = 51

Available on crate feature el2 only.

Offset of the AMVOFFEN field.

Source

pub const TOCU_SHIFT: u32 = 52

Available on crate feature el2 only.

Offset of the TOCU field.

Source

pub const ENSCXT_SHIFT: u32 = 53

Available on crate feature el2 only.

Offset of the EnSCXT field.

Source

pub const TTLBIS_SHIFT: u32 = 54

Available on crate feature el2 only.

Offset of the TTLBIS field.

Source

pub const TTLBOS_SHIFT: u32 = 55

Available on crate feature el2 only.

Offset of the TTLBOS field.

Source

pub const ATA_SHIFT: u32 = 56

Available on crate feature el2 only.

Offset of the ATA field.

Source

pub const DCT_SHIFT: u32 = 57

Available on crate feature el2 only.

Offset of the DCT field.

Source

pub const TID5_SHIFT: u32 = 58

Available on crate feature el2 only.

Offset of the TID5 field.

Source

pub const TWEDEN_SHIFT: u32 = 59

Available on crate feature el2 only.

Offset of the TWEDEn field.

Source

pub const TWEDEL_SHIFT: u32 = 60

Available on crate feature el2 only.

Offset of the TWEDEL field.

Source

pub const TWEDEL_MASK: u64 = 0b1111

Available on crate feature el2 only.

Mask for the TWEDEL field.

Source

pub const fn bsu(self) -> u8

Available on crate feature el2 only.

Returns the value of the BSU field.

Source

pub const fn set_bsu(&mut self, value: u8)

Available on crate feature el2 only.

Sets the value of the BSU field.

Source

pub const fn with_bsu(self, value: u8) -> Self

Available on crate feature el2 only.

Returns a copy with the BSU field set to the given value.

Source

pub const fn twedel(self) -> u8

Available on crate feature el2 only.

Returns the value of the TWEDEL field.

Source

pub const fn set_twedel(&mut self, value: u8)

Available on crate feature el2 only.

Sets the value of the TWEDEL field.

Source

pub const fn with_twedel(self, value: u8) -> Self

Available on crate feature el2 only.

Returns a copy with the TWEDEL field set to the given value.

Trait Implementations§

Source§

impl Binary for HcrEl2

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl BitAnd for HcrEl2

Source§

fn bitand(self, other: Self) -> Self

The bitwise and (&) of the bits in two flags values.

Source§

type Output = HcrEl2

The resulting type after applying the & operator.
Source§

impl BitAndAssign for HcrEl2

Source§

fn bitand_assign(&mut self, other: Self)

The bitwise and (&) of the bits in two flags values.

Source§

impl BitOr for HcrEl2

Source§

fn bitor(self, other: HcrEl2) -> Self

The bitwise or (|) of the bits in two flags values.

Source§

type Output = HcrEl2

The resulting type after applying the | operator.
Source§

impl BitOrAssign for HcrEl2

Source§

fn bitor_assign(&mut self, other: Self)

The bitwise or (|) of the bits in two flags values.

Source§

impl BitXor for HcrEl2

Source§

fn bitxor(self, other: Self) -> Self

The bitwise exclusive-or (^) of the bits in two flags values.

Source§

type Output = HcrEl2

The resulting type after applying the ^ operator.
Source§

impl BitXorAssign for HcrEl2

Source§

fn bitxor_assign(&mut self, other: Self)

The bitwise exclusive-or (^) of the bits in two flags values.

Source§

impl Clone for HcrEl2

Source§

fn clone(&self) -> HcrEl2

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for HcrEl2

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for HcrEl2

Source§

fn default() -> HcrEl2

Returns the “default value” for a type. Read more
Source§

impl Extend<HcrEl2> for HcrEl2

Source§

fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)

The bitwise or (|) of the bits in each flags value.

Source§

fn extend_one(&mut self, item: A)

🔬This is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
Source§

fn extend_reserve(&mut self, additional: usize)

🔬This is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
Source§

impl Flags for HcrEl2

Source§

const FLAGS: &'static [Flag<HcrEl2>]

The set of defined flags.
Source§

type Bits = u64

The underlying bits type.
Source§

fn bits(&self) -> u64

Get the underlying bits value. Read more
Source§

fn from_bits_retain(bits: u64) -> HcrEl2

Convert from a bits value exactly.
Source§

fn empty() -> Self

Get a flags value with all bits unset.
Source§

fn all() -> Self

Get a flags value with all known bits set.
Source§

fn known_bits(&self) -> Self::Bits

Get the known bits from a flags value.
Source§

fn unknown_bits(&self) -> Self::Bits

Get the unknown bits from a flags value.
Source§

fn contains_unknown_bits(&self) -> bool

This method will return true if any unknown bits are set.
Source§

fn from_bits(bits: Self::Bits) -> Option<Self>

Convert from a bits value. Read more
Source§

fn from_bits_truncate(bits: Self::Bits) -> Self

Convert from a bits value, unsetting any unknown bits.
Source§

fn from_name(name: &str) -> Option<Self>

Get a flags value with the bits of a flag with the given name set. Read more
Source§

fn iter(&self) -> Iter<Self>

Yield a set of contained flags values. Read more
Source§

fn iter_names(&self) -> IterNames<Self>

Yield a set of contained named flags values. Read more
Source§

fn iter_defined_names() -> IterDefinedNames<Self>

Yield a set of all named flags defined by Self::FLAGS.
Source§

fn is_empty(&self) -> bool

Whether all bits in this flags value are unset.
Source§

fn is_all(&self) -> bool

Whether all known bits in this flags value are set.
Source§

fn intersects(&self, other: Self) -> bool
where Self: Sized,

Whether any set bits in a source flags value are also set in a target flags value.
Source§

fn contains(&self, other: Self) -> bool
where Self: Sized,

Whether all set bits in a source flags value are also set in a target flags value.
Source§

fn truncate(&mut self)
where Self: Sized,

Remove any unknown bits from the flags.
Source§

fn insert(&mut self, other: Self)
where Self: Sized,

The bitwise or (|) of the bits in two flags values.
Source§

fn remove(&mut self, other: Self)
where Self: Sized,

The intersection of a source flags value with the complement of a target flags value (&!). Read more
Source§

fn toggle(&mut self, other: Self)
where Self: Sized,

The bitwise exclusive-or (^) of the bits in two flags values.
Source§

fn set(&mut self, other: Self, value: bool)
where Self: Sized,

Call Flags::insert when value is true or Flags::remove when value is false.
Source§

fn clear(&mut self)
where Self: Sized,

Unsets all bits in the flags.
Source§

fn intersection(self, other: Self) -> Self

The bitwise and (&) of the bits in two flags values.
Source§

fn union(self, other: Self) -> Self

The bitwise or (|) of the bits in two flags values.
Source§

fn difference(self, other: Self) -> Self

The intersection of a source flags value with the complement of a target flags value (&!). Read more
Source§

fn symmetric_difference(self, other: Self) -> Self

The bitwise exclusive-or (^) of the bits in two flags values.
Source§

fn complement(self) -> Self

The bitwise negation (!) of the bits in a flags value, truncating the result.
Source§

impl FromIterator<HcrEl2> for HcrEl2

Source§

fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self

The bitwise or (|) of the bits in each flags value.

Source§

impl IntoIterator for HcrEl2

Source§

type Item = HcrEl2

The type of the elements being iterated over.
Source§

type IntoIter = Iter<HcrEl2>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
Source§

impl LowerHex for HcrEl2

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Not for HcrEl2

Source§

fn not(self) -> Self

The bitwise negation (!) of the bits in a flags value, truncating the result.

Source§

type Output = HcrEl2

The resulting type after applying the ! operator.
Source§

impl Octal for HcrEl2

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for HcrEl2

Source§

fn eq(&self, other: &HcrEl2) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PublicFlags for HcrEl2

Source§

type Primitive = u64

The type of the underlying storage.
Source§

type Internal = InternalBitFlags

The type of the internal field on the generated flags type.
Source§

impl Sub for HcrEl2

Source§

fn sub(self, other: Self) -> Self

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.

Source§

type Output = HcrEl2

The resulting type after applying the - operator.
Source§

impl SubAssign for HcrEl2

Source§

fn sub_assign(&mut self, other: Self)

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.

Source§

impl UpperHex for HcrEl2

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Copy for HcrEl2

Source§

impl Eq for HcrEl2

Source§

impl StructuralPartialEq for HcrEl2

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.