7 #include <botan/stateful_rng.h>
8 #include <botan/internal/os_utils.h>
9 #include <botan/loadstor.h>
11 #if defined(BOTAN_HAS_RDRAND_RNG)
12 #include <botan/rdrand_rng.h>
30 return m_reseed_counter > 0;
45 uint8_t additional_input[24] = { 0 };
49 #if defined(BOTAN_HAS_RDRAND_RNG)
53 rdrand.
randomize(additional_input + 8,
sizeof(additional_input) - 8);
59 store_le(m_last_pid, additional_input + 16);
60 store_le(static_cast<uint32_t>(m_reseed_counter), additional_input + 20);
68 std::chrono::milliseconds poll_timeout)
77 return bits_collected;
94 const bool fork_detected = (m_last_pid > 0) && (cur_pid != m_last_pid);
98 (m_reseed_interval > 0 && m_reseed_counter >= m_reseed_interval))
100 m_reseed_counter = 0;
101 m_last_pid = cur_pid;
108 if(m_entropy_sources)
116 throw Invalid_State(
"Detected use of fork but cannot reseed DRBG");
124 m_reseed_counter += 1;
void randomize_with_ts_input(uint8_t output[], size_t output_len) overridefinal
virtual void add_entropy(const uint8_t input[], size_t length)=0
virtual void randomize_with_input(uint8_t output[], size_t output_len, const uint8_t input[], size_t input_len)
void randomize(uint8_t out[], size_t out_len) override
uint32_t BOTAN_TEST_API get_process_id()
virtual size_t security_level() const =0
#define BOTAN_ASSERT(expr, assertion_made)
void reseed_from_rng(RandomNumberGenerator &rng, size_t poll_bits=BOTAN_RNG_RESEED_POLL_BITS) overridefinal
virtual size_t reseed(Entropy_Sources &srcs, size_t poll_bits=BOTAN_RNG_RESEED_POLL_BITS, std::chrono::milliseconds poll_timeout=BOTAN_RNG_RESEED_DEFAULT_TIMEOUT)
virtual std::string name() const =0
uint64_t BOTAN_TEST_API get_system_timestamp_ns()
bool is_seeded() const overridefinal
virtual void reseed_from_rng(RandomNumberGenerator &rng, size_t poll_bits=BOTAN_RNG_RESEED_POLL_BITS)
void initialize_with(const uint8_t input[], size_t length)
size_t reseed(Entropy_Sources &srcs, size_t poll_bits=BOTAN_RNG_RESEED_POLL_BITS, std::chrono::milliseconds poll_timeout=BOTAN_RNG_RESEED_DEFAULT_TIMEOUT) override
void reset_reseed_counter()
void store_le(uint16_t in, uint8_t out[2])
uint64_t BOTAN_TEST_API get_high_resolution_clock()