Lines Matching +full:full +full:- +full:bias
5 * SPDX-License-Identifier: Apache-2.0
27 * values must be read out by the CPU byte-by-byte. But once started,
30 * The generation time for byte 0 after starting generation (with BIAS
33 * nRF51822 - 677us
34 * nRF52810 - 248us
35 * nRF52840 - 248us
38 * BIAS correction) is:
40 * nRF51822 - 677us
41 * nRF52810 - 120us
42 * nRF52840 - 120us
64 * low or high depending on the HFCLK-usage pattern of other
69 * entropy is requested there will be no extra current-consumption for
86 (CONFIG_ENTROPY_NRF5_ISR_POOL_SIZE - 1)) == 0,
90 (CONFIG_ENTROPY_NRF5_THR_POOL_SIZE - 1)) == 0,
105 int retval = -EAGAIN; in random_byte_get()
122 uint32_t last = rngp->last; in rng_pool_get()
123 uint32_t mask = rngp->mask; in rng_pool_get()
130 first = rngp->first_alloc; in rng_pool_get()
133 * The other_read_in_progress is non-zero if rngp->first_read != first, in rng_pool_get()
134 * which means that lower-priority code (which was interrupted by this in rng_pool_get()
137 other_read_in_progress = (rngp->first_read ^ first); in rng_pool_get()
139 available = (last - first) & mask; in rng_pool_get()
148 rngp->first_alloc = (first + len) & mask; in rng_pool_get()
151 while (likely(len--)) { in rng_pool_get()
152 *dst++ = rngp->buffer[first]; in rng_pool_get()
163 rngp->first_read = rngp->first_alloc; in rng_pool_get()
167 len = dst - buf; in rng_pool_get()
168 available = available - len; in rng_pool_get()
169 if (available <= rngp->threshold) { in rng_pool_get()
178 uint8_t first = rngp->first_read; in rng_pool_put()
179 uint8_t last = rngp->last; in rng_pool_put()
180 uint8_t mask = rngp->mask; in rng_pool_put()
182 /* Signal error if the pool is full. */ in rng_pool_put()
183 if (((last - first) & mask) == mask) { in rng_pool_put()
184 return -ENOBUFS; in rng_pool_put()
187 rngp->buffer[last] = byte; in rng_pool_put()
188 rngp->last = (last + 1) & mask; in rng_pool_put()
195 rngp->first_alloc = 0U; in rng_pool_init()
196 rngp->first_read = 0U; in rng_pool_init()
197 rngp->last = 0U; in rng_pool_init()
198 rngp->mask = size - 1; in rng_pool_init()
199 rngp->threshold = threshold; in rng_pool_init()
229 __ASSERT_NO_MSG(&entropy_nrf5_data == dev->data); in entropy_nrf5_get_entropy()
245 len -= bytes; in entropy_nrf5_get_entropy()
259 __ASSERT_NO_MSG(&entropy_nrf5_data == dev->data); in entropy_nrf5_get_entropy_isr()
279 * RNG event will set the Cortex-M single-bit event register in entropy_nrf5_get_entropy_isr()
300 buf[--len] = byte; in entropy_nrf5_get_entropy_isr()
327 __ASSERT_NO_MSG(&entropy_nrf5_data == dev->data); in entropy_nrf5_init()
342 /* Enable or disable bias correction */ in entropy_nrf5_init()