5#include "sw/device/lib/testing/keymgr_testutils.h"
7#include "hw/top/dt/otp_ctrl.h"
14#include "sw/device/lib/testing/entropy_testutils.h"
15#include "sw/device/lib/testing/flash_ctrl_testutils.h"
16#include "sw/device/lib/testing/kmac_testutils.h"
17#include "sw/device/lib/testing/otp_ctrl_testutils.h"
18#include "sw/device/lib/testing/rstmgr_testutils.h"
19#include "sw/device/lib/testing/test_framework/check.h"
21#include "sw/device/silicon_creator/lib/drivers/retention_sram.h"
25#define MODULE_ID MAKE_MODULE_ID('k', 'm', 't')
29 kFlashInfoPartitionId = 0,
35 kFlashInfoPageIdCreatorSecret = 1,
38 kFlashInfoPageIdOwnerSecret = 2,
41const static char *kKeymgrStageNames[] = {
52 const keymgr_testutils_secret_t *data,
56 TRY(flash_ctrl_testutils_info_region_scrambled_setup(
57 flash, page_id, kFlashInfoBankId, kFlashInfoPartitionId, &address));
59 TRY(flash_ctrl_testutils_info_region_setup(
60 flash, page_id, kFlashInfoBankId, kFlashInfoPartitionId, &address));
63 TRY(flash_ctrl_testutils_erase_and_write_page(
64 flash, address, kFlashInfoPartitionId, data->value,
65 kDifFlashCtrlPartitionTypeInfo,
ARRAYSIZE(data->value)));
67 keymgr_testutils_secret_t readback_data;
68 TRY(flash_ctrl_testutils_read(
69 flash, address, kFlashInfoPartitionId, readback_data.value,
70 kDifFlashCtrlPartitionTypeInfo,
ARRAYSIZE(readback_data.value), 0));
71 TRY_CHECK(memcmp(data->value, readback_data.value,
sizeof(data->value)) == 0);
75status_t keymgr_testutils_flash_init(
77 const keymgr_testutils_secret_t *creator_secret,
78 const keymgr_testutils_secret_t *owner_secret) {
81 write_info_page(flash, kFlashInfoPageIdCreatorSecret, creator_secret,
84 write_info_page(flash, kFlashInfoPageIdOwnerSecret, owner_secret,
89static status_t check_lock_otp_partition(
void) {
91 TRY(dif_otp_ctrl_init_from_dt(
kDtOtpCtrl, &otp));
99 LOG_INFO(
"OTP partition locked. Digest: %x-%x", ((uint32_t *)&digest)[0],
100 ((uint32_t *)&digest)[1]);
115 TRY(kmac_testutils_config(kmac,
true));
125 TRY(keymgr_testutils_startup(keymgr, kmac));
126 LOG_INFO(
"Keymgr entered CreatorRootKey State");
129 TRY(keymgr_testutils_generate_identity(
132 LOG_INFO(
"Keymgr generated identity at CreatorRootKey State");
136 TRY(keymgr_testutils_advance_state(keymgr, &kOwnerIntParams));
137 TRY(keymgr_testutils_check_state(keymgr,
139 LOG_INFO(
"Keymgr entered OwnerIntKey State");
145 TRY(keymgr_testutils_try_startup(keymgr, kmac, &keymgr_state));
148 TRY(keymgr_testutils_advance_state(keymgr, &kOwnerIntParams));
149 TRY(dif_keymgr_get_state(keymgr, &keymgr_state));
153 TRY(keymgr_testutils_advance_state(keymgr, &kOwnerRootKeyParams));
161 return keymgr_initialize_sival(keymgr, kmac);
164 return keymgr_initialize_sim_dv(keymgr, kmac);
169 TRY(dif_init(keymgr, kmac));
173 TRY(dif_keymgr_get_state(keymgr, keymgr_state));
177 LOG_INFO(
"Unexpected keymgr state: 0x%x", keymgr_state);
182 TRY(keymgr_testutils_startup(keymgr, kmac));
183 TRY(dif_keymgr_get_state(keymgr, keymgr_state));
189status_t keymgr_testutils_init_nvm_then_reset(
void) {
197 rstmgr_testutils_reason_get();
201 LOG_INFO(
"Powered up for the first time, program flash");
203 TRY(dif_flash_ctrl_init_state(
205 TRY(dif_otp_ctrl_init(
209 bool secret2_computed =
false;
216 const keymgr_testutils_secret_t *creator_secret = NULL;
217 if (!secret2_computed) {
218 creator_secret = &kCreatorSecret;
220 TRY(keymgr_testutils_flash_init(&flash, creator_secret, &kOwnerSecret));
222 TRY(check_lock_otp_partition());
225 LOG_INFO(
"Requesting a reset to make OTP partitions accessible to keymgr");
226 rstmgr_testutils_reason_clear();
227 TRY(dif_rstmgr_software_device_reset(&rstmgr));
230 wait_for_interrupt();
247 bool is_using_test_rom =
250 .reserved[
ARRAYSIZE((retention_sram_t){0}.creator.reserved) - 1] ==
253 TRY(keymgr_testutils_init_nvm_then_reset());
262 LOG_INFO(
"Initializing entropy complex in Auto mode");
264 TRY(entropy_testutils_auto_mode_init());
266 LOG_INFO(
"Powered up for the second time, actuate keymgr and perform test.");
268 TRY(dif_init(keymgr, kmac));
272 TRY(keymgr_testutils_advance_state(keymgr, NULL));
274 LOG_INFO(
"Keymgr entered Init State");
277 if (is_using_test_rom) {
278 LOG_INFO(
"Using test_rom, setting inputs and advancing state...");
279 TRY(keymgr_testutils_advance_state(keymgr, &kCreatorParams));
281 LOG_INFO(
"Using rom, only advancing state...");
282 TRY(dif_keymgr_advance_state_raw(keymgr));
283 TRY(keymgr_testutils_wait_for_operation_done(keymgr));
286 LOG_INFO(
"Keymgr entered CreatorRootKey State");
291 TRY(keymgr_testutils_generate_identity(
294 LOG_INFO(
"Keymgr generated identity at CreatorRootKey State");
299status_t keymgr_testutils_advance_state(
301 TRY(dif_keymgr_advance_state(keymgr, params));
302 return keymgr_testutils_wait_for_operation_done(keymgr);
305status_t keymgr_testutils_check_state(
const dif_keymgr_t *keymgr,
308 TRY(dif_keymgr_get_state(keymgr, &act_state));
309 TRY_CHECK(act_state == exp_state,
310 "Keymgr in unexpected state: %x, expected to be %x", act_state,
315status_t keymgr_testutils_generate_identity(
318 TRY(dif_keymgr_generate_identity_seed(keymgr, params));
319 return keymgr_testutils_wait_for_operation_done(keymgr);
322status_t keymgr_testutils_generate_versioned_key(
325 TRY(dif_keymgr_generate_versioned_key(keymgr, params));
326 return keymgr_testutils_wait_for_operation_done(keymgr);
329status_t keymgr_testutils_disable(
const dif_keymgr_t *keymgr) {
330 TRY(dif_keymgr_disable(keymgr));
331 return keymgr_testutils_wait_for_operation_done(keymgr);
334status_t keymgr_testutils_wait_for_operation_done(
const dif_keymgr_t *keymgr) {
337 TRY(dif_keymgr_get_status_codes(keymgr, &
status));
344status_t keymgr_testutils_max_key_version_get(
const dif_keymgr_t *keymgr,
345 uint32_t *max_key_version) {
347 TRY(dif_keymgr_get_state(keymgr, &keymgr_state));
352 LOG_INFO(
"Unexpected keymgr state: 0x%x", keymgr_state);
356 dif_keymgr_max_key_version_t versions;
357 TRY(dif_keymgr_read_max_key_version(keymgr, &versions));
359 switch (keymgr_state) {
376status_t keymgr_testutils_state_string_get(
const dif_keymgr_t *keymgr,
377 const char **stage_name) {
379 CHECK_DIF_OK(dif_keymgr_get_state(keymgr, &state));
381 if (state >=
ARRAYSIZE(kKeymgrStageNames)) {
386 *stage_name = kKeymgrStageNames[state];