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);
102 if (csrng == NULL || len == 0) {
108 const uint32_t num_128bit_blocks = (len + 3) / 4;
111 .id = kCsrngAppCmdGenerate,
112 .generate_len = num_128bit_blocks,
178 case kDifCsrngFifoCmd:
179 fifo_bit = CSRNG_ERR_CODE_SFIFO_CMD_ERR_BIT;
181 case kDifCsrngFifoGenBits:
182 fifo_bit = CSRNG_ERR_CODE_SFIFO_GENBITS_ERR_BIT;
184 case kDifCsrngFifoGBencAck:
185 fifo_bit = CSRNG_ERR_CODE_SFIFO_GBENCACK_ERR_BIT;
187 case kDifCsrngFifoGadStage:
188 fifo_bit = CSRNG_ERR_CODE_SFIFO_GADSTAGE_ERR_BIT;
190 case kDifCsrngFifoCmdId:
191 fifo_bit = CSRNG_ERR_CODE_SFIFO_CMDID_ERR_BIT;
198 mmio_region_write32(csrng->
base_addr, CSRNG_ERR_CODE_TEST_REG_OFFSET,
212 error_bit = CSRNG_ERR_CODE_CMD_STAGE_SM_ERR_BIT;
215 error_bit = CSRNG_ERR_CODE_MAIN_SM_ERR_BIT;
218 error_bit = CSRNG_ERR_CODE_DRBG_CMD_SM_ERR_BIT;
221 error_bit = CSRNG_ERR_CODE_DRBG_GEN_SM_ERR_BIT;
224 error_bit = CSRNG_ERR_CODE_DRBG_UPDBE_SM_ERR_BIT;
227 error_bit = CSRNG_ERR_CODE_DRBG_UPDOB_SM_ERR_BIT;
230 error_bit = CSRNG_ERR_CODE_AES_CIPHER_SM_ERR_BIT;
233 error_bit = CSRNG_ERR_CODE_CMD_GEN_CNT_ERR_BIT;
236 error_bit = CSRNG_ERR_CODE_FIFO_WRITE_ERR_BIT;
239 error_bit = CSRNG_ERR_CODE_FIFO_READ_ERR_BIT;
242 error_bit = CSRNG_ERR_CODE_FIFO_STATE_ERR_BIT;
249 mmio_region_write32(csrng->
base_addr, CSRNG_ERR_CODE_TEST_REG_OFFSET,
296 if (csrng == NULL || state == NULL) {
302 uint32_t reg = bitfield_field32_write(
303 0, CSRNG_INT_STATE_NUM_INT_STATE_NUM_FIELD, instance_id);
304 mmio_region_write32(csrng->
base_addr, CSRNG_INT_STATE_NUM_REG_OFFSET, reg);
305 uint32_t actual_reg =
306 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_NUM_REG_OFFSET);
307 if (reg != actual_reg) {
313 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_VAL_REG_OFFSET);
315 for (
size_t i = 0; i <
ARRAYSIZE(state->
v); ++i) {
317 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_VAL_REG_OFFSET);
322 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_VAL_REG_OFFSET);
326 mmio_region_read32(csrng->
base_addr, CSRNG_INT_STATE_VAL_REG_OFFSET);
338 uint32_t *reseed_counter) {
339 if (csrng == NULL || reseed_counter == NULL) {
344 switch (instance_id) {
346 reg_offset = CSRNG_RESEED_COUNTER_0_REG_OFFSET;
349 reg_offset = CSRNG_RESEED_COUNTER_1_REG_OFFSET;
352 reg_offset = CSRNG_RESEED_COUNTER_2_REG_OFFSET;
359 *reseed_counter = mmio_region_read32(csrng->
base_addr, (ptrdiff_t)reg_offset);