12#include "hw/top/otp_ctrl_regs.h"
23static bool checks_are_locked(
const dif_otp_ctrl_t *otp,
bool check_config) {
24 ptrdiff_t reg_offset = check_config
25 ? OTP_CTRL_CHECK_REGWEN_REG_OFFSET
26 : OTP_CTRL_CHECK_TRIGGER_REGWEN_REG_OFFSET;
28 check_config ? OTP_CTRL_CHECK_REGWEN_CHECK_REGWEN_BIT
29 : OTP_CTRL_CHECK_TRIGGER_REGWEN_CHECK_TRIGGER_REGWEN_BIT;
30 uint32_t locked = mmio_region_read32(otp->
base_addr, reg_offset);
31 return !bitfield_bit32_read(locked, regwen_bit);
35 uint32_t partition_number,
39 .mask = OTP_CTRL_ERR_CODE_0_ERR_CODE_0_MASK,
40 .index = OTP_CTRL_ERR_CODE_0_ERR_CODE_0_OFFSET,
43 ptrdiff_t err_code_address =
44 OTP_CTRL_ERR_CODE_0_REG_OFFSET +
45 (ptrdiff_t)partition_number * (ptrdiff_t)
sizeof(uint32_t);
46 uint32_t error_code = mmio_region_read32(otp->
base_addr, err_code_address);
48 switch (bitfield_field32_read(error_code, field)) {
49 case OTP_CTRL_ERR_CODE_0_ERR_CODE_0_VALUE_NO_ERROR:
52 case OTP_CTRL_ERR_CODE_0_ERR_CODE_0_VALUE_MACRO_ERROR:
55 case OTP_CTRL_ERR_CODE_0_ERR_CODE_0_VALUE_MACRO_ECC_CORR_ERROR:
58 case OTP_CTRL_ERR_CODE_0_ERR_CODE_0_VALUE_MACRO_ECC_UNCORR_ERROR:
61 case OTP_CTRL_ERR_CODE_0_ERR_CODE_0_VALUE_MACRO_WRITE_BLANK_ERROR:
64 case OTP_CTRL_ERR_CODE_0_ERR_CODE_0_VALUE_ACCESS_ERROR:
67 case OTP_CTRL_ERR_CODE_0_ERR_CODE_0_VALUE_CHECK_FAIL_ERROR:
70 case OTP_CTRL_ERR_CODE_0_ERR_CODE_0_VALUE_FSM_STATE_ERROR:
84 if (checks_are_locked(otp,
true)) {
88 mmio_region_write32(otp->
base_addr, OTP_CTRL_CHECK_TIMEOUT_REG_OFFSET,
91 OTP_CTRL_INTEGRITY_CHECK_PERIOD_REG_OFFSET,
94 OTP_CTRL_CONSISTENCY_CHECK_PERIOD_REG_OFFSET,
104 if (checks_are_locked(otp,
false)) {
109 bitfield_bit32_write(0, OTP_CTRL_CHECK_TRIGGER_INTEGRITY_BIT,
true);
110 mmio_region_write32(otp->
base_addr, OTP_CTRL_CHECK_TRIGGER_REG_OFFSET, reg);
119 if (checks_are_locked(otp,
false)) {
124 bitfield_bit32_write(0, OTP_CTRL_CHECK_TRIGGER_CONSISTENCY_BIT,
true);
125 mmio_region_write32(otp->
base_addr, OTP_CTRL_CHECK_TRIGGER_REG_OFFSET, reg);
135 uint32_t reg = bitfield_bit32_write(
136 0, OTP_CTRL_DIRECT_ACCESS_REGWEN_DIRECT_ACCESS_REGWEN_BIT,
false);
137 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_REGWEN_REG_OFFSET,
145 if (otp == NULL || is_locked == NULL) {
149 uint32_t reg = mmio_region_read32(otp->
base_addr,
150 OTP_CTRL_DIRECT_ACCESS_REGWEN_REG_OFFSET);
151 *is_locked = !bitfield_bit32_read(
152 reg, OTP_CTRL_DIRECT_ACCESS_REGWEN_DIRECT_ACCESS_REGWEN_BIT);
163 bitfield_bit32_write(0, OTP_CTRL_CHECK_REGWEN_CHECK_REGWEN_BIT,
false);
164 mmio_region_write32(otp->
base_addr, OTP_CTRL_CHECK_REGWEN_REG_OFFSET, reg);
171 if (otp == NULL || is_locked == NULL) {
175 *is_locked = checks_are_locked(otp,
true);
184 uint32_t reg = bitfield_bit32_write(
185 0, OTP_CTRL_CHECK_TRIGGER_REGWEN_CHECK_TRIGGER_REGWEN_BIT,
false);
186 mmio_region_write32(otp->
base_addr, OTP_CTRL_CHECK_TRIGGER_REGWEN_REG_OFFSET,
194 if (otp == NULL || is_locked == NULL) {
198 *is_locked = checks_are_locked(otp,
false);
203 ptrdiff_t *reg_offset,
207 *reg_offset = OTP_CTRL_VENDOR_TEST_READ_LOCK_REG_OFFSET;
208 *index = OTP_CTRL_VENDOR_TEST_READ_LOCK_VENDOR_TEST_READ_LOCK_BIT;
211 *reg_offset = OTP_CTRL_CREATOR_SW_CFG_READ_LOCK_REG_OFFSET;
212 *index = OTP_CTRL_CREATOR_SW_CFG_READ_LOCK_CREATOR_SW_CFG_READ_LOCK_BIT;
215 *reg_offset = OTP_CTRL_OWNER_SW_CFG_READ_LOCK_REG_OFFSET;
216 *index = OTP_CTRL_OWNER_SW_CFG_READ_LOCK_OWNER_SW_CFG_READ_LOCK_BIT;
218#if defined(OPENTITAN_IS_EARLGREY)
219 case kDifOtpCtrlPartitionRotCreatorAuthCodesign:
220 *reg_offset = OTP_CTRL_ROT_CREATOR_AUTH_CODESIGN_READ_LOCK_REG_OFFSET;
222 OTP_CTRL_ROT_CREATOR_AUTH_CODESIGN_READ_LOCK_ROT_CREATOR_AUTH_CODESIGN_READ_LOCK_BIT;
224 case kDifOtpCtrlPartitionRotCreatorAuthState:
225 *reg_offset = OTP_CTRL_ROT_CREATOR_AUTH_STATE_READ_LOCK_REG_OFFSET;
227 OTP_CTRL_ROT_CREATOR_AUTH_STATE_READ_LOCK_ROT_CREATOR_AUTH_STATE_READ_LOCK_BIT;
229#elif defined(OPENTITAN_IS_DARJEELING)
230 case kDifOtpCtrlPartitionOwnershipSlotState:
231 *reg_offset = OTP_CTRL_OWNERSHIP_SLOT_STATE_READ_LOCK_REG_OFFSET;
233 OTP_CTRL_OWNERSHIP_SLOT_STATE_READ_LOCK_OWNERSHIP_SLOT_STATE_READ_LOCK_BIT;
235 case kDifOtpCtrlPartitionRotCreatorAuth:
236 *reg_offset = OTP_CTRL_ROT_CREATOR_AUTH_READ_LOCK_REG_OFFSET;
238 OTP_CTRL_ROT_CREATOR_AUTH_READ_LOCK_ROT_CREATOR_AUTH_READ_LOCK_BIT;
240 case kDifOtpCtrlPartitionRotOwnerAuthSlot0:
241 *reg_offset = OTP_CTRL_ROT_OWNER_AUTH_SLOT0_READ_LOCK_REG_OFFSET;
243 OTP_CTRL_ROT_OWNER_AUTH_SLOT0_READ_LOCK_ROT_OWNER_AUTH_SLOT0_READ_LOCK_BIT;
245 case kDifOtpCtrlPartitionRotOwnerAuthSlot1:
246 *reg_offset = OTP_CTRL_ROT_OWNER_AUTH_SLOT1_READ_LOCK_REG_OFFSET;
248 OTP_CTRL_ROT_OWNER_AUTH_SLOT1_READ_LOCK_ROT_OWNER_AUTH_SLOT1_READ_LOCK_BIT;
250 case kDifOtpCtrlPartitionPlatIntegAuthSlot0:
251 *reg_offset = OTP_CTRL_PLAT_INTEG_AUTH_SLOT0_READ_LOCK_REG_OFFSET;
253 OTP_CTRL_PLAT_INTEG_AUTH_SLOT0_READ_LOCK_PLAT_INTEG_AUTH_SLOT0_READ_LOCK_BIT;
255 case kDifOtpCtrlPartitionPlatIntegAuthSlot1:
256 *reg_offset = OTP_CTRL_PLAT_INTEG_AUTH_SLOT1_READ_LOCK_REG_OFFSET;
258 OTP_CTRL_PLAT_INTEG_AUTH_SLOT1_READ_LOCK_PLAT_INTEG_AUTH_SLOT1_READ_LOCK_BIT;
260 case kDifOtpCtrlPartitionPlatOwnerAuthSlot0:
261 *reg_offset = OTP_CTRL_PLAT_OWNER_AUTH_SLOT0_READ_LOCK_REG_OFFSET;
263 OTP_CTRL_PLAT_OWNER_AUTH_SLOT0_READ_LOCK_PLAT_OWNER_AUTH_SLOT0_READ_LOCK_BIT;
265 case kDifOtpCtrlPartitionPlatOwnerAuthSlot1:
266 *reg_offset = OTP_CTRL_PLAT_OWNER_AUTH_SLOT1_READ_LOCK_REG_OFFSET;
268 OTP_CTRL_PLAT_OWNER_AUTH_SLOT1_READ_LOCK_PLAT_OWNER_AUTH_SLOT1_READ_LOCK_BIT;
270 case kDifOtpCtrlPartitionPlatOwnerAuthSlot2:
271 *reg_offset = OTP_CTRL_PLAT_OWNER_AUTH_SLOT2_READ_LOCK_REG_OFFSET;
273 OTP_CTRL_PLAT_OWNER_AUTH_SLOT2_READ_LOCK_PLAT_OWNER_AUTH_SLOT2_READ_LOCK_BIT;
275 case kDifOtpCtrlPartitionPlatOwnerAuthSlot3:
276 *reg_offset = OTP_CTRL_PLAT_OWNER_AUTH_SLOT3_READ_LOCK_REG_OFFSET;
278 OTP_CTRL_PLAT_OWNER_AUTH_SLOT3_READ_LOCK_PLAT_OWNER_AUTH_SLOT3_READ_LOCK_BIT;
280 case kDifOtpCtrlPartitionExtNvm:
281 *reg_offset = OTP_CTRL_EXT_NVM_READ_LOCK_REG_OFFSET;
282 *index = OTP_CTRL_EXT_NVM_READ_LOCK_EXT_NVM_READ_LOCK_BIT;
284 case kDifOtpCtrlPartitionRomPatch:
285 *reg_offset = OTP_CTRL_ROM_PATCH_READ_LOCK_REG_OFFSET;
286 *index = OTP_CTRL_ROM_PATCH_READ_LOCK_ROM_PATCH_READ_LOCK_BIT;
289#error "dif_otp_ctrl does not support this top"
305 if (!sw_read_lock_reg_offset(partition, &offset, &index)) {
309 uint32_t reg = bitfield_bit32_write(0, index,
false);
310 mmio_region_write32(otp->
base_addr, offset, reg);
318 if (otp == NULL || is_locked == NULL) {
324 if (!sw_read_lock_reg_offset(partition, &offset, &index)) {
328 uint32_t reg = mmio_region_read32(otp->
base_addr, offset);
329 *is_locked = !bitfield_bit32_read(reg, index);
335 if (otp == NULL ||
status == NULL) {
342 uint32_t status_code_reg =
343 mmio_region_read32(otp->
base_addr, OTP_CTRL_STATUS_REG_OFFSET);
346 if (bitfield_bit32_read(status_code_reg,
347 OTP_CTRL_STATUS_PARTITION_ERROR_BIT)) {
349 for (
int status_reg_num = 0; status_reg_num < num_part_status_regs;
351 uint32_t partition_status_reg = mmio_region_read32(
353 (ptrdiff_t)(OTP_CTRL_PARTITION_STATUS_0_REG_OFFSET +
354 (ptrdiff_t)
sizeof(uint32_t) * status_reg_num));
356 for (
int status_idx = 0; status_idx < 32; ++status_idx) {
357 uint32_t partition_number =
358 (uint32_t)status_reg_num * 32 + (uint32_t)status_idx;
364 if (!bitfield_bit32_read(partition_status_reg,
371 status->codes = bitfield_bit32_write(
377 if (get_error_code(otp, partition_number, &err) !=
kDifOk) {
380 status->causes[partition_number] = err;
402 if (get_error_code(otp, err_code_index, &err) !=
kDifOk) {
407 status->causes[err_code_index] = err;
464static const partition_info_t kPartitions[] = {
466 .start_addr = OTP_CTRL_PARAM_VENDOR_TEST_OFFSET,
467 .len = OTP_CTRL_PARAM_VENDOR_TEST_SIZE,
471 .is_lifecycle =
false},
473 .start_addr = OTP_CTRL_PARAM_CREATOR_SW_CFG_OFFSET,
474 .len = OTP_CTRL_PARAM_CREATOR_SW_CFG_SIZE,
478 .is_lifecycle =
false},
480 .start_addr = OTP_CTRL_PARAM_OWNER_SW_CFG_OFFSET,
481 .len = OTP_CTRL_PARAM_OWNER_SW_CFG_SIZE,
485 .is_lifecycle =
false},
486#if defined(OPENTITAN_IS_EARLGREY)
487 [kDifOtpCtrlPartitionRotCreatorAuthCodesign] = {
488 .start_addr = OTP_CTRL_PARAM_ROT_CREATOR_AUTH_CODESIGN_OFFSET,
489 .len = OTP_CTRL_PARAM_ROT_CREATOR_AUTH_CODESIGN_SIZE,
493 .is_lifecycle =
false},
494 [kDifOtpCtrlPartitionRotCreatorAuthState] = {
495 .start_addr = OTP_CTRL_PARAM_ROT_CREATOR_AUTH_STATE_OFFSET,
496 .len = OTP_CTRL_PARAM_ROT_CREATOR_AUTH_STATE_SIZE,
500 .is_lifecycle =
false},
501#elif defined(OPENTITAN_IS_DARJEELING)
502 [kDifOtpCtrlPartitionOwnershipSlotState] = {
503 .start_addr = OTP_CTRL_PARAM_OWNERSHIP_SLOT_STATE_OFFSET,
504 .len = OTP_CTRL_PARAM_OWNERSHIP_SLOT_STATE_SIZE,
508 .is_lifecycle =
false},
509 [kDifOtpCtrlPartitionRotCreatorAuth] = {
510 .start_addr = OTP_CTRL_PARAM_ROT_CREATOR_AUTH_OFFSET,
511 .len = OTP_CTRL_PARAM_ROT_CREATOR_AUTH_SIZE,
515 .is_lifecycle =
false},
516 [kDifOtpCtrlPartitionRotOwnerAuthSlot0] = {
517 .start_addr = OTP_CTRL_PARAM_ROT_OWNER_AUTH_SLOT0_OFFSET,
518 .len = OTP_CTRL_PARAM_ROT_OWNER_AUTH_SLOT0_SIZE,
522 .is_lifecycle =
false},
523 [kDifOtpCtrlPartitionRotOwnerAuthSlot1] = {
524 .start_addr = OTP_CTRL_PARAM_ROT_OWNER_AUTH_SLOT1_OFFSET,
525 .len = OTP_CTRL_PARAM_ROT_OWNER_AUTH_SLOT1_SIZE,
529 .is_lifecycle =
false},
530 [kDifOtpCtrlPartitionPlatIntegAuthSlot0] = {
531 .start_addr = OTP_CTRL_PARAM_PLAT_INTEG_AUTH_SLOT0_OFFSET,
532 .len = OTP_CTRL_PARAM_PLAT_INTEG_AUTH_SLOT0_SIZE,
536 .is_lifecycle =
false},
537 [kDifOtpCtrlPartitionPlatIntegAuthSlot1] = {
538 .start_addr = OTP_CTRL_PARAM_PLAT_INTEG_AUTH_SLOT1_OFFSET,
539 .len = OTP_CTRL_PARAM_PLAT_INTEG_AUTH_SLOT1_SIZE,
543 .is_lifecycle =
false},
544 [kDifOtpCtrlPartitionPlatOwnerAuthSlot0] = {
545 .start_addr = OTP_CTRL_PARAM_PLAT_OWNER_AUTH_SLOT0_OFFSET,
546 .len = OTP_CTRL_PARAM_PLAT_OWNER_AUTH_SLOT0_SIZE,
550 .is_lifecycle =
false},
551 [kDifOtpCtrlPartitionPlatOwnerAuthSlot1] = {
552 .start_addr = OTP_CTRL_PARAM_PLAT_OWNER_AUTH_SLOT1_OFFSET,
553 .len = OTP_CTRL_PARAM_PLAT_OWNER_AUTH_SLOT1_SIZE,
557 .is_lifecycle =
false},
558 [kDifOtpCtrlPartitionPlatOwnerAuthSlot2] = {
559 .start_addr = OTP_CTRL_PARAM_PLAT_OWNER_AUTH_SLOT2_OFFSET,
560 .len = OTP_CTRL_PARAM_PLAT_OWNER_AUTH_SLOT2_SIZE,
564 .is_lifecycle =
false},
565 [kDifOtpCtrlPartitionPlatOwnerAuthSlot3] = {
566 .start_addr = OTP_CTRL_PARAM_PLAT_OWNER_AUTH_SLOT3_OFFSET,
567 .len = OTP_CTRL_PARAM_PLAT_OWNER_AUTH_SLOT3_SIZE,
571 .is_lifecycle =
false},
572 [kDifOtpCtrlPartitionExtNvm] = {
573 .start_addr = OTP_CTRL_PARAM_EXT_NVM_OFFSET,
574 .len = OTP_CTRL_PARAM_EXT_NVM_SIZE,
578 .is_lifecycle =
false},
579 [kDifOtpCtrlPartitionRomPatch] = {
580 .start_addr = OTP_CTRL_PARAM_ROM_PATCH_OFFSET,
581 .len = OTP_CTRL_PARAM_ROM_PATCH_SIZE,
585 .is_lifecycle =
false},
587#error "dif_otp_ctrl does not support this top"
590 .start_addr = OTP_CTRL_PARAM_HW_CFG0_OFFSET,
591 .len = OTP_CTRL_PARAM_HW_CFG0_SIZE,
593 .is_software =
false,
595 .is_lifecycle =
false},
597 .start_addr = OTP_CTRL_PARAM_HW_CFG1_OFFSET,
598 .len = OTP_CTRL_PARAM_HW_CFG1_SIZE,
600 .is_software =
false,
602 .is_lifecycle =
false},
604 .start_addr = OTP_CTRL_PARAM_SECRET0_OFFSET,
605 .len = OTP_CTRL_PARAM_SECRET0_SIZE,
607 .is_software =
false,
609 .is_lifecycle =
false},
611 .start_addr = OTP_CTRL_PARAM_SECRET1_OFFSET,
612 .len = OTP_CTRL_PARAM_SECRET1_SIZE,
614 .is_software =
false,
616 .is_lifecycle =
false},
618 .start_addr = OTP_CTRL_PARAM_SECRET2_OFFSET,
619 .len = OTP_CTRL_PARAM_SECRET2_SIZE,
621 .is_software =
false,
623 .is_lifecycle =
false},
624#if defined(OPENTITAN_IS_DARJEELING)
625 [kDifOtpCtrlPartitionSecret3] = {
626 .start_addr = OTP_CTRL_PARAM_SECRET3_OFFSET,
627 .len = OTP_CTRL_PARAM_SECRET3_SIZE,
629 .is_software =
false,
631 .is_lifecycle =
false},
632#elif defined(OPENTITAN_IS_EARLGREY)
635#error "dif_otp_ctrl does not support this top"
638 .start_addr = OTP_CTRL_PARAM_LIFE_CYCLE_OFFSET,
639 .len = OTP_CTRL_PARAM_LIFE_CYCLE_SIZE,
641 .is_software =
false,
643 .is_lifecycle =
true},
648 uint32_t abs_address,
649 uint32_t *relative_address) {
650 *relative_address = 0;
652 if (partition >=
ARRAYSIZE(kPartitions)) {
656 if ((abs_address & kPartitions[partition].align_mask) != 0) {
660 if (abs_address < kPartitions[partition].start_addr) {
664 *relative_address = abs_address - kPartitions[partition].start_addr;
665 if (*relative_address >= kPartitions[partition].len) {
666 *relative_address = 0;
676 if (otp == NULL || partition >=
ARRAYSIZE(kPartitions)) {
680 if ((address & kPartitions[partition].align_mask) != 0) {
684 if (address >= kPartitions[partition].len) {
688 address += kPartitions[partition].start_addr;
689 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_ADDRESS_REG_OFFSET,
693 bitfield_bit32_write(0, OTP_CTRL_DIRECT_ACCESS_CMD_RD_BIT,
true);
694 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_CMD_REG_OFFSET,
702 if (otp == NULL || value == NULL) {
706 *value = mmio_region_read32(otp->
base_addr,
707 OTP_CTRL_DIRECT_ACCESS_RDATA_0_REG_OFFSET);
713 if (otp == NULL || value == NULL) {
717 *value = mmio_region_read32(otp->
base_addr,
718 OTP_CTRL_DIRECT_ACCESS_RDATA_1_REG_OFFSET);
720 *value |= mmio_region_read32(otp->
base_addr,
721 OTP_CTRL_DIRECT_ACCESS_RDATA_0_REG_OFFSET);
727 uint32_t address, uint32_t value) {
728 if (otp == NULL || partition >=
ARRAYSIZE(kPartitions)) {
737 if (kPartitions[partition].align_mask != 0x3 ||
738 kPartitions[partition].is_lifecycle) {
742 if ((address & kPartitions[partition].align_mask) != 0) {
749 size_t digest_size = kPartitions[partition].has_digest *
sizeof(uint64_t);
750 if (address >= kPartitions[partition].len - digest_size) {
754 address += kPartitions[partition].start_addr;
755 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_ADDRESS_REG_OFFSET,
758 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_WDATA_0_REG_OFFSET,
762 bitfield_bit32_write(0, OTP_CTRL_DIRECT_ACCESS_CMD_WR_BIT,
true);
763 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_CMD_REG_OFFSET,
771 uint32_t address, uint64_t value) {
772 if (otp == NULL || partition >=
ARRAYSIZE(kPartitions)) {
778 if (kPartitions[partition].align_mask != 0x7) {
782 if ((address & kPartitions[partition].align_mask) != 0) {
788 size_t digest_size =
sizeof(uint64_t);
789 if (address >= kPartitions[partition].len - digest_size) {
793 address += kPartitions[partition].start_addr;
794 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_ADDRESS_REG_OFFSET,
797 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_WDATA_0_REG_OFFSET,
799 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_WDATA_1_REG_OFFSET,
803 bitfield_bit32_write(0, OTP_CTRL_DIRECT_ACCESS_CMD_WR_BIT,
true);
804 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_CMD_REG_OFFSET,
813 if (otp == NULL || partition >=
ARRAYSIZE(kPartitions)) {
818 if (!kPartitions[partition].has_digest) {
824 bool is_sw = kPartitions[partition].is_software;
825 if (is_sw == (digest == 0)) {
829 uint32_t address = kPartitions[partition].start_addr;
831 address += kPartitions[partition].len -
sizeof(digest);
833 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_ADDRESS_REG_OFFSET,
838 OTP_CTRL_DIRECT_ACCESS_WDATA_0_REG_OFFSET,
839 digest & 0xffffffff);
841 OTP_CTRL_DIRECT_ACCESS_WDATA_1_REG_OFFSET,
846 ? OTP_CTRL_DIRECT_ACCESS_CMD_WR_BIT
847 : OTP_CTRL_DIRECT_ACCESS_CMD_DIGEST_BIT;
848 uint32_t cmd = bitfield_bit32_write(0, cmd_bit,
true);
849 mmio_region_write32(otp->
base_addr, OTP_CTRL_DIRECT_ACCESS_CMD_REG_OFFSET,
859 *reg0 = OTP_CTRL_VENDOR_TEST_DIGEST_0_REG_OFFSET;
860 *reg1 = OTP_CTRL_VENDOR_TEST_DIGEST_1_REG_OFFSET;
863 *reg0 = OTP_CTRL_CREATOR_SW_CFG_DIGEST_0_REG_OFFSET;
864 *reg1 = OTP_CTRL_CREATOR_SW_CFG_DIGEST_1_REG_OFFSET;
867 *reg0 = OTP_CTRL_OWNER_SW_CFG_DIGEST_0_REG_OFFSET;
868 *reg1 = OTP_CTRL_OWNER_SW_CFG_DIGEST_1_REG_OFFSET;
870#if defined(OPENTITAN_IS_EARLGREY)
871 case kDifOtpCtrlPartitionRotCreatorAuthCodesign:
872 *reg0 = OTP_CTRL_ROT_CREATOR_AUTH_CODESIGN_DIGEST_0_REG_OFFSET;
873 *reg1 = OTP_CTRL_ROT_CREATOR_AUTH_CODESIGN_DIGEST_1_REG_OFFSET;
875 case kDifOtpCtrlPartitionRotCreatorAuthState:
876 *reg0 = OTP_CTRL_ROT_CREATOR_AUTH_STATE_DIGEST_0_REG_OFFSET;
877 *reg1 = OTP_CTRL_ROT_CREATOR_AUTH_STATE_DIGEST_1_REG_OFFSET;
879#elif defined(OPENTITAN_IS_DARJEELING)
880 case kDifOtpCtrlPartitionRotCreatorAuth:
881 *reg0 = OTP_CTRL_ROT_CREATOR_AUTH_DIGEST_0_REG_OFFSET;
882 *reg1 = OTP_CTRL_ROT_CREATOR_AUTH_DIGEST_1_REG_OFFSET;
884 case kDifOtpCtrlPartitionRotOwnerAuthSlot0:
885 *reg0 = OTP_CTRL_ROT_OWNER_AUTH_SLOT0_DIGEST_0_REG_OFFSET;
886 *reg1 = OTP_CTRL_ROT_OWNER_AUTH_SLOT0_DIGEST_1_REG_OFFSET;
888 case kDifOtpCtrlPartitionRotOwnerAuthSlot1:
889 *reg0 = OTP_CTRL_ROT_OWNER_AUTH_SLOT1_DIGEST_0_REG_OFFSET;
890 *reg1 = OTP_CTRL_ROT_OWNER_AUTH_SLOT1_DIGEST_1_REG_OFFSET;
892 case kDifOtpCtrlPartitionPlatIntegAuthSlot0:
893 *reg0 = OTP_CTRL_PLAT_INTEG_AUTH_SLOT0_DIGEST_0_REG_OFFSET;
894 *reg1 = OTP_CTRL_PLAT_INTEG_AUTH_SLOT0_DIGEST_1_REG_OFFSET;
896 case kDifOtpCtrlPartitionPlatIntegAuthSlot1:
897 *reg0 = OTP_CTRL_PLAT_INTEG_AUTH_SLOT1_DIGEST_0_REG_OFFSET;
898 *reg1 = OTP_CTRL_PLAT_INTEG_AUTH_SLOT1_DIGEST_1_REG_OFFSET;
900 case kDifOtpCtrlPartitionPlatOwnerAuthSlot0:
901 *reg0 = OTP_CTRL_PLAT_OWNER_AUTH_SLOT0_DIGEST_0_REG_OFFSET;
902 *reg1 = OTP_CTRL_PLAT_OWNER_AUTH_SLOT0_DIGEST_1_REG_OFFSET;
904 case kDifOtpCtrlPartitionPlatOwnerAuthSlot1:
905 *reg0 = OTP_CTRL_PLAT_OWNER_AUTH_SLOT1_DIGEST_0_REG_OFFSET;
906 *reg1 = OTP_CTRL_PLAT_OWNER_AUTH_SLOT1_DIGEST_1_REG_OFFSET;
908 case kDifOtpCtrlPartitionPlatOwnerAuthSlot2:
909 *reg0 = OTP_CTRL_PLAT_OWNER_AUTH_SLOT2_DIGEST_0_REG_OFFSET;
910 *reg1 = OTP_CTRL_PLAT_OWNER_AUTH_SLOT2_DIGEST_1_REG_OFFSET;
912 case kDifOtpCtrlPartitionPlatOwnerAuthSlot3:
913 *reg0 = OTP_CTRL_PLAT_OWNER_AUTH_SLOT3_DIGEST_0_REG_OFFSET;
914 *reg1 = OTP_CTRL_PLAT_OWNER_AUTH_SLOT3_DIGEST_1_REG_OFFSET;
916 case kDifOtpCtrlPartitionRomPatch:
917 *reg0 = OTP_CTRL_ROM_PATCH_DIGEST_0_REG_OFFSET;
918 *reg1 = OTP_CTRL_ROM_PATCH_DIGEST_1_REG_OFFSET;
921#error "dif_otp_ctrl does not support this top"
924 *reg0 = OTP_CTRL_HW_CFG0_DIGEST_0_REG_OFFSET;
925 *reg1 = OTP_CTRL_HW_CFG0_DIGEST_1_REG_OFFSET;
928 *reg0 = OTP_CTRL_HW_CFG1_DIGEST_0_REG_OFFSET;
929 *reg1 = OTP_CTRL_HW_CFG1_DIGEST_1_REG_OFFSET;
932 *reg0 = OTP_CTRL_SECRET0_DIGEST_0_REG_OFFSET;
933 *reg1 = OTP_CTRL_SECRET0_DIGEST_1_REG_OFFSET;
936 *reg0 = OTP_CTRL_SECRET1_DIGEST_0_REG_OFFSET;
937 *reg1 = OTP_CTRL_SECRET1_DIGEST_1_REG_OFFSET;
940 *reg0 = OTP_CTRL_SECRET2_DIGEST_0_REG_OFFSET;
941 *reg1 = OTP_CTRL_SECRET2_DIGEST_1_REG_OFFSET;
943#if defined(OPENTITAN_IS_DARJEELING)
944 case kDifOtpCtrlPartitionSecret3:
945 *reg0 = OTP_CTRL_SECRET3_DIGEST_0_REG_OFFSET;
946 *reg1 = OTP_CTRL_SECRET3_DIGEST_1_REG_OFFSET;
948#elif defined(OPENTITAN_IS_EARLGREY)
951#error "dif_otp_ctrl does not support this top"
963 if (otp == NULL || is_computed == NULL) {
967 ptrdiff_t reg0, reg1;
968 if (!get_digest_regs(partition, ®0, ®1)) {
972 uint64_t value = mmio_region_read32(otp->
base_addr, reg1);
974 value |= mmio_region_read32(otp->
base_addr, reg0);
976 *is_computed = value != 0;
984 if (otp == NULL || digest == NULL) {
988 ptrdiff_t reg0, reg1;
989 if (!get_digest_regs(partition, ®0, ®1)) {
993 uint64_t value = mmio_region_read32(otp->
base_addr, reg1);
995 value |= mmio_region_read32(otp->
base_addr, reg0);
1007 uint32_t address, uint32_t *buf,
1009 if (otp == NULL || partition >=
ARRAYSIZE(kPartitions) || buf == NULL) {
1013 if (!kPartitions[partition].is_software) {
1017 if ((address & kPartitions[partition].align_mask) != 0) {
1021 if (address + len >= kPartitions[partition].len) {
1025 uint32_t reg_offset = OTP_CTRL_SW_CFG_WINDOW_REG_OFFSET +
1026 kPartitions[partition].start_addr + address;
1027 mmio_region_memcpy_from_mmio32(otp->
base_addr, reg_offset, buf,
1028 len *
sizeof(uint32_t));