52 bitfield_field32_write(0, CSRNG_CTRL_ENABLE_FIELD, kMultiBitBool4True);
53 reg = bitfield_field32_write(reg, CSRNG_CTRL_SW_APP_ENABLE_FIELD,
55 reg = bitfield_field32_write(reg, CSRNG_CTRL_READ_INT_STATE_FIELD,
57 reg = bitfield_field32_write(reg, CSRNG_CTRL_FIPS_FORCE_ENABLE_FIELD,
59 mmio_region_write32(csrng->
base_addr, CSRNG_CTRL_REG_OFFSET, reg);
104 if (csrng == NULL || len == 0) {
110 const uint32_t num_128bit_blocks = (len + 3) / 4;
113 .id = kCsrngAppCmdGenerate,
114 .seed_material = additional_data,
115 .generate_len = num_128bit_blocks,
181 case kDifCsrngFifoCmd:
182 fifo_bit = CSRNG_ERR_CODE_SFIFO_CMD_ERR_BIT;
184 case kDifCsrngFifoGenBits:
185 fifo_bit = CSRNG_ERR_CODE_SFIFO_GENBITS_ERR_BIT;
192 mmio_region_write32(csrng->
base_addr, CSRNG_ERR_CODE_TEST_REG_OFFSET,
206 error_bit = CSRNG_ERR_CODE_CMD_STAGE_SM_ERR_BIT;
209 error_bit = CSRNG_ERR_CODE_MAIN_SM_ERR_BIT;
212 error_bit = CSRNG_ERR_CODE_CTR_DRBG_SM_ERR_BIT;
215 error_bit = CSRNG_ERR_CODE_AES_CIPHER_SM_ERR_BIT;
218 error_bit = CSRNG_ERR_CODE_CTR_ERR_BIT;
221 error_bit = CSRNG_ERR_CODE_FIFO_WRITE_ERR_BIT;
224 error_bit = CSRNG_ERR_CODE_FIFO_READ_ERR_BIT;
227 error_bit = CSRNG_ERR_CODE_FIFO_STATE_ERR_BIT;
234 mmio_region_write32(csrng->
base_addr, CSRNG_ERR_CODE_TEST_REG_OFFSET,
281 if (csrng == NULL || state == NULL) {
287 uint32_t reg = bitfield_field32_write(
288 0, CSRNG_INT_STATE_NUM_INT_STATE_NUM_FIELD, instance_id);
289 mmio_region_write32(csrng->
base_addr, CSRNG_INT_STATE_NUM_REG_OFFSET, reg);
290 uint32_t actual_reg =
291 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_NUM_REG_OFFSET);
292 if (reg != actual_reg) {
298 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_VAL_REG_OFFSET);
300 for (
size_t i = 0; i <
ARRAYSIZE(state->
v); ++i) {
302 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_VAL_REG_OFFSET);
307 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_VAL_REG_OFFSET);
311 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_VAL_REG_OFFSET);
323 uint32_t *reseed_counter) {
324 if (csrng == NULL || reseed_counter == NULL) {
329 switch (instance_id) {
331 reg_offset = CSRNG_RESEED_COUNTER_0_REG_OFFSET;
334 reg_offset = CSRNG_RESEED_COUNTER_1_REG_OFFSET;
337 reg_offset = CSRNG_RESEED_COUNTER_2_REG_OFFSET;
344 *reseed_counter = mmio_region_read32(csrng->
base_addr, (ptrdiff_t)reg_offset);