| // Copyright lowRISC contributors. |
| // Licensed under the Apache License, Version 2.0, see LICENSE for details. |
| // SPDX-License-Identifier: Apache-2.0 |
| // clang-format off |
| |
| // |
| // ------------------- W A R N I N G: A U T O - G E N E R A T E D C O D E !! -------------------// |
| // PLEASE DO NOT HAND-EDIT THIS FILE. IT HAS BEEN AUTO-GENERATED WITH THE FOLLOWING COMMAND: |
| // util/topgen.py -t hw/top_earlgrey/data/top_earlgrey.hjson |
| // -o hw/top_earlgrey |
| #include "sw/device/lib/base/mmio.h" |
| #include "sw/device/lib/dif/dif_adc_ctrl.h" |
| #include "sw/device/lib/dif/dif_aes.h" |
| #include "sw/device/lib/dif/dif_alert_handler.h" |
| #include "sw/device/lib/dif/dif_aon_timer.h" |
| #include "sw/device/lib/dif/dif_clkmgr.h" |
| #include "sw/device/lib/dif/dif_csrng.h" |
| #include "sw/device/lib/dif/dif_edn.h" |
| #include "sw/device/lib/dif/dif_entropy_src.h" |
| #include "sw/device/lib/dif/dif_flash_ctrl.h" |
| #include "sw/device/lib/dif/dif_gpio.h" |
| #include "sw/device/lib/dif/dif_hmac.h" |
| #include "sw/device/lib/dif/dif_i2c.h" |
| #include "sw/device/lib/dif/dif_keymgr.h" |
| #include "sw/device/lib/dif/dif_kmac.h" |
| #include "sw/device/lib/dif/dif_lc_ctrl.h" |
| #include "sw/device/lib/dif/dif_otbn.h" |
| #include "sw/device/lib/dif/dif_otp_ctrl.h" |
| #include "sw/device/lib/dif/dif_pattgen.h" |
| #include "sw/device/lib/dif/dif_pinmux.h" |
| #include "sw/device/lib/dif/dif_pwm.h" |
| #include "sw/device/lib/dif/dif_pwrmgr.h" |
| #include "sw/device/lib/dif/dif_rom_ctrl.h" |
| #include "sw/device/lib/dif/dif_rstmgr.h" |
| #include "sw/device/lib/dif/dif_rv_core_ibex.h" |
| #include "sw/device/lib/dif/dif_rv_plic.h" |
| #include "sw/device/lib/dif/dif_rv_timer.h" |
| #include "sw/device/lib/dif/dif_sensor_ctrl.h" |
| #include "sw/device/lib/dif/dif_spi_device.h" |
| #include "sw/device/lib/dif/dif_spi_host.h" |
| #include "sw/device/lib/dif/dif_sram_ctrl.h" |
| #include "sw/device/lib/dif/dif_sysrst_ctrl.h" |
| #include "sw/device/lib/dif/dif_uart.h" |
| #include "sw/device/lib/dif/dif_usbdev.h" |
| #include "sw/device/lib/testing/alert_handler_testutils.h" |
| #include "sw/device/lib/testing/test_framework/FreeRTOSConfig.h" |
| #include "sw/device/lib/testing/test_framework/check.h" |
| #include "sw/device/lib/testing/test_framework/ottf_test_config.h" |
| |
| #include "alert_handler_regs.h" // Generated. |
| #include "hw/top_earlgrey/sw/autogen/top_earlgrey.h" |
| |
| OTTF_DEFINE_TEST_CONFIG(); |
| |
| static dif_alert_handler_t alert_handler; |
| static dif_adc_ctrl_t adc_ctrl_aon; |
| static dif_aes_t aes; |
| static dif_aon_timer_t aon_timer_aon; |
| static dif_clkmgr_t clkmgr_aon; |
| static dif_csrng_t csrng; |
| static dif_edn_t edn0; |
| static dif_edn_t edn1; |
| static dif_entropy_src_t entropy_src; |
| static dif_flash_ctrl_t flash_ctrl; |
| static dif_gpio_t gpio; |
| static dif_hmac_t hmac; |
| static dif_i2c_t i2c0; |
| static dif_i2c_t i2c1; |
| static dif_i2c_t i2c2; |
| static dif_keymgr_t keymgr; |
| static dif_kmac_t kmac; |
| static dif_lc_ctrl_t lc_ctrl; |
| static dif_otbn_t otbn; |
| static dif_otp_ctrl_t otp_ctrl; |
| static dif_pattgen_t pattgen; |
| static dif_pinmux_t pinmux_aon; |
| static dif_pwm_t pwm_aon; |
| static dif_pwrmgr_t pwrmgr_aon; |
| static dif_rom_ctrl_t rom_ctrl; |
| static dif_rstmgr_t rstmgr_aon; |
| static dif_rv_core_ibex_t rv_core_ibex; |
| static dif_rv_plic_t rv_plic; |
| static dif_rv_timer_t rv_timer; |
| static dif_sensor_ctrl_t sensor_ctrl; |
| static dif_spi_device_t spi_device; |
| static dif_spi_host_t spi_host0; |
| static dif_spi_host_t spi_host1; |
| static dif_sram_ctrl_t sram_ctrl_main; |
| static dif_sram_ctrl_t sram_ctrl_ret_aon; |
| static dif_sysrst_ctrl_t sysrst_ctrl_aon; |
| static dif_uart_t uart0; |
| static dif_uart_t uart1; |
| static dif_uart_t uart2; |
| static dif_uart_t uart3; |
| static dif_usbdev_t usbdev; |
| |
| /** |
| * Initialize the peripherals used in this test. |
| */ |
| static void init_peripherals(void) { |
| mmio_region_t base_addr; |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_ALERT_HANDLER_BASE_ADDR); |
| CHECK_DIF_OK(dif_alert_handler_init(base_addr, &alert_handler)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_ADC_CTRL_AON_BASE_ADDR); |
| CHECK_DIF_OK(dif_adc_ctrl_init(base_addr, &adc_ctrl_aon)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_AES_BASE_ADDR); |
| CHECK_DIF_OK(dif_aes_init(base_addr, &aes)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_AON_TIMER_AON_BASE_ADDR); |
| CHECK_DIF_OK(dif_aon_timer_init(base_addr, &aon_timer_aon)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_CLKMGR_AON_BASE_ADDR); |
| CHECK_DIF_OK(dif_clkmgr_init(base_addr, &clkmgr_aon)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_CSRNG_BASE_ADDR); |
| CHECK_DIF_OK(dif_csrng_init(base_addr, &csrng)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_EDN0_BASE_ADDR); |
| CHECK_DIF_OK(dif_edn_init(base_addr, &edn0)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_EDN1_BASE_ADDR); |
| CHECK_DIF_OK(dif_edn_init(base_addr, &edn1)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_ENTROPY_SRC_BASE_ADDR); |
| CHECK_DIF_OK(dif_entropy_src_init(base_addr, &entropy_src)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_FLASH_CTRL_CORE_BASE_ADDR); |
| CHECK_DIF_OK(dif_flash_ctrl_init(base_addr, &flash_ctrl)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_GPIO_BASE_ADDR); |
| CHECK_DIF_OK(dif_gpio_init(base_addr, &gpio)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_HMAC_BASE_ADDR); |
| CHECK_DIF_OK(dif_hmac_init(base_addr, &hmac)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_I2C0_BASE_ADDR); |
| CHECK_DIF_OK(dif_i2c_init(base_addr, &i2c0)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_I2C1_BASE_ADDR); |
| CHECK_DIF_OK(dif_i2c_init(base_addr, &i2c1)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_I2C2_BASE_ADDR); |
| CHECK_DIF_OK(dif_i2c_init(base_addr, &i2c2)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_KEYMGR_BASE_ADDR); |
| CHECK_DIF_OK(dif_keymgr_init(base_addr, &keymgr)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_KMAC_BASE_ADDR); |
| CHECK_DIF_OK(dif_kmac_init(base_addr, &kmac)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_LC_CTRL_BASE_ADDR); |
| CHECK_DIF_OK(dif_lc_ctrl_init(base_addr, &lc_ctrl)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_OTBN_BASE_ADDR); |
| CHECK_DIF_OK(dif_otbn_init(base_addr, &otbn)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_OTP_CTRL_CORE_BASE_ADDR); |
| CHECK_DIF_OK(dif_otp_ctrl_init(base_addr, &otp_ctrl)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_PATTGEN_BASE_ADDR); |
| CHECK_DIF_OK(dif_pattgen_init(base_addr, &pattgen)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_PINMUX_AON_BASE_ADDR); |
| CHECK_DIF_OK(dif_pinmux_init(base_addr, &pinmux_aon)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_PWM_AON_BASE_ADDR); |
| CHECK_DIF_OK(dif_pwm_init(base_addr, &pwm_aon)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_PWRMGR_AON_BASE_ADDR); |
| CHECK_DIF_OK(dif_pwrmgr_init(base_addr, &pwrmgr_aon)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_ROM_CTRL_REGS_BASE_ADDR); |
| CHECK_DIF_OK(dif_rom_ctrl_init(base_addr, &rom_ctrl)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_RSTMGR_AON_BASE_ADDR); |
| CHECK_DIF_OK(dif_rstmgr_init(base_addr, &rstmgr_aon)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_RV_CORE_IBEX_CFG_BASE_ADDR); |
| CHECK_DIF_OK(dif_rv_core_ibex_init(base_addr, &rv_core_ibex)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_RV_PLIC_BASE_ADDR); |
| CHECK_DIF_OK(dif_rv_plic_init(base_addr, &rv_plic)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_RV_TIMER_BASE_ADDR); |
| CHECK_DIF_OK(dif_rv_timer_init(base_addr, &rv_timer)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_SENSOR_CTRL_BASE_ADDR); |
| CHECK_DIF_OK(dif_sensor_ctrl_init(base_addr, &sensor_ctrl)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_SPI_DEVICE_BASE_ADDR); |
| CHECK_DIF_OK(dif_spi_device_init(base_addr, &spi_device)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_SPI_HOST0_BASE_ADDR); |
| CHECK_DIF_OK(dif_spi_host_init(base_addr, &spi_host0)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_SPI_HOST1_BASE_ADDR); |
| CHECK_DIF_OK(dif_spi_host_init(base_addr, &spi_host1)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_SRAM_CTRL_MAIN_REGS_BASE_ADDR); |
| CHECK_DIF_OK(dif_sram_ctrl_init(base_addr, &sram_ctrl_main)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_SRAM_CTRL_RET_AON_REGS_BASE_ADDR); |
| CHECK_DIF_OK(dif_sram_ctrl_init(base_addr, &sram_ctrl_ret_aon)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_SYSRST_CTRL_AON_BASE_ADDR); |
| CHECK_DIF_OK(dif_sysrst_ctrl_init(base_addr, &sysrst_ctrl_aon)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_UART0_BASE_ADDR); |
| CHECK_DIF_OK(dif_uart_init(base_addr, &uart0)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_UART1_BASE_ADDR); |
| CHECK_DIF_OK(dif_uart_init(base_addr, &uart1)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_UART2_BASE_ADDR); |
| CHECK_DIF_OK(dif_uart_init(base_addr, &uart2)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_UART3_BASE_ADDR); |
| CHECK_DIF_OK(dif_uart_init(base_addr, &uart3)); |
| |
| base_addr = mmio_region_from_addr(TOP_EARLGREY_USBDEV_BASE_ADDR); |
| CHECK_DIF_OK(dif_usbdev_init(base_addr, &usbdev)); |
| |
| } |
| |
| /** |
| * Configure the alert handler to escalate on alerts upto phase 1 (i.e. wipe |
| * secret) but not trigger reset. Then CPU can check if alert_handler triggers the correct |
| * alert_cause register. |
| */ |
| static void alert_handler_config(void) { |
| dif_alert_handler_alert_t alerts[ALERT_HANDLER_PARAM_N_ALERTS]; |
| dif_alert_handler_class_t alert_classes[ALERT_HANDLER_PARAM_N_ALERTS]; |
| |
| // Enable all incoming alerts and configure them to classa. |
| // This alert should never fire because we do not expect any incoming alerts. |
| for (int i = 0; i < ALERT_HANDLER_PARAM_N_ALERTS; ++i) { |
| alerts[i] = i; |
| alert_classes[i] = kDifAlertHandlerClassA; |
| } |
| |
| dif_alert_handler_escalation_phase_t esc_phases[] = { |
| {.phase = kDifAlertHandlerClassStatePhase0, |
| .signal = 0, |
| .duration_cycles = 2000}}; |
| |
| dif_alert_handler_class_config_t class_config = { |
| .auto_lock_accumulation_counter = kDifToggleDisabled, |
| .accumulator_threshold = 0, |
| .irq_deadline_cycles = 10000, |
| .escalation_phases = esc_phases, |
| .escalation_phases_len = ARRAYSIZE(esc_phases), |
| .crashdump_escalation_phase = kDifAlertHandlerClassStatePhase1, |
| }; |
| |
| dif_alert_handler_class_config_t class_configs[] = {class_config, |
| class_config}; |
| |
| dif_alert_handler_class_t classes[] = {kDifAlertHandlerClassA, |
| kDifAlertHandlerClassB}; |
| dif_alert_handler_config_t config = { |
| .alerts = alerts, |
| .alert_classes = alert_classes, |
| .alerts_len = ARRAYSIZE(alerts), |
| .classes = classes, |
| .class_configs = class_configs, |
| .classes_len = ARRAYSIZE(class_configs), |
| .ping_timeout = 1000, |
| }; |
| |
| alert_handler_testutils_configure_all(&alert_handler, config, |
| kDifToggleEnabled); |
| } |
| |
| // Trigger alert for each module by writing one to `alert_test` register. |
| // Then check alert_handler's alert_cause register to make sure the correct alert reaches |
| // alert_handler. |
| static void trigger_alert_test(void) { |
| bool is_cause; |
| dif_alert_handler_alert_t exp_alert; |
| |
| // Write adc_ctrl's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_adc_ctrl_alert_force(&adc_ctrl_aon, kDifAdcCtrlAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdAdcCtrlAonFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write aes's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_aes_alert_force(&aes, kDifAesAlertRecovCtrlUpdateErr + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdAesRecovCtrlUpdateErr + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write aon_timer's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_aon_timer_alert_force(&aon_timer_aon, kDifAonTimerAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdAonTimerAonFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write clkmgr's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_clkmgr_alert_force(&clkmgr_aon, kDifClkmgrAlertRecovFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdClkmgrAonRecovFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write csrng's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_csrng_alert_force(&csrng, kDifCsrngAlertRecovAlert + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdCsrngRecovAlert + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write edn's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_edn_alert_force(&edn0, kDifEdnAlertRecovAlert + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdEdn0RecovAlert + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write edn's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_edn_alert_force(&edn1, kDifEdnAlertRecovAlert + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdEdn1RecovAlert + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write entropy_src's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_entropy_src_alert_force(&entropy_src, kDifEntropySrcAlertRecovAlert + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdEntropySrcRecovAlert + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write flash_ctrl's alert_test reg and check alert_cause. |
| for (int i = 0; i < 5; ++i) { |
| CHECK_DIF_OK(dif_flash_ctrl_alert_force(&flash_ctrl, kDifFlashCtrlAlertRecovErr + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdFlashCtrlRecovErr + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write gpio's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_gpio_alert_force(&gpio, kDifGpioAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdGpioFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write hmac's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_hmac_alert_force(&hmac, kDifHmacAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdHmacFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write i2c's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_i2c_alert_force(&i2c0, kDifI2cAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdI2c0FatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write i2c's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_i2c_alert_force(&i2c1, kDifI2cAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdI2c1FatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write i2c's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_i2c_alert_force(&i2c2, kDifI2cAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdI2c2FatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write keymgr's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_keymgr_alert_force(&keymgr, kDifKeymgrAlertRecovOperationErr + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdKeymgrRecovOperationErr + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write kmac's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_kmac_alert_force(&kmac, kDifKmacAlertRecovOperationErr + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdKmacRecovOperationErr + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write lc_ctrl's alert_test reg and check alert_cause. |
| for (int i = 0; i < 3; ++i) { |
| CHECK_DIF_OK(dif_lc_ctrl_alert_force(&lc_ctrl, kDifLcCtrlAlertFatalProgError + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdLcCtrlFatalProgError + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write otbn's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_otbn_alert_force(&otbn, kDifOtbnAlertFatal + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdOtbnFatal + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write otp_ctrl's alert_test reg and check alert_cause. |
| for (int i = 0; i < 5; ++i) { |
| CHECK_DIF_OK(dif_otp_ctrl_alert_force(&otp_ctrl, kDifOtpCtrlAlertFatalMacroError + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdOtpCtrlFatalMacroError + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write pattgen's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_pattgen_alert_force(&pattgen, kDifPattgenAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdPattgenFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write pinmux's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_pinmux_alert_force(&pinmux_aon, kDifPinmuxAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdPinmuxAonFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write pwm's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_pwm_alert_force(&pwm_aon, kDifPwmAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdPwmAonFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write pwrmgr's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_pwrmgr_alert_force(&pwrmgr_aon, kDifPwrmgrAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdPwrmgrAonFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write rom_ctrl's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_rom_ctrl_alert_force(&rom_ctrl, kDifRomCtrlAlertFatal + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdRomCtrlFatal + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write rstmgr's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_rstmgr_alert_force(&rstmgr_aon, kDifRstmgrAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdRstmgrAonFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write rv_core_ibex's alert_test reg and check alert_cause. |
| for (int i = 0; i < 4; ++i) { |
| CHECK_DIF_OK(dif_rv_core_ibex_alert_force(&rv_core_ibex, kDifRvCoreIbexAlertFatalSwErr + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdRvCoreIbexFatalSwErr + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write rv_plic's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_rv_plic_alert_force(&rv_plic, kDifRvPlicAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdRvPlicFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write rv_timer's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_rv_timer_alert_force(&rv_timer, kDifRvTimerAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdRvTimerFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write sensor_ctrl's alert_test reg and check alert_cause. |
| for (int i = 0; i < 2; ++i) { |
| CHECK_DIF_OK(dif_sensor_ctrl_alert_force(&sensor_ctrl, kDifSensorCtrlAlertRecovAlert + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdSensorCtrlRecovAlert + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write spi_device's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_spi_device_alert_force(&spi_device, kDifSpiDeviceAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdSpiDeviceFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write spi_host's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_spi_host_alert_force(&spi_host0, kDifSpiHostAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdSpiHost0FatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write spi_host's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_spi_host_alert_force(&spi_host1, kDifSpiHostAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdSpiHost1FatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write sram_ctrl's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_sram_ctrl_alert_force(&sram_ctrl_main, kDifSramCtrlAlertFatalError + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdSramCtrlMainFatalError + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write sram_ctrl's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_sram_ctrl_alert_force(&sram_ctrl_ret_aon, kDifSramCtrlAlertFatalError + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdSramCtrlRetAonFatalError + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write sysrst_ctrl's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_sysrst_ctrl_alert_force(&sysrst_ctrl_aon, kDifSysrstCtrlAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdSysrstCtrlAonFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write uart's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_uart_alert_force(&uart0, kDifUartAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdUart0FatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write uart's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_uart_alert_force(&uart1, kDifUartAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdUart1FatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write uart's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_uart_alert_force(&uart2, kDifUartAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdUart2FatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write uart's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_uart_alert_force(&uart3, kDifUartAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdUart3FatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| |
| // Write usbdev's alert_test reg and check alert_cause. |
| for (int i = 0; i < 1; ++i) { |
| CHECK_DIF_OK(dif_usbdev_alert_force(&usbdev, kDifUsbdevAlertFatalFault + i)); |
| |
| // Verify that alert handler received it. |
| exp_alert = kTopEarlgreyAlertIdUsbdevFatalFault + i; |
| CHECK_DIF_OK(dif_alert_handler_alert_is_cause( |
| &alert_handler, exp_alert, &is_cause)); |
| CHECK(is_cause, "Expect alert %d!", exp_alert); |
| |
| // Clear alert cause register |
| CHECK_DIF_OK(dif_alert_handler_alert_acknowledge( |
| &alert_handler, exp_alert)); |
| } |
| } |
| |
| bool test_main(void) { |
| init_peripherals(); |
| alert_handler_config(); |
| trigger_alert_test(); |
| return true; |
| } |