TRNG

Struct TRNG 

Source
pub struct TRNG { /* private fields */ }
Expand description

ARM TrustZone RNG register block

Implementations§

Source§

impl TRNG

Source

pub const PTR: *const RegisterBlock = {0x400f0000 as *const rp235x_hal::rp235x_pac::trng::RegisterBlock}

Pointer to the register block

Source

pub const fn ptr() -> *const RegisterBlock

Return the pointer to the register block

Source

pub unsafe fn steal() -> TRNG

Steal an instance of this peripheral

§Safety

Ensure that the new instance of the peripheral cannot be used in a way that may race with any existing instances, for example by only accessing read-only or write-only registers, or by consuming the original peripheral and using critical sections to coordinate access between multiple new instances.

Additionally, other software such as HALs may rely on only one peripheral instance existing to ensure memory safety; ensure no stolen instances are passed to such software.

Methods from Deref<Target = RegisterBlock>§

Source

pub fn rng_imr(&self) -> &Reg<RNG_IMR_SPEC>

0x100 - Interrupt masking.

Source

pub fn rng_isr(&self) -> &Reg<RNG_ISR_SPEC>

0x104 - RNG status register. If corresponding RNG_IMR bit is unmasked, an interrupt will be generated.

Source

pub fn rng_icr(&self) -> &Reg<RNG_ICR_SPEC>

0x108 - Interrupt/status bit clear Register.

Source

pub fn trng_config(&self) -> &Reg<TRNG_CONFIG_SPEC>

0x10c - Selecting the inverter-chain length.

Source

pub fn trng_valid(&self) -> &Reg<TRNG_VALID_SPEC>

0x110 - 192 bit collection indication.

Source

pub fn ehr_data0(&self) -> &Reg<EHR_DATA0_SPEC>

0x114 - RNG collected bits.

Source

pub fn ehr_data1(&self) -> &Reg<EHR_DATA1_SPEC>

0x118 - RNG collected bits.

Source

pub fn ehr_data2(&self) -> &Reg<EHR_DATA2_SPEC>

0x11c - RNG collected bits.

Source

pub fn ehr_data3(&self) -> &Reg<EHR_DATA3_SPEC>

0x120 - RNG collected bits.

Source

pub fn ehr_data4(&self) -> &Reg<EHR_DATA4_SPEC>

0x124 - RNG collected bits.

Source

pub fn ehr_data5(&self) -> &Reg<EHR_DATA5_SPEC>

0x128 - RNG collected bits.

Source

pub fn rnd_source_enable(&self) -> &Reg<RND_SOURCE_ENABLE_SPEC>

0x12c - Enable signal for the random source.

Source

pub fn sample_cnt1(&self) -> &Reg<SAMPLE_CNT1_SPEC>

0x130 - Counts clocks between sampling of random bit.

Source

pub fn autocorr_statistic(&self) -> &Reg<AUTOCORR_STATISTIC_SPEC>

0x134 - Statistic about Autocorrelation test activations.

Source

pub fn trng_debug_control(&self) -> &Reg<TRNG_DEBUG_CONTROL_SPEC>

0x138 - Debug register.

Source

pub fn trng_sw_reset(&self) -> &Reg<TRNG_SW_RESET_SPEC>

0x140 - Generate internal SW reset within the RNG block.

Source

pub fn rng_debug_en_input(&self) -> &Reg<RNG_DEBUG_EN_INPUT_SPEC>

0x1b4 - Enable the RNG debug mode

Source

pub fn trng_busy(&self) -> &Reg<TRNG_BUSY_SPEC>

0x1b8 - RNG Busy indication.

Source

pub fn rst_bits_counter(&self) -> &Reg<RST_BITS_COUNTER_SPEC>

0x1bc - Reset the counter of collected bits in the RNG.

Source

pub fn rng_version(&self) -> &Reg<RNG_VERSION_SPEC>

0x1c0 - Displays the version settings of the TRNG.

Source

pub fn rng_bist_cntr_0(&self) -> &Reg<RNG_BIST_CNTR_0_SPEC>

0x1e0 - Collected BIST results.

Source

pub fn rng_bist_cntr_1(&self) -> &Reg<RNG_BIST_CNTR_1_SPEC>

0x1e4 - Collected BIST results.

Source

pub fn rng_bist_cntr_2(&self) -> &Reg<RNG_BIST_CNTR_2_SPEC>

0x1e8 - Collected BIST results.

Trait Implementations§

Source§

impl Debug for TRNG

Source§

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

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

impl Deref for TRNG

Source§

type Target = RegisterBlock

The resulting type after dereferencing.
Source§

fn deref(&self) -> &<TRNG as Deref>::Target

Dereferences the value.
Source§

impl Send for TRNG

Auto Trait Implementations§

§

impl Freeze for TRNG

§

impl RefUnwindSafe for TRNG

§

impl !Sync for TRNG

§

impl Unpin for TRNG

§

impl UnwindSafe for TRNG

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<Choices> CoproductSubsetter<CNil, HNil> for Choices

Source§

type Remainder = Choices

Source§

fn subset( self, ) -> Result<CNil, <Choices as CoproductSubsetter<CNil, HNil>>::Remainder>

Extract a subset of the possible types in a coproduct (or get the remaining possibilities) 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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T, U, I> LiftInto<U, I> for T
where U: LiftFrom<T, I>,

Source§

fn lift_into(self) -> U

Performs the indexed conversion.
Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<Source> Sculptor<HNil, HNil> for Source

Source§

type Remainder = Source

Source§

fn sculpt(self) -> (HNil, <Source as Sculptor<HNil, HNil>>::Remainder)

Consumes the current HList and returns an HList with the requested shape. 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.