| // Copyright lowRISC contributors. |
| // Licensed under the Apache License, Version 2.0, see LICENSE for details. |
| // SPDX-License-Identifier: Apache-2.0 |
| |
| #ifndef OPENTITAN_HW_TOP_EARLGREY_SW_AUTOGEN_TOP_EARLGREY_H_ |
| #define OPENTITAN_HW_TOP_EARLGREY_SW_AUTOGEN_TOP_EARLGREY_H_ |
| |
| /** |
| * @file |
| * @brief Top-specific Definitions |
| * |
| * This file contains preprocessor and type definitions for use within the |
| * device C/C++ codebase. |
| * |
| * These definitions are for information that depends on the top-specific chip |
| * configuration, which includes: |
| * - Device Memory Information (for Peripherals and Memory) |
| * - PLIC Interrupt ID Names and Source Mappings |
| * - Alert ID Names and Source Mappings |
| * - Pinmux Pin/Select Names |
| * - Power Manager Wakeups |
| */ |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| /** |
| * Peripheral base address for uart0 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_UART0_BASE_ADDR 0x40000000u |
| |
| /** |
| * Peripheral size for uart0 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_UART0_BASE_ADDR and |
| * `TOP_EARLGREY_UART0_BASE_ADDR + TOP_EARLGREY_UART0_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_UART0_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for uart1 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_UART1_BASE_ADDR 0x40010000u |
| |
| /** |
| * Peripheral size for uart1 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_UART1_BASE_ADDR and |
| * `TOP_EARLGREY_UART1_BASE_ADDR + TOP_EARLGREY_UART1_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_UART1_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for uart2 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_UART2_BASE_ADDR 0x40020000u |
| |
| /** |
| * Peripheral size for uart2 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_UART2_BASE_ADDR and |
| * `TOP_EARLGREY_UART2_BASE_ADDR + TOP_EARLGREY_UART2_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_UART2_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for uart3 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_UART3_BASE_ADDR 0x40030000u |
| |
| /** |
| * Peripheral size for uart3 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_UART3_BASE_ADDR and |
| * `TOP_EARLGREY_UART3_BASE_ADDR + TOP_EARLGREY_UART3_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_UART3_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for gpio in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_GPIO_BASE_ADDR 0x40040000u |
| |
| /** |
| * Peripheral size for gpio in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_GPIO_BASE_ADDR and |
| * `TOP_EARLGREY_GPIO_BASE_ADDR + TOP_EARLGREY_GPIO_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_GPIO_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for spi_device in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_SPI_DEVICE_BASE_ADDR 0x40050000u |
| |
| /** |
| * Peripheral size for spi_device in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_SPI_DEVICE_BASE_ADDR and |
| * `TOP_EARLGREY_SPI_DEVICE_BASE_ADDR + TOP_EARLGREY_SPI_DEVICE_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_SPI_DEVICE_SIZE_BYTES 0x2000u |
| |
| /** |
| * Peripheral base address for i2c0 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_I2C0_BASE_ADDR 0x40080000u |
| |
| /** |
| * Peripheral size for i2c0 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_I2C0_BASE_ADDR and |
| * `TOP_EARLGREY_I2C0_BASE_ADDR + TOP_EARLGREY_I2C0_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_I2C0_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for i2c1 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_I2C1_BASE_ADDR 0x40090000u |
| |
| /** |
| * Peripheral size for i2c1 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_I2C1_BASE_ADDR and |
| * `TOP_EARLGREY_I2C1_BASE_ADDR + TOP_EARLGREY_I2C1_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_I2C1_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for i2c2 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_I2C2_BASE_ADDR 0x400A0000u |
| |
| /** |
| * Peripheral size for i2c2 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_I2C2_BASE_ADDR and |
| * `TOP_EARLGREY_I2C2_BASE_ADDR + TOP_EARLGREY_I2C2_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_I2C2_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for pattgen in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_PATTGEN_BASE_ADDR 0x400E0000u |
| |
| /** |
| * Peripheral size for pattgen in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_PATTGEN_BASE_ADDR and |
| * `TOP_EARLGREY_PATTGEN_BASE_ADDR + TOP_EARLGREY_PATTGEN_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_PATTGEN_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for rv_timer in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_RV_TIMER_BASE_ADDR 0x40100000u |
| |
| /** |
| * Peripheral size for rv_timer in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_RV_TIMER_BASE_ADDR and |
| * `TOP_EARLGREY_RV_TIMER_BASE_ADDR + TOP_EARLGREY_RV_TIMER_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_RV_TIMER_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for core device on otp_ctrl in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_OTP_CTRL_CORE_BASE_ADDR 0x40130000u |
| |
| /** |
| * Peripheral size for core device on otp_ctrl in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_OTP_CTRL_CORE_BASE_ADDR and |
| * `TOP_EARLGREY_OTP_CTRL_CORE_BASE_ADDR + TOP_EARLGREY_OTP_CTRL_CORE_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_OTP_CTRL_CORE_SIZE_BYTES 0x2000u |
| |
| /** |
| * Peripheral base address for prim device on otp_ctrl in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_OTP_CTRL_PRIM_BASE_ADDR 0x40132000u |
| |
| /** |
| * Peripheral size for prim device on otp_ctrl in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_OTP_CTRL_PRIM_BASE_ADDR and |
| * `TOP_EARLGREY_OTP_CTRL_PRIM_BASE_ADDR + TOP_EARLGREY_OTP_CTRL_PRIM_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_OTP_CTRL_PRIM_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for lc_ctrl in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_LC_CTRL_BASE_ADDR 0x40140000u |
| |
| /** |
| * Peripheral size for lc_ctrl in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_LC_CTRL_BASE_ADDR and |
| * `TOP_EARLGREY_LC_CTRL_BASE_ADDR + TOP_EARLGREY_LC_CTRL_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_LC_CTRL_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for alert_handler in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_ALERT_HANDLER_BASE_ADDR 0x40150000u |
| |
| /** |
| * Peripheral size for alert_handler in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_ALERT_HANDLER_BASE_ADDR and |
| * `TOP_EARLGREY_ALERT_HANDLER_BASE_ADDR + TOP_EARLGREY_ALERT_HANDLER_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_ALERT_HANDLER_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for spi_host0 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_SPI_HOST0_BASE_ADDR 0x40300000u |
| |
| /** |
| * Peripheral size for spi_host0 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_SPI_HOST0_BASE_ADDR and |
| * `TOP_EARLGREY_SPI_HOST0_BASE_ADDR + TOP_EARLGREY_SPI_HOST0_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_SPI_HOST0_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for spi_host1 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_SPI_HOST1_BASE_ADDR 0x40310000u |
| |
| /** |
| * Peripheral size for spi_host1 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_SPI_HOST1_BASE_ADDR and |
| * `TOP_EARLGREY_SPI_HOST1_BASE_ADDR + TOP_EARLGREY_SPI_HOST1_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_SPI_HOST1_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for usbdev in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_USBDEV_BASE_ADDR 0x40320000u |
| |
| /** |
| * Peripheral size for usbdev in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_USBDEV_BASE_ADDR and |
| * `TOP_EARLGREY_USBDEV_BASE_ADDR + TOP_EARLGREY_USBDEV_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_USBDEV_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for pwrmgr_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_PWRMGR_AON_BASE_ADDR 0x40400000u |
| |
| /** |
| * Peripheral size for pwrmgr_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_PWRMGR_AON_BASE_ADDR and |
| * `TOP_EARLGREY_PWRMGR_AON_BASE_ADDR + TOP_EARLGREY_PWRMGR_AON_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_PWRMGR_AON_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for rstmgr_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_RSTMGR_AON_BASE_ADDR 0x40410000u |
| |
| /** |
| * Peripheral size for rstmgr_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_RSTMGR_AON_BASE_ADDR and |
| * `TOP_EARLGREY_RSTMGR_AON_BASE_ADDR + TOP_EARLGREY_RSTMGR_AON_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_RSTMGR_AON_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for clkmgr_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_CLKMGR_AON_BASE_ADDR 0x40420000u |
| |
| /** |
| * Peripheral size for clkmgr_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_CLKMGR_AON_BASE_ADDR and |
| * `TOP_EARLGREY_CLKMGR_AON_BASE_ADDR + TOP_EARLGREY_CLKMGR_AON_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_CLKMGR_AON_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for sysrst_ctrl_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_SYSRST_CTRL_AON_BASE_ADDR 0x40430000u |
| |
| /** |
| * Peripheral size for sysrst_ctrl_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_SYSRST_CTRL_AON_BASE_ADDR and |
| * `TOP_EARLGREY_SYSRST_CTRL_AON_BASE_ADDR + TOP_EARLGREY_SYSRST_CTRL_AON_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_SYSRST_CTRL_AON_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for adc_ctrl_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_ADC_CTRL_AON_BASE_ADDR 0x40440000u |
| |
| /** |
| * Peripheral size for adc_ctrl_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_ADC_CTRL_AON_BASE_ADDR and |
| * `TOP_EARLGREY_ADC_CTRL_AON_BASE_ADDR + TOP_EARLGREY_ADC_CTRL_AON_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_ADC_CTRL_AON_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for pwm_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_PWM_AON_BASE_ADDR 0x40450000u |
| |
| /** |
| * Peripheral size for pwm_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_PWM_AON_BASE_ADDR and |
| * `TOP_EARLGREY_PWM_AON_BASE_ADDR + TOP_EARLGREY_PWM_AON_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_PWM_AON_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for pinmux_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_PINMUX_AON_BASE_ADDR 0x40460000u |
| |
| /** |
| * Peripheral size for pinmux_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_PINMUX_AON_BASE_ADDR and |
| * `TOP_EARLGREY_PINMUX_AON_BASE_ADDR + TOP_EARLGREY_PINMUX_AON_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_PINMUX_AON_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for aon_timer_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_AON_TIMER_AON_BASE_ADDR 0x40470000u |
| |
| /** |
| * Peripheral size for aon_timer_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_AON_TIMER_AON_BASE_ADDR and |
| * `TOP_EARLGREY_AON_TIMER_AON_BASE_ADDR + TOP_EARLGREY_AON_TIMER_AON_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_AON_TIMER_AON_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for ast in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_AST_BASE_ADDR 0x40480000u |
| |
| /** |
| * Peripheral size for ast in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_AST_BASE_ADDR and |
| * `TOP_EARLGREY_AST_BASE_ADDR + TOP_EARLGREY_AST_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_AST_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for sensor_ctrl in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_SENSOR_CTRL_BASE_ADDR 0x40490000u |
| |
| /** |
| * Peripheral size for sensor_ctrl in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_SENSOR_CTRL_BASE_ADDR and |
| * `TOP_EARLGREY_SENSOR_CTRL_BASE_ADDR + TOP_EARLGREY_SENSOR_CTRL_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_SENSOR_CTRL_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for regs device on sram_ctrl_ret_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_SRAM_CTRL_RET_AON_REGS_BASE_ADDR 0x40500000u |
| |
| /** |
| * Peripheral size for regs device on sram_ctrl_ret_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_SRAM_CTRL_RET_AON_REGS_BASE_ADDR and |
| * `TOP_EARLGREY_SRAM_CTRL_RET_AON_REGS_BASE_ADDR + TOP_EARLGREY_SRAM_CTRL_RET_AON_REGS_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_SRAM_CTRL_RET_AON_REGS_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for ram device on sram_ctrl_ret_aon in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_SRAM_CTRL_RET_AON_RAM_BASE_ADDR 0x40600000u |
| |
| /** |
| * Peripheral size for ram device on sram_ctrl_ret_aon in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_SRAM_CTRL_RET_AON_RAM_BASE_ADDR and |
| * `TOP_EARLGREY_SRAM_CTRL_RET_AON_RAM_BASE_ADDR + TOP_EARLGREY_SRAM_CTRL_RET_AON_RAM_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_SRAM_CTRL_RET_AON_RAM_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for core device on flash_ctrl in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_FLASH_CTRL_CORE_BASE_ADDR 0x41000000u |
| |
| /** |
| * Peripheral size for core device on flash_ctrl in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_FLASH_CTRL_CORE_BASE_ADDR and |
| * `TOP_EARLGREY_FLASH_CTRL_CORE_BASE_ADDR + TOP_EARLGREY_FLASH_CTRL_CORE_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_FLASH_CTRL_CORE_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for prim device on flash_ctrl in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_FLASH_CTRL_PRIM_BASE_ADDR 0x41008000u |
| |
| /** |
| * Peripheral size for prim device on flash_ctrl in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_FLASH_CTRL_PRIM_BASE_ADDR and |
| * `TOP_EARLGREY_FLASH_CTRL_PRIM_BASE_ADDR + TOP_EARLGREY_FLASH_CTRL_PRIM_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_FLASH_CTRL_PRIM_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for mem device on flash_ctrl in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_FLASH_CTRL_MEM_BASE_ADDR 0x20000000u |
| |
| /** |
| * Peripheral size for mem device on flash_ctrl in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_FLASH_CTRL_MEM_BASE_ADDR and |
| * `TOP_EARLGREY_FLASH_CTRL_MEM_BASE_ADDR + TOP_EARLGREY_FLASH_CTRL_MEM_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_FLASH_CTRL_MEM_SIZE_BYTES 0x100000u |
| |
| /** |
| * Peripheral base address for regs device on rv_dm in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_RV_DM_REGS_BASE_ADDR 0x41200000u |
| |
| /** |
| * Peripheral size for regs device on rv_dm in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_RV_DM_REGS_BASE_ADDR and |
| * `TOP_EARLGREY_RV_DM_REGS_BASE_ADDR + TOP_EARLGREY_RV_DM_REGS_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_RV_DM_REGS_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for rom device on rv_dm in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_RV_DM_ROM_BASE_ADDR 0x10000u |
| |
| /** |
| * Peripheral size for rom device on rv_dm in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_RV_DM_ROM_BASE_ADDR and |
| * `TOP_EARLGREY_RV_DM_ROM_BASE_ADDR + TOP_EARLGREY_RV_DM_ROM_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_RV_DM_ROM_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for rv_plic in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_RV_PLIC_BASE_ADDR 0x48000000u |
| |
| /** |
| * Peripheral size for rv_plic in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_RV_PLIC_BASE_ADDR and |
| * `TOP_EARLGREY_RV_PLIC_BASE_ADDR + TOP_EARLGREY_RV_PLIC_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_RV_PLIC_SIZE_BYTES 0x8000000u |
| |
| /** |
| * Peripheral base address for aes in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_AES_BASE_ADDR 0x41100000u |
| |
| /** |
| * Peripheral size for aes in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_AES_BASE_ADDR and |
| * `TOP_EARLGREY_AES_BASE_ADDR + TOP_EARLGREY_AES_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_AES_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for hmac in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_HMAC_BASE_ADDR 0x41110000u |
| |
| /** |
| * Peripheral size for hmac in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_HMAC_BASE_ADDR and |
| * `TOP_EARLGREY_HMAC_BASE_ADDR + TOP_EARLGREY_HMAC_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_HMAC_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for kmac in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_KMAC_BASE_ADDR 0x41120000u |
| |
| /** |
| * Peripheral size for kmac in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_KMAC_BASE_ADDR and |
| * `TOP_EARLGREY_KMAC_BASE_ADDR + TOP_EARLGREY_KMAC_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_KMAC_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for otbn in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_OTBN_BASE_ADDR 0x41130000u |
| |
| /** |
| * Peripheral size for otbn in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_OTBN_BASE_ADDR and |
| * `TOP_EARLGREY_OTBN_BASE_ADDR + TOP_EARLGREY_OTBN_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_OTBN_SIZE_BYTES 0x10000u |
| |
| /** |
| * Peripheral base address for keymgr in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_KEYMGR_BASE_ADDR 0x41140000u |
| |
| /** |
| * Peripheral size for keymgr in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_KEYMGR_BASE_ADDR and |
| * `TOP_EARLGREY_KEYMGR_BASE_ADDR + TOP_EARLGREY_KEYMGR_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_KEYMGR_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for csrng in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_CSRNG_BASE_ADDR 0x41150000u |
| |
| /** |
| * Peripheral size for csrng in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_CSRNG_BASE_ADDR and |
| * `TOP_EARLGREY_CSRNG_BASE_ADDR + TOP_EARLGREY_CSRNG_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_CSRNG_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for entropy_src in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_ENTROPY_SRC_BASE_ADDR 0x41160000u |
| |
| /** |
| * Peripheral size for entropy_src in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_ENTROPY_SRC_BASE_ADDR and |
| * `TOP_EARLGREY_ENTROPY_SRC_BASE_ADDR + TOP_EARLGREY_ENTROPY_SRC_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_ENTROPY_SRC_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for edn0 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_EDN0_BASE_ADDR 0x41170000u |
| |
| /** |
| * Peripheral size for edn0 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_EDN0_BASE_ADDR and |
| * `TOP_EARLGREY_EDN0_BASE_ADDR + TOP_EARLGREY_EDN0_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_EDN0_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for edn1 in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_EDN1_BASE_ADDR 0x41180000u |
| |
| /** |
| * Peripheral size for edn1 in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_EDN1_BASE_ADDR and |
| * `TOP_EARLGREY_EDN1_BASE_ADDR + TOP_EARLGREY_EDN1_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_EDN1_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for regs device on sram_ctrl_main in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_SRAM_CTRL_MAIN_REGS_BASE_ADDR 0x411C0000u |
| |
| /** |
| * Peripheral size for regs device on sram_ctrl_main in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_SRAM_CTRL_MAIN_REGS_BASE_ADDR and |
| * `TOP_EARLGREY_SRAM_CTRL_MAIN_REGS_BASE_ADDR + TOP_EARLGREY_SRAM_CTRL_MAIN_REGS_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_SRAM_CTRL_MAIN_REGS_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for ram device on sram_ctrl_main in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_SRAM_CTRL_MAIN_RAM_BASE_ADDR 0x10000000u |
| |
| /** |
| * Peripheral size for ram device on sram_ctrl_main in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_SRAM_CTRL_MAIN_RAM_BASE_ADDR and |
| * `TOP_EARLGREY_SRAM_CTRL_MAIN_RAM_BASE_ADDR + TOP_EARLGREY_SRAM_CTRL_MAIN_RAM_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_SRAM_CTRL_MAIN_RAM_SIZE_BYTES 0x20000u |
| |
| /** |
| * Peripheral base address for regs device on rom_ctrl in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_ROM_CTRL_REGS_BASE_ADDR 0x411E0000u |
| |
| /** |
| * Peripheral size for regs device on rom_ctrl in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_ROM_CTRL_REGS_BASE_ADDR and |
| * `TOP_EARLGREY_ROM_CTRL_REGS_BASE_ADDR + TOP_EARLGREY_ROM_CTRL_REGS_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_ROM_CTRL_REGS_SIZE_BYTES 0x1000u |
| |
| /** |
| * Peripheral base address for rom device on rom_ctrl in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_ROM_CTRL_ROM_BASE_ADDR 0x8000u |
| |
| /** |
| * Peripheral size for rom device on rom_ctrl in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_ROM_CTRL_ROM_BASE_ADDR and |
| * `TOP_EARLGREY_ROM_CTRL_ROM_BASE_ADDR + TOP_EARLGREY_ROM_CTRL_ROM_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_ROM_CTRL_ROM_SIZE_BYTES 0x8000u |
| |
| /** |
| * Peripheral base address for cfg device on rv_core_ibex in top earlgrey. |
| * |
| * This should be used with #mmio_region_from_addr to access the memory-mapped |
| * registers associated with the peripheral (usually via a DIF). |
| */ |
| #define TOP_EARLGREY_RV_CORE_IBEX_CFG_BASE_ADDR 0x411F0000u |
| |
| /** |
| * Peripheral size for cfg device on rv_core_ibex in top earlgrey. |
| * |
| * This is the size (in bytes) of the peripheral's reserved memory area. All |
| * memory-mapped registers associated with this peripheral should have an |
| * address between #TOP_EARLGREY_RV_CORE_IBEX_CFG_BASE_ADDR and |
| * `TOP_EARLGREY_RV_CORE_IBEX_CFG_BASE_ADDR + TOP_EARLGREY_RV_CORE_IBEX_CFG_SIZE_BYTES`. |
| */ |
| #define TOP_EARLGREY_RV_CORE_IBEX_CFG_SIZE_BYTES 0x1000u |
| |
| |
| /** |
| * Memory base address for ram_ret_aon in top earlgrey. |
| */ |
| #define TOP_EARLGREY_RAM_RET_AON_BASE_ADDR 0x40600000u |
| |
| /** |
| * Memory size for ram_ret_aon in top earlgrey. |
| */ |
| #define TOP_EARLGREY_RAM_RET_AON_SIZE_BYTES 0x1000u |
| |
| /** |
| * Memory base address for eflash in top earlgrey. |
| */ |
| #define TOP_EARLGREY_EFLASH_BASE_ADDR 0x20000000u |
| |
| /** |
| * Memory size for eflash in top earlgrey. |
| */ |
| #define TOP_EARLGREY_EFLASH_SIZE_BYTES 0x100000u |
| |
| /** |
| * Memory base address for ram_main in top earlgrey. |
| */ |
| #define TOP_EARLGREY_RAM_MAIN_BASE_ADDR 0x10000000u |
| |
| /** |
| * Memory size for ram_main in top earlgrey. |
| */ |
| #define TOP_EARLGREY_RAM_MAIN_SIZE_BYTES 0x20000u |
| |
| /** |
| * Memory base address for rom in top earlgrey. |
| */ |
| #define TOP_EARLGREY_ROM_BASE_ADDR 0x8000u |
| |
| /** |
| * Memory size for rom in top earlgrey. |
| */ |
| #define TOP_EARLGREY_ROM_SIZE_BYTES 0x8000u |
| |
| |
| /** |
| * PLIC Interrupt Source Peripheral. |
| * |
| * Enumeration used to determine which peripheral asserted the corresponding |
| * interrupt. |
| */ |
| typedef enum top_earlgrey_plic_peripheral { |
| kTopEarlgreyPlicPeripheralUnknown = 0, /**< Unknown Peripheral */ |
| kTopEarlgreyPlicPeripheralUart0 = 1, /**< uart0 */ |
| kTopEarlgreyPlicPeripheralUart1 = 2, /**< uart1 */ |
| kTopEarlgreyPlicPeripheralUart2 = 3, /**< uart2 */ |
| kTopEarlgreyPlicPeripheralUart3 = 4, /**< uart3 */ |
| kTopEarlgreyPlicPeripheralGpio = 5, /**< gpio */ |
| kTopEarlgreyPlicPeripheralSpiDevice = 6, /**< spi_device */ |
| kTopEarlgreyPlicPeripheralI2c0 = 7, /**< i2c0 */ |
| kTopEarlgreyPlicPeripheralI2c1 = 8, /**< i2c1 */ |
| kTopEarlgreyPlicPeripheralI2c2 = 9, /**< i2c2 */ |
| kTopEarlgreyPlicPeripheralPattgen = 10, /**< pattgen */ |
| kTopEarlgreyPlicPeripheralRvTimer = 11, /**< rv_timer */ |
| kTopEarlgreyPlicPeripheralOtpCtrl = 12, /**< otp_ctrl */ |
| kTopEarlgreyPlicPeripheralAlertHandler = 13, /**< alert_handler */ |
| kTopEarlgreyPlicPeripheralSpiHost0 = 14, /**< spi_host0 */ |
| kTopEarlgreyPlicPeripheralSpiHost1 = 15, /**< spi_host1 */ |
| kTopEarlgreyPlicPeripheralUsbdev = 16, /**< usbdev */ |
| kTopEarlgreyPlicPeripheralPwrmgrAon = 17, /**< pwrmgr_aon */ |
| kTopEarlgreyPlicPeripheralSysrstCtrlAon = 18, /**< sysrst_ctrl_aon */ |
| kTopEarlgreyPlicPeripheralAdcCtrlAon = 19, /**< adc_ctrl_aon */ |
| kTopEarlgreyPlicPeripheralAonTimerAon = 20, /**< aon_timer_aon */ |
| kTopEarlgreyPlicPeripheralSensorCtrl = 21, /**< sensor_ctrl */ |
| kTopEarlgreyPlicPeripheralFlashCtrl = 22, /**< flash_ctrl */ |
| kTopEarlgreyPlicPeripheralHmac = 23, /**< hmac */ |
| kTopEarlgreyPlicPeripheralKmac = 24, /**< kmac */ |
| kTopEarlgreyPlicPeripheralOtbn = 25, /**< otbn */ |
| kTopEarlgreyPlicPeripheralKeymgr = 26, /**< keymgr */ |
| kTopEarlgreyPlicPeripheralCsrng = 27, /**< csrng */ |
| kTopEarlgreyPlicPeripheralEntropySrc = 28, /**< entropy_src */ |
| kTopEarlgreyPlicPeripheralEdn0 = 29, /**< edn0 */ |
| kTopEarlgreyPlicPeripheralEdn1 = 30, /**< edn1 */ |
| kTopEarlgreyPlicPeripheralLast = 30, /**< \internal Final PLIC peripheral */ |
| } top_earlgrey_plic_peripheral_t; |
| |
| /** |
| * PLIC Interrupt Source. |
| * |
| * Enumeration of all PLIC interrupt sources. The interrupt sources belonging to |
| * the same peripheral are guaranteed to be consecutive. |
| */ |
| typedef enum top_earlgrey_plic_irq_id { |
| kTopEarlgreyPlicIrqIdNone = 0, /**< No Interrupt */ |
| kTopEarlgreyPlicIrqIdUart0TxWatermark = 1, /**< uart0_tx_watermark */ |
| kTopEarlgreyPlicIrqIdUart0RxWatermark = 2, /**< uart0_rx_watermark */ |
| kTopEarlgreyPlicIrqIdUart0TxEmpty = 3, /**< uart0_tx_empty */ |
| kTopEarlgreyPlicIrqIdUart0RxOverflow = 4, /**< uart0_rx_overflow */ |
| kTopEarlgreyPlicIrqIdUart0RxFrameErr = 5, /**< uart0_rx_frame_err */ |
| kTopEarlgreyPlicIrqIdUart0RxBreakErr = 6, /**< uart0_rx_break_err */ |
| kTopEarlgreyPlicIrqIdUart0RxTimeout = 7, /**< uart0_rx_timeout */ |
| kTopEarlgreyPlicIrqIdUart0RxParityErr = 8, /**< uart0_rx_parity_err */ |
| kTopEarlgreyPlicIrqIdUart1TxWatermark = 9, /**< uart1_tx_watermark */ |
| kTopEarlgreyPlicIrqIdUart1RxWatermark = 10, /**< uart1_rx_watermark */ |
| kTopEarlgreyPlicIrqIdUart1TxEmpty = 11, /**< uart1_tx_empty */ |
| kTopEarlgreyPlicIrqIdUart1RxOverflow = 12, /**< uart1_rx_overflow */ |
| kTopEarlgreyPlicIrqIdUart1RxFrameErr = 13, /**< uart1_rx_frame_err */ |
| kTopEarlgreyPlicIrqIdUart1RxBreakErr = 14, /**< uart1_rx_break_err */ |
| kTopEarlgreyPlicIrqIdUart1RxTimeout = 15, /**< uart1_rx_timeout */ |
| kTopEarlgreyPlicIrqIdUart1RxParityErr = 16, /**< uart1_rx_parity_err */ |
| kTopEarlgreyPlicIrqIdUart2TxWatermark = 17, /**< uart2_tx_watermark */ |
| kTopEarlgreyPlicIrqIdUart2RxWatermark = 18, /**< uart2_rx_watermark */ |
| kTopEarlgreyPlicIrqIdUart2TxEmpty = 19, /**< uart2_tx_empty */ |
| kTopEarlgreyPlicIrqIdUart2RxOverflow = 20, /**< uart2_rx_overflow */ |
| kTopEarlgreyPlicIrqIdUart2RxFrameErr = 21, /**< uart2_rx_frame_err */ |
| kTopEarlgreyPlicIrqIdUart2RxBreakErr = 22, /**< uart2_rx_break_err */ |
| kTopEarlgreyPlicIrqIdUart2RxTimeout = 23, /**< uart2_rx_timeout */ |
| kTopEarlgreyPlicIrqIdUart2RxParityErr = 24, /**< uart2_rx_parity_err */ |
| kTopEarlgreyPlicIrqIdUart3TxWatermark = 25, /**< uart3_tx_watermark */ |
| kTopEarlgreyPlicIrqIdUart3RxWatermark = 26, /**< uart3_rx_watermark */ |
| kTopEarlgreyPlicIrqIdUart3TxEmpty = 27, /**< uart3_tx_empty */ |
| kTopEarlgreyPlicIrqIdUart3RxOverflow = 28, /**< uart3_rx_overflow */ |
| kTopEarlgreyPlicIrqIdUart3RxFrameErr = 29, /**< uart3_rx_frame_err */ |
| kTopEarlgreyPlicIrqIdUart3RxBreakErr = 30, /**< uart3_rx_break_err */ |
| kTopEarlgreyPlicIrqIdUart3RxTimeout = 31, /**< uart3_rx_timeout */ |
| kTopEarlgreyPlicIrqIdUart3RxParityErr = 32, /**< uart3_rx_parity_err */ |
| kTopEarlgreyPlicIrqIdGpioGpio0 = 33, /**< gpio_gpio 0 */ |
| kTopEarlgreyPlicIrqIdGpioGpio1 = 34, /**< gpio_gpio 1 */ |
| kTopEarlgreyPlicIrqIdGpioGpio2 = 35, /**< gpio_gpio 2 */ |
| kTopEarlgreyPlicIrqIdGpioGpio3 = 36, /**< gpio_gpio 3 */ |
| kTopEarlgreyPlicIrqIdGpioGpio4 = 37, /**< gpio_gpio 4 */ |
| kTopEarlgreyPlicIrqIdGpioGpio5 = 38, /**< gpio_gpio 5 */ |
| kTopEarlgreyPlicIrqIdGpioGpio6 = 39, /**< gpio_gpio 6 */ |
| kTopEarlgreyPlicIrqIdGpioGpio7 = 40, /**< gpio_gpio 7 */ |
| kTopEarlgreyPlicIrqIdGpioGpio8 = 41, /**< gpio_gpio 8 */ |
| kTopEarlgreyPlicIrqIdGpioGpio9 = 42, /**< gpio_gpio 9 */ |
| kTopEarlgreyPlicIrqIdGpioGpio10 = 43, /**< gpio_gpio 10 */ |
| kTopEarlgreyPlicIrqIdGpioGpio11 = 44, /**< gpio_gpio 11 */ |
| kTopEarlgreyPlicIrqIdGpioGpio12 = 45, /**< gpio_gpio 12 */ |
| kTopEarlgreyPlicIrqIdGpioGpio13 = 46, /**< gpio_gpio 13 */ |
| kTopEarlgreyPlicIrqIdGpioGpio14 = 47, /**< gpio_gpio 14 */ |
| kTopEarlgreyPlicIrqIdGpioGpio15 = 48, /**< gpio_gpio 15 */ |
| kTopEarlgreyPlicIrqIdGpioGpio16 = 49, /**< gpio_gpio 16 */ |
| kTopEarlgreyPlicIrqIdGpioGpio17 = 50, /**< gpio_gpio 17 */ |
| kTopEarlgreyPlicIrqIdGpioGpio18 = 51, /**< gpio_gpio 18 */ |
| kTopEarlgreyPlicIrqIdGpioGpio19 = 52, /**< gpio_gpio 19 */ |
| kTopEarlgreyPlicIrqIdGpioGpio20 = 53, /**< gpio_gpio 20 */ |
| kTopEarlgreyPlicIrqIdGpioGpio21 = 54, /**< gpio_gpio 21 */ |
| kTopEarlgreyPlicIrqIdGpioGpio22 = 55, /**< gpio_gpio 22 */ |
| kTopEarlgreyPlicIrqIdGpioGpio23 = 56, /**< gpio_gpio 23 */ |
| kTopEarlgreyPlicIrqIdGpioGpio24 = 57, /**< gpio_gpio 24 */ |
| kTopEarlgreyPlicIrqIdGpioGpio25 = 58, /**< gpio_gpio 25 */ |
| kTopEarlgreyPlicIrqIdGpioGpio26 = 59, /**< gpio_gpio 26 */ |
| kTopEarlgreyPlicIrqIdGpioGpio27 = 60, /**< gpio_gpio 27 */ |
| kTopEarlgreyPlicIrqIdGpioGpio28 = 61, /**< gpio_gpio 28 */ |
| kTopEarlgreyPlicIrqIdGpioGpio29 = 62, /**< gpio_gpio 29 */ |
| kTopEarlgreyPlicIrqIdGpioGpio30 = 63, /**< gpio_gpio 30 */ |
| kTopEarlgreyPlicIrqIdGpioGpio31 = 64, /**< gpio_gpio 31 */ |
| kTopEarlgreyPlicIrqIdSpiDeviceGenericRxFull = 65, /**< spi_device_generic_rx_full */ |
| kTopEarlgreyPlicIrqIdSpiDeviceGenericRxWatermark = 66, /**< spi_device_generic_rx_watermark */ |
| kTopEarlgreyPlicIrqIdSpiDeviceGenericTxWatermark = 67, /**< spi_device_generic_tx_watermark */ |
| kTopEarlgreyPlicIrqIdSpiDeviceGenericRxError = 68, /**< spi_device_generic_rx_error */ |
| kTopEarlgreyPlicIrqIdSpiDeviceGenericRxOverflow = 69, /**< spi_device_generic_rx_overflow */ |
| kTopEarlgreyPlicIrqIdSpiDeviceGenericTxUnderflow = 70, /**< spi_device_generic_tx_underflow */ |
| kTopEarlgreyPlicIrqIdSpiDeviceUploadCmdfifoNotEmpty = 71, /**< spi_device_upload_cmdfifo_not_empty */ |
| kTopEarlgreyPlicIrqIdSpiDeviceUploadPayloadNotEmpty = 72, /**< spi_device_upload_payload_not_empty */ |
| kTopEarlgreyPlicIrqIdSpiDeviceUploadPayloadOverflow = 73, /**< spi_device_upload_payload_overflow */ |
| kTopEarlgreyPlicIrqIdSpiDeviceReadbufWatermark = 74, /**< spi_device_readbuf_watermark */ |
| kTopEarlgreyPlicIrqIdSpiDeviceReadbufFlip = 75, /**< spi_device_readbuf_flip */ |
| kTopEarlgreyPlicIrqIdSpiDeviceTpmHeaderNotEmpty = 76, /**< spi_device_tpm_header_not_empty */ |
| kTopEarlgreyPlicIrqIdI2c0FmtWatermark = 77, /**< i2c0_fmt_watermark */ |
| kTopEarlgreyPlicIrqIdI2c0RxWatermark = 78, /**< i2c0_rx_watermark */ |
| kTopEarlgreyPlicIrqIdI2c0FmtOverflow = 79, /**< i2c0_fmt_overflow */ |
| kTopEarlgreyPlicIrqIdI2c0RxOverflow = 80, /**< i2c0_rx_overflow */ |
| kTopEarlgreyPlicIrqIdI2c0Nak = 81, /**< i2c0_nak */ |
| kTopEarlgreyPlicIrqIdI2c0SclInterference = 82, /**< i2c0_scl_interference */ |
| kTopEarlgreyPlicIrqIdI2c0SdaInterference = 83, /**< i2c0_sda_interference */ |
| kTopEarlgreyPlicIrqIdI2c0StretchTimeout = 84, /**< i2c0_stretch_timeout */ |
| kTopEarlgreyPlicIrqIdI2c0SdaUnstable = 85, /**< i2c0_sda_unstable */ |
| kTopEarlgreyPlicIrqIdI2c0TransComplete = 86, /**< i2c0_trans_complete */ |
| kTopEarlgreyPlicIrqIdI2c0TxEmpty = 87, /**< i2c0_tx_empty */ |
| kTopEarlgreyPlicIrqIdI2c0TxNonempty = 88, /**< i2c0_tx_nonempty */ |
| kTopEarlgreyPlicIrqIdI2c0TxOverflow = 89, /**< i2c0_tx_overflow */ |
| kTopEarlgreyPlicIrqIdI2c0AcqOverflow = 90, /**< i2c0_acq_overflow */ |
| kTopEarlgreyPlicIrqIdI2c0AckStop = 91, /**< i2c0_ack_stop */ |
| kTopEarlgreyPlicIrqIdI2c0HostTimeout = 92, /**< i2c0_host_timeout */ |
| kTopEarlgreyPlicIrqIdI2c1FmtWatermark = 93, /**< i2c1_fmt_watermark */ |
| kTopEarlgreyPlicIrqIdI2c1RxWatermark = 94, /**< i2c1_rx_watermark */ |
| kTopEarlgreyPlicIrqIdI2c1FmtOverflow = 95, /**< i2c1_fmt_overflow */ |
| kTopEarlgreyPlicIrqIdI2c1RxOverflow = 96, /**< i2c1_rx_overflow */ |
| kTopEarlgreyPlicIrqIdI2c1Nak = 97, /**< i2c1_nak */ |
| kTopEarlgreyPlicIrqIdI2c1SclInterference = 98, /**< i2c1_scl_interference */ |
| kTopEarlgreyPlicIrqIdI2c1SdaInterference = 99, /**< i2c1_sda_interference */ |
| kTopEarlgreyPlicIrqIdI2c1StretchTimeout = 100, /**< i2c1_stretch_timeout */ |
| kTopEarlgreyPlicIrqIdI2c1SdaUnstable = 101, /**< i2c1_sda_unstable */ |
| kTopEarlgreyPlicIrqIdI2c1TransComplete = 102, /**< i2c1_trans_complete */ |
| kTopEarlgreyPlicIrqIdI2c1TxEmpty = 103, /**< i2c1_tx_empty */ |
| kTopEarlgreyPlicIrqIdI2c1TxNonempty = 104, /**< i2c1_tx_nonempty */ |
| kTopEarlgreyPlicIrqIdI2c1TxOverflow = 105, /**< i2c1_tx_overflow */ |
| kTopEarlgreyPlicIrqIdI2c1AcqOverflow = 106, /**< i2c1_acq_overflow */ |
| kTopEarlgreyPlicIrqIdI2c1AckStop = 107, /**< i2c1_ack_stop */ |
| kTopEarlgreyPlicIrqIdI2c1HostTimeout = 108, /**< i2c1_host_timeout */ |
| kTopEarlgreyPlicIrqIdI2c2FmtWatermark = 109, /**< i2c2_fmt_watermark */ |
| kTopEarlgreyPlicIrqIdI2c2RxWatermark = 110, /**< i2c2_rx_watermark */ |
| kTopEarlgreyPlicIrqIdI2c2FmtOverflow = 111, /**< i2c2_fmt_overflow */ |
| kTopEarlgreyPlicIrqIdI2c2RxOverflow = 112, /**< i2c2_rx_overflow */ |
| kTopEarlgreyPlicIrqIdI2c2Nak = 113, /**< i2c2_nak */ |
| kTopEarlgreyPlicIrqIdI2c2SclInterference = 114, /**< i2c2_scl_interference */ |
| kTopEarlgreyPlicIrqIdI2c2SdaInterference = 115, /**< i2c2_sda_interference */ |
| kTopEarlgreyPlicIrqIdI2c2StretchTimeout = 116, /**< i2c2_stretch_timeout */ |
| kTopEarlgreyPlicIrqIdI2c2SdaUnstable = 117, /**< i2c2_sda_unstable */ |
| kTopEarlgreyPlicIrqIdI2c2TransComplete = 118, /**< i2c2_trans_complete */ |
| kTopEarlgreyPlicIrqIdI2c2TxEmpty = 119, /**< i2c2_tx_empty */ |
| kTopEarlgreyPlicIrqIdI2c2TxNonempty = 120, /**< i2c2_tx_nonempty */ |
| kTopEarlgreyPlicIrqIdI2c2TxOverflow = 121, /**< i2c2_tx_overflow */ |
| kTopEarlgreyPlicIrqIdI2c2AcqOverflow = 122, /**< i2c2_acq_overflow */ |
| kTopEarlgreyPlicIrqIdI2c2AckStop = 123, /**< i2c2_ack_stop */ |
| kTopEarlgreyPlicIrqIdI2c2HostTimeout = 124, /**< i2c2_host_timeout */ |
| kTopEarlgreyPlicIrqIdPattgenDoneCh0 = 125, /**< pattgen_done_ch0 */ |
| kTopEarlgreyPlicIrqIdPattgenDoneCh1 = 126, /**< pattgen_done_ch1 */ |
| kTopEarlgreyPlicIrqIdRvTimerTimerExpiredHart0Timer0 = 127, /**< rv_timer_timer_expired_hart0_timer0 */ |
| kTopEarlgreyPlicIrqIdOtpCtrlOtpOperationDone = 128, /**< otp_ctrl_otp_operation_done */ |
| kTopEarlgreyPlicIrqIdOtpCtrlOtpError = 129, /**< otp_ctrl_otp_error */ |
| kTopEarlgreyPlicIrqIdAlertHandlerClassa = 130, /**< alert_handler_classa */ |
| kTopEarlgreyPlicIrqIdAlertHandlerClassb = 131, /**< alert_handler_classb */ |
| kTopEarlgreyPlicIrqIdAlertHandlerClassc = 132, /**< alert_handler_classc */ |
| kTopEarlgreyPlicIrqIdAlertHandlerClassd = 133, /**< alert_handler_classd */ |
| kTopEarlgreyPlicIrqIdSpiHost0Error = 134, /**< spi_host0_error */ |
| kTopEarlgreyPlicIrqIdSpiHost0SpiEvent = 135, /**< spi_host0_spi_event */ |
| kTopEarlgreyPlicIrqIdSpiHost1Error = 136, /**< spi_host1_error */ |
| kTopEarlgreyPlicIrqIdSpiHost1SpiEvent = 137, /**< spi_host1_spi_event */ |
| kTopEarlgreyPlicIrqIdUsbdevPktReceived = 138, /**< usbdev_pkt_received */ |
| kTopEarlgreyPlicIrqIdUsbdevPktSent = 139, /**< usbdev_pkt_sent */ |
| kTopEarlgreyPlicIrqIdUsbdevDisconnected = 140, /**< usbdev_disconnected */ |
| kTopEarlgreyPlicIrqIdUsbdevHostLost = 141, /**< usbdev_host_lost */ |
| kTopEarlgreyPlicIrqIdUsbdevLinkReset = 142, /**< usbdev_link_reset */ |
| kTopEarlgreyPlicIrqIdUsbdevLinkSuspend = 143, /**< usbdev_link_suspend */ |
| kTopEarlgreyPlicIrqIdUsbdevLinkResume = 144, /**< usbdev_link_resume */ |
| kTopEarlgreyPlicIrqIdUsbdevAvEmpty = 145, /**< usbdev_av_empty */ |
| kTopEarlgreyPlicIrqIdUsbdevRxFull = 146, /**< usbdev_rx_full */ |
| kTopEarlgreyPlicIrqIdUsbdevAvOverflow = 147, /**< usbdev_av_overflow */ |
| kTopEarlgreyPlicIrqIdUsbdevLinkInErr = 148, /**< usbdev_link_in_err */ |
| kTopEarlgreyPlicIrqIdUsbdevRxCrcErr = 149, /**< usbdev_rx_crc_err */ |
| kTopEarlgreyPlicIrqIdUsbdevRxPidErr = 150, /**< usbdev_rx_pid_err */ |
| kTopEarlgreyPlicIrqIdUsbdevRxBitstuffErr = 151, /**< usbdev_rx_bitstuff_err */ |
| kTopEarlgreyPlicIrqIdUsbdevFrame = 152, /**< usbdev_frame */ |
| kTopEarlgreyPlicIrqIdUsbdevPowered = 153, /**< usbdev_powered */ |
| kTopEarlgreyPlicIrqIdUsbdevLinkOutErr = 154, /**< usbdev_link_out_err */ |
| kTopEarlgreyPlicIrqIdPwrmgrAonWakeup = 155, /**< pwrmgr_aon_wakeup */ |
| kTopEarlgreyPlicIrqIdSysrstCtrlAonSysrstCtrl = 156, /**< sysrst_ctrl_aon_sysrst_ctrl */ |
| kTopEarlgreyPlicIrqIdAdcCtrlAonDebugCable = 157, /**< adc_ctrl_aon_debug_cable */ |
| kTopEarlgreyPlicIrqIdAonTimerAonWkupTimerExpired = 158, /**< aon_timer_aon_wkup_timer_expired */ |
| kTopEarlgreyPlicIrqIdAonTimerAonWdogTimerBark = 159, /**< aon_timer_aon_wdog_timer_bark */ |
| kTopEarlgreyPlicIrqIdSensorCtrlIoStatusChange = 160, /**< sensor_ctrl_io_status_change */ |
| kTopEarlgreyPlicIrqIdSensorCtrlInitStatusChange = 161, /**< sensor_ctrl_init_status_change */ |
| kTopEarlgreyPlicIrqIdFlashCtrlProgEmpty = 162, /**< flash_ctrl_prog_empty */ |
| kTopEarlgreyPlicIrqIdFlashCtrlProgLvl = 163, /**< flash_ctrl_prog_lvl */ |
| kTopEarlgreyPlicIrqIdFlashCtrlRdFull = 164, /**< flash_ctrl_rd_full */ |
| kTopEarlgreyPlicIrqIdFlashCtrlRdLvl = 165, /**< flash_ctrl_rd_lvl */ |
| kTopEarlgreyPlicIrqIdFlashCtrlOpDone = 166, /**< flash_ctrl_op_done */ |
| kTopEarlgreyPlicIrqIdFlashCtrlCorrErr = 167, /**< flash_ctrl_corr_err */ |
| kTopEarlgreyPlicIrqIdHmacHmacDone = 168, /**< hmac_hmac_done */ |
| kTopEarlgreyPlicIrqIdHmacFifoEmpty = 169, /**< hmac_fifo_empty */ |
| kTopEarlgreyPlicIrqIdHmacHmacErr = 170, /**< hmac_hmac_err */ |
| kTopEarlgreyPlicIrqIdKmacKmacDone = 171, /**< kmac_kmac_done */ |
| kTopEarlgreyPlicIrqIdKmacFifoEmpty = 172, /**< kmac_fifo_empty */ |
| kTopEarlgreyPlicIrqIdKmacKmacErr = 173, /**< kmac_kmac_err */ |
| kTopEarlgreyPlicIrqIdOtbnDone = 174, /**< otbn_done */ |
| kTopEarlgreyPlicIrqIdKeymgrOpDone = 175, /**< keymgr_op_done */ |
| kTopEarlgreyPlicIrqIdCsrngCsCmdReqDone = 176, /**< csrng_cs_cmd_req_done */ |
| kTopEarlgreyPlicIrqIdCsrngCsEntropyReq = 177, /**< csrng_cs_entropy_req */ |
| kTopEarlgreyPlicIrqIdCsrngCsHwInstExc = 178, /**< csrng_cs_hw_inst_exc */ |
| kTopEarlgreyPlicIrqIdCsrngCsFatalErr = 179, /**< csrng_cs_fatal_err */ |
| kTopEarlgreyPlicIrqIdEntropySrcEsEntropyValid = 180, /**< entropy_src_es_entropy_valid */ |
| kTopEarlgreyPlicIrqIdEntropySrcEsHealthTestFailed = 181, /**< entropy_src_es_health_test_failed */ |
| kTopEarlgreyPlicIrqIdEntropySrcEsObserveFifoReady = 182, /**< entropy_src_es_observe_fifo_ready */ |
| kTopEarlgreyPlicIrqIdEntropySrcEsFatalErr = 183, /**< entropy_src_es_fatal_err */ |
| kTopEarlgreyPlicIrqIdEdn0EdnCmdReqDone = 184, /**< edn0_edn_cmd_req_done */ |
| kTopEarlgreyPlicIrqIdEdn0EdnFatalErr = 185, /**< edn0_edn_fatal_err */ |
| kTopEarlgreyPlicIrqIdEdn1EdnCmdReqDone = 186, /**< edn1_edn_cmd_req_done */ |
| kTopEarlgreyPlicIrqIdEdn1EdnFatalErr = 187, /**< edn1_edn_fatal_err */ |
| kTopEarlgreyPlicIrqIdLast = 187, /**< \internal The Last Valid Interrupt ID. */ |
| } top_earlgrey_plic_irq_id_t; |
| |
| /** |
| * PLIC Interrupt Source to Peripheral Map |
| * |
| * This array is a mapping from `top_earlgrey_plic_irq_id_t` to |
| * `top_earlgrey_plic_peripheral_t`. |
| */ |
| extern const top_earlgrey_plic_peripheral_t |
| top_earlgrey_plic_interrupt_for_peripheral[188]; |
| |
| /** |
| * PLIC Interrupt Target. |
| * |
| * Enumeration used to determine which set of IE, CC, threshold registers to |
| * access for a given interrupt target. |
| */ |
| typedef enum top_earlgrey_plic_target { |
| kTopEarlgreyPlicTargetIbex0 = 0, /**< Ibex Core 0 */ |
| kTopEarlgreyPlicTargetLast = 0, /**< \internal Final PLIC target */ |
| } top_earlgrey_plic_target_t; |
| |
| /** |
| * Alert Handler Source Peripheral. |
| * |
| * Enumeration used to determine which peripheral asserted the corresponding |
| * alert. |
| */ |
| typedef enum top_earlgrey_alert_peripheral { |
| kTopEarlgreyAlertPeripheralUart0 = 0, /**< uart0 */ |
| kTopEarlgreyAlertPeripheralUart1 = 1, /**< uart1 */ |
| kTopEarlgreyAlertPeripheralUart2 = 2, /**< uart2 */ |
| kTopEarlgreyAlertPeripheralUart3 = 3, /**< uart3 */ |
| kTopEarlgreyAlertPeripheralGpio = 4, /**< gpio */ |
| kTopEarlgreyAlertPeripheralSpiDevice = 5, /**< spi_device */ |
| kTopEarlgreyAlertPeripheralI2c0 = 6, /**< i2c0 */ |
| kTopEarlgreyAlertPeripheralI2c1 = 7, /**< i2c1 */ |
| kTopEarlgreyAlertPeripheralI2c2 = 8, /**< i2c2 */ |
| kTopEarlgreyAlertPeripheralPattgen = 9, /**< pattgen */ |
| kTopEarlgreyAlertPeripheralRvTimer = 10, /**< rv_timer */ |
| kTopEarlgreyAlertPeripheralOtpCtrl = 11, /**< otp_ctrl */ |
| kTopEarlgreyAlertPeripheralLcCtrl = 12, /**< lc_ctrl */ |
| kTopEarlgreyAlertPeripheralSpiHost0 = 13, /**< spi_host0 */ |
| kTopEarlgreyAlertPeripheralSpiHost1 = 14, /**< spi_host1 */ |
| kTopEarlgreyAlertPeripheralUsbdev = 15, /**< usbdev */ |
| kTopEarlgreyAlertPeripheralPwrmgrAon = 16, /**< pwrmgr_aon */ |
| kTopEarlgreyAlertPeripheralRstmgrAon = 17, /**< rstmgr_aon */ |
| kTopEarlgreyAlertPeripheralClkmgrAon = 18, /**< clkmgr_aon */ |
| kTopEarlgreyAlertPeripheralSysrstCtrlAon = 19, /**< sysrst_ctrl_aon */ |
| kTopEarlgreyAlertPeripheralAdcCtrlAon = 20, /**< adc_ctrl_aon */ |
| kTopEarlgreyAlertPeripheralPwmAon = 21, /**< pwm_aon */ |
| kTopEarlgreyAlertPeripheralPinmuxAon = 22, /**< pinmux_aon */ |
| kTopEarlgreyAlertPeripheralAonTimerAon = 23, /**< aon_timer_aon */ |
| kTopEarlgreyAlertPeripheralSensorCtrl = 24, /**< sensor_ctrl */ |
| kTopEarlgreyAlertPeripheralSramCtrlRetAon = 25, /**< sram_ctrl_ret_aon */ |
| kTopEarlgreyAlertPeripheralFlashCtrl = 26, /**< flash_ctrl */ |
| kTopEarlgreyAlertPeripheralRvDm = 27, /**< rv_dm */ |
| kTopEarlgreyAlertPeripheralRvPlic = 28, /**< rv_plic */ |
| kTopEarlgreyAlertPeripheralAes = 29, /**< aes */ |
| kTopEarlgreyAlertPeripheralHmac = 30, /**< hmac */ |
| kTopEarlgreyAlertPeripheralKmac = 31, /**< kmac */ |
| kTopEarlgreyAlertPeripheralOtbn = 32, /**< otbn */ |
| kTopEarlgreyAlertPeripheralKeymgr = 33, /**< keymgr */ |
| kTopEarlgreyAlertPeripheralCsrng = 34, /**< csrng */ |
| kTopEarlgreyAlertPeripheralEntropySrc = 35, /**< entropy_src */ |
| kTopEarlgreyAlertPeripheralEdn0 = 36, /**< edn0 */ |
| kTopEarlgreyAlertPeripheralEdn1 = 37, /**< edn1 */ |
| kTopEarlgreyAlertPeripheralSramCtrlMain = 38, /**< sram_ctrl_main */ |
| kTopEarlgreyAlertPeripheralRomCtrl = 39, /**< rom_ctrl */ |
| kTopEarlgreyAlertPeripheralRvCoreIbex = 40, /**< rv_core_ibex */ |
| kTopEarlgreyAlertPeripheralLast = 40, /**< \internal Final Alert peripheral */ |
| } top_earlgrey_alert_peripheral_t; |
| |
| /** |
| * Alert Handler Alert Source. |
| * |
| * Enumeration of all Alert Handler Alert Sources. The alert sources belonging to |
| * the same peripheral are guaranteed to be consecutive. |
| */ |
| typedef enum top_earlgrey_alert_id { |
| kTopEarlgreyAlertIdUart0FatalFault = 0, /**< uart0_fatal_fault */ |
| kTopEarlgreyAlertIdUart1FatalFault = 1, /**< uart1_fatal_fault */ |
| kTopEarlgreyAlertIdUart2FatalFault = 2, /**< uart2_fatal_fault */ |
| kTopEarlgreyAlertIdUart3FatalFault = 3, /**< uart3_fatal_fault */ |
| kTopEarlgreyAlertIdGpioFatalFault = 4, /**< gpio_fatal_fault */ |
| kTopEarlgreyAlertIdSpiDeviceFatalFault = 5, /**< spi_device_fatal_fault */ |
| kTopEarlgreyAlertIdI2c0FatalFault = 6, /**< i2c0_fatal_fault */ |
| kTopEarlgreyAlertIdI2c1FatalFault = 7, /**< i2c1_fatal_fault */ |
| kTopEarlgreyAlertIdI2c2FatalFault = 8, /**< i2c2_fatal_fault */ |
| kTopEarlgreyAlertIdPattgenFatalFault = 9, /**< pattgen_fatal_fault */ |
| kTopEarlgreyAlertIdRvTimerFatalFault = 10, /**< rv_timer_fatal_fault */ |
| kTopEarlgreyAlertIdOtpCtrlFatalMacroError = 11, /**< otp_ctrl_fatal_macro_error */ |
| kTopEarlgreyAlertIdOtpCtrlFatalCheckError = 12, /**< otp_ctrl_fatal_check_error */ |
| kTopEarlgreyAlertIdOtpCtrlFatalBusIntegError = 13, /**< otp_ctrl_fatal_bus_integ_error */ |
| kTopEarlgreyAlertIdLcCtrlFatalProgError = 14, /**< lc_ctrl_fatal_prog_error */ |
| kTopEarlgreyAlertIdLcCtrlFatalStateError = 15, /**< lc_ctrl_fatal_state_error */ |
| kTopEarlgreyAlertIdLcCtrlFatalBusIntegError = 16, /**< lc_ctrl_fatal_bus_integ_error */ |
| kTopEarlgreyAlertIdSpiHost0FatalFault = 17, /**< spi_host0_fatal_fault */ |
| kTopEarlgreyAlertIdSpiHost1FatalFault = 18, /**< spi_host1_fatal_fault */ |
| kTopEarlgreyAlertIdUsbdevFatalFault = 19, /**< usbdev_fatal_fault */ |
| kTopEarlgreyAlertIdPwrmgrAonFatalFault = 20, /**< pwrmgr_aon_fatal_fault */ |
| kTopEarlgreyAlertIdRstmgrAonFatalFault = 21, /**< rstmgr_aon_fatal_fault */ |
| kTopEarlgreyAlertIdRstmgrAonFatalCnstyFault = 22, /**< rstmgr_aon_fatal_cnsty_fault */ |
| kTopEarlgreyAlertIdClkmgrAonRecovFault = 23, /**< clkmgr_aon_recov_fault */ |
| kTopEarlgreyAlertIdClkmgrAonFatalFault = 24, /**< clkmgr_aon_fatal_fault */ |
| kTopEarlgreyAlertIdSysrstCtrlAonFatalFault = 25, /**< sysrst_ctrl_aon_fatal_fault */ |
| kTopEarlgreyAlertIdAdcCtrlAonFatalFault = 26, /**< adc_ctrl_aon_fatal_fault */ |
| kTopEarlgreyAlertIdPwmAonFatalFault = 27, /**< pwm_aon_fatal_fault */ |
| kTopEarlgreyAlertIdPinmuxAonFatalFault = 28, /**< pinmux_aon_fatal_fault */ |
| kTopEarlgreyAlertIdAonTimerAonFatalFault = 29, /**< aon_timer_aon_fatal_fault */ |
| kTopEarlgreyAlertIdSensorCtrlRecovAlert = 30, /**< sensor_ctrl_recov_alert */ |
| kTopEarlgreyAlertIdSensorCtrlFatalAlert = 31, /**< sensor_ctrl_fatal_alert */ |
| kTopEarlgreyAlertIdSramCtrlRetAonFatalError = 32, /**< sram_ctrl_ret_aon_fatal_error */ |
| kTopEarlgreyAlertIdFlashCtrlRecovErr = 33, /**< flash_ctrl_recov_err */ |
| kTopEarlgreyAlertIdFlashCtrlFatalStdErr = 34, /**< flash_ctrl_fatal_std_err */ |
| kTopEarlgreyAlertIdFlashCtrlFatalErr = 35, /**< flash_ctrl_fatal_err */ |
| kTopEarlgreyAlertIdRvDmFatalFault = 36, /**< rv_dm_fatal_fault */ |
| kTopEarlgreyAlertIdRvPlicFatalFault = 37, /**< rv_plic_fatal_fault */ |
| kTopEarlgreyAlertIdAesRecovCtrlUpdateErr = 38, /**< aes_recov_ctrl_update_err */ |
| kTopEarlgreyAlertIdAesFatalFault = 39, /**< aes_fatal_fault */ |
| kTopEarlgreyAlertIdHmacFatalFault = 40, /**< hmac_fatal_fault */ |
| kTopEarlgreyAlertIdKmacRecovOperationErr = 41, /**< kmac_recov_operation_err */ |
| kTopEarlgreyAlertIdKmacFatalFaultErr = 42, /**< kmac_fatal_fault_err */ |
| kTopEarlgreyAlertIdOtbnFatal = 43, /**< otbn_fatal */ |
| kTopEarlgreyAlertIdOtbnRecov = 44, /**< otbn_recov */ |
| kTopEarlgreyAlertIdKeymgrRecovOperationErr = 45, /**< keymgr_recov_operation_err */ |
| kTopEarlgreyAlertIdKeymgrFatalFaultErr = 46, /**< keymgr_fatal_fault_err */ |
| kTopEarlgreyAlertIdCsrngRecovAlert = 47, /**< csrng_recov_alert */ |
| kTopEarlgreyAlertIdCsrngFatalAlert = 48, /**< csrng_fatal_alert */ |
| kTopEarlgreyAlertIdEntropySrcRecovAlert = 49, /**< entropy_src_recov_alert */ |
| kTopEarlgreyAlertIdEntropySrcFatalAlert = 50, /**< entropy_src_fatal_alert */ |
| kTopEarlgreyAlertIdEdn0RecovAlert = 51, /**< edn0_recov_alert */ |
| kTopEarlgreyAlertIdEdn0FatalAlert = 52, /**< edn0_fatal_alert */ |
| kTopEarlgreyAlertIdEdn1RecovAlert = 53, /**< edn1_recov_alert */ |
| kTopEarlgreyAlertIdEdn1FatalAlert = 54, /**< edn1_fatal_alert */ |
| kTopEarlgreyAlertIdSramCtrlMainFatalError = 55, /**< sram_ctrl_main_fatal_error */ |
| kTopEarlgreyAlertIdRomCtrlFatal = 56, /**< rom_ctrl_fatal */ |
| kTopEarlgreyAlertIdRvCoreIbexFatalSwErr = 57, /**< rv_core_ibex_fatal_sw_err */ |
| kTopEarlgreyAlertIdRvCoreIbexRecovSwErr = 58, /**< rv_core_ibex_recov_sw_err */ |
| kTopEarlgreyAlertIdRvCoreIbexFatalHwErr = 59, /**< rv_core_ibex_fatal_hw_err */ |
| kTopEarlgreyAlertIdRvCoreIbexRecovHwErr = 60, /**< rv_core_ibex_recov_hw_err */ |
| kTopEarlgreyAlertIdLast = 60, /**< \internal The Last Valid Alert ID. */ |
| } top_earlgrey_alert_id_t; |
| |
| /** |
| * Alert Handler Alert Source to Peripheral Map |
| * |
| * This array is a mapping from `top_earlgrey_alert_id_t` to |
| * `top_earlgrey_alert_peripheral_t`. |
| */ |
| extern const top_earlgrey_alert_peripheral_t |
| top_earlgrey_alert_for_peripheral[61]; |
| |
| #define PINMUX_MIO_PERIPH_INSEL_IDX_OFFSET 2 |
| |
| // PERIPH_INSEL ranges from 0 to NUM_MIO_PADS + 2 -1} |
| // 0 and 1 are tied to value 0 and 1 |
| #define NUM_MIO_PADS 47 |
| #define NUM_DIO_PADS 16 |
| |
| #define PINMUX_PERIPH_OUTSEL_IDX_OFFSET 3 |
| |
| /** |
| * Pinmux Peripheral Input. |
| */ |
| typedef enum top_earlgrey_pinmux_peripheral_in { |
| kTopEarlgreyPinmuxPeripheralInGpioGpio0 = 0, /**< Peripheral Input 0 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio1 = 1, /**< Peripheral Input 1 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio2 = 2, /**< Peripheral Input 2 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio3 = 3, /**< Peripheral Input 3 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio4 = 4, /**< Peripheral Input 4 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio5 = 5, /**< Peripheral Input 5 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio6 = 6, /**< Peripheral Input 6 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio7 = 7, /**< Peripheral Input 7 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio8 = 8, /**< Peripheral Input 8 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio9 = 9, /**< Peripheral Input 9 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio10 = 10, /**< Peripheral Input 10 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio11 = 11, /**< Peripheral Input 11 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio12 = 12, /**< Peripheral Input 12 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio13 = 13, /**< Peripheral Input 13 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio14 = 14, /**< Peripheral Input 14 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio15 = 15, /**< Peripheral Input 15 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio16 = 16, /**< Peripheral Input 16 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio17 = 17, /**< Peripheral Input 17 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio18 = 18, /**< Peripheral Input 18 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio19 = 19, /**< Peripheral Input 19 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio20 = 20, /**< Peripheral Input 20 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio21 = 21, /**< Peripheral Input 21 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio22 = 22, /**< Peripheral Input 22 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio23 = 23, /**< Peripheral Input 23 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio24 = 24, /**< Peripheral Input 24 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio25 = 25, /**< Peripheral Input 25 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio26 = 26, /**< Peripheral Input 26 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio27 = 27, /**< Peripheral Input 27 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio28 = 28, /**< Peripheral Input 28 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio29 = 29, /**< Peripheral Input 29 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio30 = 30, /**< Peripheral Input 30 */ |
| kTopEarlgreyPinmuxPeripheralInGpioGpio31 = 31, /**< Peripheral Input 31 */ |
| kTopEarlgreyPinmuxPeripheralInI2c0Sda = 32, /**< Peripheral Input 32 */ |
| kTopEarlgreyPinmuxPeripheralInI2c0Scl = 33, /**< Peripheral Input 33 */ |
| kTopEarlgreyPinmuxPeripheralInI2c1Sda = 34, /**< Peripheral Input 34 */ |
| kTopEarlgreyPinmuxPeripheralInI2c1Scl = 35, /**< Peripheral Input 35 */ |
| kTopEarlgreyPinmuxPeripheralInI2c2Sda = 36, /**< Peripheral Input 36 */ |
| kTopEarlgreyPinmuxPeripheralInI2c2Scl = 37, /**< Peripheral Input 37 */ |
| kTopEarlgreyPinmuxPeripheralInSpiHost1Sd0 = 38, /**< Peripheral Input 38 */ |
| kTopEarlgreyPinmuxPeripheralInSpiHost1Sd1 = 39, /**< Peripheral Input 39 */ |
| kTopEarlgreyPinmuxPeripheralInSpiHost1Sd2 = 40, /**< Peripheral Input 40 */ |
| kTopEarlgreyPinmuxPeripheralInSpiHost1Sd3 = 41, /**< Peripheral Input 41 */ |
| kTopEarlgreyPinmuxPeripheralInUart0Rx = 42, /**< Peripheral Input 42 */ |
| kTopEarlgreyPinmuxPeripheralInUart1Rx = 43, /**< Peripheral Input 43 */ |
| kTopEarlgreyPinmuxPeripheralInUart2Rx = 44, /**< Peripheral Input 44 */ |
| kTopEarlgreyPinmuxPeripheralInUart3Rx = 45, /**< Peripheral Input 45 */ |
| kTopEarlgreyPinmuxPeripheralInSpiDeviceTpmCsb = 46, /**< Peripheral Input 46 */ |
| kTopEarlgreyPinmuxPeripheralInFlashCtrlTck = 47, /**< Peripheral Input 47 */ |
| kTopEarlgreyPinmuxPeripheralInFlashCtrlTms = 48, /**< Peripheral Input 48 */ |
| kTopEarlgreyPinmuxPeripheralInFlashCtrlTdi = 49, /**< Peripheral Input 49 */ |
| kTopEarlgreyPinmuxPeripheralInSysrstCtrlAonAcPresent = 50, /**< Peripheral Input 50 */ |
| kTopEarlgreyPinmuxPeripheralInSysrstCtrlAonKey0In = 51, /**< Peripheral Input 51 */ |
| kTopEarlgreyPinmuxPeripheralInSysrstCtrlAonKey1In = 52, /**< Peripheral Input 52 */ |
| kTopEarlgreyPinmuxPeripheralInSysrstCtrlAonKey2In = 53, /**< Peripheral Input 53 */ |
| kTopEarlgreyPinmuxPeripheralInSysrstCtrlAonPwrbIn = 54, /**< Peripheral Input 54 */ |
| kTopEarlgreyPinmuxPeripheralInSysrstCtrlAonLidOpen = 55, /**< Peripheral Input 55 */ |
| kTopEarlgreyPinmuxPeripheralInUsbdevSense = 56, /**< Peripheral Input 56 */ |
| kTopEarlgreyPinmuxPeripheralInLast = 56, /**< \internal Last valid peripheral input */ |
| } top_earlgrey_pinmux_peripheral_in_t; |
| |
| /** |
| * Pinmux MIO Input Selector. |
| */ |
| typedef enum top_earlgrey_pinmux_insel { |
| kTopEarlgreyPinmuxInselConstantZero = 0, /**< Tie constantly to zero */ |
| kTopEarlgreyPinmuxInselConstantOne = 1, /**< Tie constantly to one */ |
| kTopEarlgreyPinmuxInselIoa0 = 2, /**< MIO Pad 0 */ |
| kTopEarlgreyPinmuxInselIoa1 = 3, /**< MIO Pad 1 */ |
| kTopEarlgreyPinmuxInselIoa2 = 4, /**< MIO Pad 2 */ |
| kTopEarlgreyPinmuxInselIoa3 = 5, /**< MIO Pad 3 */ |
| kTopEarlgreyPinmuxInselIoa4 = 6, /**< MIO Pad 4 */ |
| kTopEarlgreyPinmuxInselIoa5 = 7, /**< MIO Pad 5 */ |
| kTopEarlgreyPinmuxInselIoa6 = 8, /**< MIO Pad 6 */ |
| kTopEarlgreyPinmuxInselIoa7 = 9, /**< MIO Pad 7 */ |
| kTopEarlgreyPinmuxInselIoa8 = 10, /**< MIO Pad 8 */ |
| kTopEarlgreyPinmuxInselIob0 = 11, /**< MIO Pad 9 */ |
| kTopEarlgreyPinmuxInselIob1 = 12, /**< MIO Pad 10 */ |
| kTopEarlgreyPinmuxInselIob2 = 13, /**< MIO Pad 11 */ |
| kTopEarlgreyPinmuxInselIob3 = 14, /**< MIO Pad 12 */ |
| kTopEarlgreyPinmuxInselIob4 = 15, /**< MIO Pad 13 */ |
| kTopEarlgreyPinmuxInselIob5 = 16, /**< MIO Pad 14 */ |
| kTopEarlgreyPinmuxInselIob6 = 17, /**< MIO Pad 15 */ |
| kTopEarlgreyPinmuxInselIob7 = 18, /**< MIO Pad 16 */ |
| kTopEarlgreyPinmuxInselIob8 = 19, /**< MIO Pad 17 */ |
| kTopEarlgreyPinmuxInselIob9 = 20, /**< MIO Pad 18 */ |
| kTopEarlgreyPinmuxInselIob10 = 21, /**< MIO Pad 19 */ |
| kTopEarlgreyPinmuxInselIob11 = 22, /**< MIO Pad 20 */ |
| kTopEarlgreyPinmuxInselIob12 = 23, /**< MIO Pad 21 */ |
| kTopEarlgreyPinmuxInselIoc0 = 24, /**< MIO Pad 22 */ |
| kTopEarlgreyPinmuxInselIoc1 = 25, /**< MIO Pad 23 */ |
| kTopEarlgreyPinmuxInselIoc2 = 26, /**< MIO Pad 24 */ |
| kTopEarlgreyPinmuxInselIoc3 = 27, /**< MIO Pad 25 */ |
| kTopEarlgreyPinmuxInselIoc4 = 28, /**< MIO Pad 26 */ |
| kTopEarlgreyPinmuxInselIoc5 = 29, /**< MIO Pad 27 */ |
| kTopEarlgreyPinmuxInselIoc6 = 30, /**< MIO Pad 28 */ |
| kTopEarlgreyPinmuxInselIoc7 = 31, /**< MIO Pad 29 */ |
| kTopEarlgreyPinmuxInselIoc8 = 32, /**< MIO Pad 30 */ |
| kTopEarlgreyPinmuxInselIoc9 = 33, /**< MIO Pad 31 */ |
| kTopEarlgreyPinmuxInselIoc10 = 34, /**< MIO Pad 32 */ |
| kTopEarlgreyPinmuxInselIoc11 = 35, /**< MIO Pad 33 */ |
| kTopEarlgreyPinmuxInselIoc12 = 36, /**< MIO Pad 34 */ |
| kTopEarlgreyPinmuxInselIor0 = 37, /**< MIO Pad 35 */ |
| kTopEarlgreyPinmuxInselIor1 = 38, /**< MIO Pad 36 */ |
| kTopEarlgreyPinmuxInselIor2 = 39, /**< MIO Pad 37 */ |
| kTopEarlgreyPinmuxInselIor3 = 40, /**< MIO Pad 38 */ |
| kTopEarlgreyPinmuxInselIor4 = 41, /**< MIO Pad 39 */ |
| kTopEarlgreyPinmuxInselIor5 = 42, /**< MIO Pad 40 */ |
| kTopEarlgreyPinmuxInselIor6 = 43, /**< MIO Pad 41 */ |
| kTopEarlgreyPinmuxInselIor7 = 44, /**< MIO Pad 42 */ |
| kTopEarlgreyPinmuxInselIor10 = 45, /**< MIO Pad 43 */ |
| kTopEarlgreyPinmuxInselIor11 = 46, /**< MIO Pad 44 */ |
| kTopEarlgreyPinmuxInselIor12 = 47, /**< MIO Pad 45 */ |
| kTopEarlgreyPinmuxInselIor13 = 48, /**< MIO Pad 46 */ |
| kTopEarlgreyPinmuxInselLast = 48, /**< \internal Last valid insel value */ |
| } top_earlgrey_pinmux_insel_t; |
| |
| /** |
| * Pinmux MIO Output. |
| */ |
| typedef enum top_earlgrey_pinmux_mio_out { |
| kTopEarlgreyPinmuxMioOutIoa0 = 0, /**< MIO Pad 0 */ |
| kTopEarlgreyPinmuxMioOutIoa1 = 1, /**< MIO Pad 1 */ |
| kTopEarlgreyPinmuxMioOutIoa2 = 2, /**< MIO Pad 2 */ |
| kTopEarlgreyPinmuxMioOutIoa3 = 3, /**< MIO Pad 3 */ |
| kTopEarlgreyPinmuxMioOutIoa4 = 4, /**< MIO Pad 4 */ |
| kTopEarlgreyPinmuxMioOutIoa5 = 5, /**< MIO Pad 5 */ |
| kTopEarlgreyPinmuxMioOutIoa6 = 6, /**< MIO Pad 6 */ |
| kTopEarlgreyPinmuxMioOutIoa7 = 7, /**< MIO Pad 7 */ |
| kTopEarlgreyPinmuxMioOutIoa8 = 8, /**< MIO Pad 8 */ |
| kTopEarlgreyPinmuxMioOutIob0 = 9, /**< MIO Pad 9 */ |
| kTopEarlgreyPinmuxMioOutIob1 = 10, /**< MIO Pad 10 */ |
| kTopEarlgreyPinmuxMioOutIob2 = 11, /**< MIO Pad 11 */ |
| kTopEarlgreyPinmuxMioOutIob3 = 12, /**< MIO Pad 12 */ |
| kTopEarlgreyPinmuxMioOutIob4 = 13, /**< MIO Pad 13 */ |
| kTopEarlgreyPinmuxMioOutIob5 = 14, /**< MIO Pad 14 */ |
| kTopEarlgreyPinmuxMioOutIob6 = 15, /**< MIO Pad 15 */ |
| kTopEarlgreyPinmuxMioOutIob7 = 16, /**< MIO Pad 16 */ |
| kTopEarlgreyPinmuxMioOutIob8 = 17, /**< MIO Pad 17 */ |
| kTopEarlgreyPinmuxMioOutIob9 = 18, /**< MIO Pad 18 */ |
| kTopEarlgreyPinmuxMioOutIob10 = 19, /**< MIO Pad 19 */ |
| kTopEarlgreyPinmuxMioOutIob11 = 20, /**< MIO Pad 20 */ |
| kTopEarlgreyPinmuxMioOutIob12 = 21, /**< MIO Pad 21 */ |
| kTopEarlgreyPinmuxMioOutIoc0 = 22, /**< MIO Pad 22 */ |
| kTopEarlgreyPinmuxMioOutIoc1 = 23, /**< MIO Pad 23 */ |
| kTopEarlgreyPinmuxMioOutIoc2 = 24, /**< MIO Pad 24 */ |
| kTopEarlgreyPinmuxMioOutIoc3 = 25, /**< MIO Pad 25 */ |
| kTopEarlgreyPinmuxMioOutIoc4 = 26, /**< MIO Pad 26 */ |
| kTopEarlgreyPinmuxMioOutIoc5 = 27, /**< MIO Pad 27 */ |
| kTopEarlgreyPinmuxMioOutIoc6 = 28, /**< MIO Pad 28 */ |
| kTopEarlgreyPinmuxMioOutIoc7 = 29, /**< MIO Pad 29 */ |
| kTopEarlgreyPinmuxMioOutIoc8 = 30, /**< MIO Pad 30 */ |
| kTopEarlgreyPinmuxMioOutIoc9 = 31, /**< MIO Pad 31 */ |
| kTopEarlgreyPinmuxMioOutIoc10 = 32, /**< MIO Pad 32 */ |
| kTopEarlgreyPinmuxMioOutIoc11 = 33, /**< MIO Pad 33 */ |
| kTopEarlgreyPinmuxMioOutIoc12 = 34, /**< MIO Pad 34 */ |
| kTopEarlgreyPinmuxMioOutIor0 = 35, /**< MIO Pad 35 */ |
| kTopEarlgreyPinmuxMioOutIor1 = 36, /**< MIO Pad 36 */ |
| kTopEarlgreyPinmuxMioOutIor2 = 37, /**< MIO Pad 37 */ |
| kTopEarlgreyPinmuxMioOutIor3 = 38, /**< MIO Pad 38 */ |
| kTopEarlgreyPinmuxMioOutIor4 = 39, /**< MIO Pad 39 */ |
| kTopEarlgreyPinmuxMioOutIor5 = 40, /**< MIO Pad 40 */ |
| kTopEarlgreyPinmuxMioOutIor6 = 41, /**< MIO Pad 41 */ |
| kTopEarlgreyPinmuxMioOutIor7 = 42, /**< MIO Pad 42 */ |
| kTopEarlgreyPinmuxMioOutIor10 = 43, /**< MIO Pad 43 */ |
| kTopEarlgreyPinmuxMioOutIor11 = 44, /**< MIO Pad 44 */ |
| kTopEarlgreyPinmuxMioOutIor12 = 45, /**< MIO Pad 45 */ |
| kTopEarlgreyPinmuxMioOutIor13 = 46, /**< MIO Pad 46 */ |
| kTopEarlgreyPinmuxMioOutLast = 46, /**< \internal Last valid mio output */ |
| } top_earlgrey_pinmux_mio_out_t; |
| |
| /** |
| * Pinmux Peripheral Output Selector. |
| */ |
| typedef enum top_earlgrey_pinmux_outsel { |
| kTopEarlgreyPinmuxOutselConstantZero = 0, /**< Tie constantly to zero */ |
| kTopEarlgreyPinmuxOutselConstantOne = 1, /**< Tie constantly to one */ |
| kTopEarlgreyPinmuxOutselConstantHighZ = 2, /**< Tie constantly to high-Z */ |
| kTopEarlgreyPinmuxOutselGpioGpio0 = 3, /**< Peripheral Output 0 */ |
| kTopEarlgreyPinmuxOutselGpioGpio1 = 4, /**< Peripheral Output 1 */ |
| kTopEarlgreyPinmuxOutselGpioGpio2 = 5, /**< Peripheral Output 2 */ |
| kTopEarlgreyPinmuxOutselGpioGpio3 = 6, /**< Peripheral Output 3 */ |
| kTopEarlgreyPinmuxOutselGpioGpio4 = 7, /**< Peripheral Output 4 */ |
| kTopEarlgreyPinmuxOutselGpioGpio5 = 8, /**< Peripheral Output 5 */ |
| kTopEarlgreyPinmuxOutselGpioGpio6 = 9, /**< Peripheral Output 6 */ |
| kTopEarlgreyPinmuxOutselGpioGpio7 = 10, /**< Peripheral Output 7 */ |
| kTopEarlgreyPinmuxOutselGpioGpio8 = 11, /**< Peripheral Output 8 */ |
| kTopEarlgreyPinmuxOutselGpioGpio9 = 12, /**< Peripheral Output 9 */ |
| kTopEarlgreyPinmuxOutselGpioGpio10 = 13, /**< Peripheral Output 10 */ |
| kTopEarlgreyPinmuxOutselGpioGpio11 = 14, /**< Peripheral Output 11 */ |
| kTopEarlgreyPinmuxOutselGpioGpio12 = 15, /**< Peripheral Output 12 */ |
| kTopEarlgreyPinmuxOutselGpioGpio13 = 16, /**< Peripheral Output 13 */ |
| kTopEarlgreyPinmuxOutselGpioGpio14 = 17, /**< Peripheral Output 14 */ |
| kTopEarlgreyPinmuxOutselGpioGpio15 = 18, /**< Peripheral Output 15 */ |
| kTopEarlgreyPinmuxOutselGpioGpio16 = 19, /**< Peripheral Output 16 */ |
| kTopEarlgreyPinmuxOutselGpioGpio17 = 20, /**< Peripheral Output 17 */ |
| kTopEarlgreyPinmuxOutselGpioGpio18 = 21, /**< Peripheral Output 18 */ |
| kTopEarlgreyPinmuxOutselGpioGpio19 = 22, /**< Peripheral Output 19 */ |
| kTopEarlgreyPinmuxOutselGpioGpio20 = 23, /**< Peripheral Output 20 */ |
| kTopEarlgreyPinmuxOutselGpioGpio21 = 24, /**< Peripheral Output 21 */ |
| kTopEarlgreyPinmuxOutselGpioGpio22 = 25, /**< Peripheral Output 22 */ |
| kTopEarlgreyPinmuxOutselGpioGpio23 = 26, /**< Peripheral Output 23 */ |
| kTopEarlgreyPinmuxOutselGpioGpio24 = 27, /**< Peripheral Output 24 */ |
| kTopEarlgreyPinmuxOutselGpioGpio25 = 28, /**< Peripheral Output 25 */ |
| kTopEarlgreyPinmuxOutselGpioGpio26 = 29, /**< Peripheral Output 26 */ |
| kTopEarlgreyPinmuxOutselGpioGpio27 = 30, /**< Peripheral Output 27 */ |
| kTopEarlgreyPinmuxOutselGpioGpio28 = 31, /**< Peripheral Output 28 */ |
| kTopEarlgreyPinmuxOutselGpioGpio29 = 32, /**< Peripheral Output 29 */ |
| kTopEarlgreyPinmuxOutselGpioGpio30 = 33, /**< Peripheral Output 30 */ |
| kTopEarlgreyPinmuxOutselGpioGpio31 = 34, /**< Peripheral Output 31 */ |
| kTopEarlgreyPinmuxOutselI2c0Sda = 35, /**< Peripheral Output 32 */ |
| kTopEarlgreyPinmuxOutselI2c0Scl = 36, /**< Peripheral Output 33 */ |
| kTopEarlgreyPinmuxOutselI2c1Sda = 37, /**< Peripheral Output 34 */ |
| kTopEarlgreyPinmuxOutselI2c1Scl = 38, /**< Peripheral Output 35 */ |
| kTopEarlgreyPinmuxOutselI2c2Sda = 39, /**< Peripheral Output 36 */ |
| kTopEarlgreyPinmuxOutselI2c2Scl = 40, /**< Peripheral Output 37 */ |
| kTopEarlgreyPinmuxOutselSpiHost1Sd0 = 41, /**< Peripheral Output 38 */ |
| kTopEarlgreyPinmuxOutselSpiHost1Sd1 = 42, /**< Peripheral Output 39 */ |
| kTopEarlgreyPinmuxOutselSpiHost1Sd2 = 43, /**< Peripheral Output 40 */ |
| kTopEarlgreyPinmuxOutselSpiHost1Sd3 = 44, /**< Peripheral Output 41 */ |
| kTopEarlgreyPinmuxOutselUart0Tx = 45, /**< Peripheral Output 42 */ |
| kTopEarlgreyPinmuxOutselUart1Tx = 46, /**< Peripheral Output 43 */ |
| kTopEarlgreyPinmuxOutselUart2Tx = 47, /**< Peripheral Output 44 */ |
| kTopEarlgreyPinmuxOutselUart3Tx = 48, /**< Peripheral Output 45 */ |
| kTopEarlgreyPinmuxOutselPattgenPda0Tx = 49, /**< Peripheral Output 46 */ |
| kTopEarlgreyPinmuxOutselPattgenPcl0Tx = 50, /**< Peripheral Output 47 */ |
| kTopEarlgreyPinmuxOutselPattgenPda1Tx = 51, /**< Peripheral Output 48 */ |
| kTopEarlgreyPinmuxOutselPattgenPcl1Tx = 52, /**< Peripheral Output 49 */ |
| kTopEarlgreyPinmuxOutselSpiHost1Sck = 53, /**< Peripheral Output 50 */ |
| kTopEarlgreyPinmuxOutselSpiHost1Csb = 54, /**< Peripheral Output 51 */ |
| kTopEarlgreyPinmuxOutselFlashCtrlTdo = 55, /**< Peripheral Output 52 */ |
| kTopEarlgreyPinmuxOutselSensorCtrlAstDebugOut0 = 56, /**< Peripheral Output 53 */ |
| kTopEarlgreyPinmuxOutselSensorCtrlAstDebugOut1 = 57, /**< Peripheral Output 54 */ |
| kTopEarlgreyPinmuxOutselSensorCtrlAstDebugOut2 = 58, /**< Peripheral Output 55 */ |
| kTopEarlgreyPinmuxOutselSensorCtrlAstDebugOut3 = 59, /**< Peripheral Output 56 */ |
| kTopEarlgreyPinmuxOutselSensorCtrlAstDebugOut4 = 60, /**< Peripheral Output 57 */ |
| kTopEarlgreyPinmuxOutselSensorCtrlAstDebugOut5 = 61, /**< Peripheral Output 58 */ |
| kTopEarlgreyPinmuxOutselSensorCtrlAstDebugOut6 = 62, /**< Peripheral Output 59 */ |
| kTopEarlgreyPinmuxOutselSensorCtrlAstDebugOut7 = 63, /**< Peripheral Output 60 */ |
| kTopEarlgreyPinmuxOutselSensorCtrlAstDebugOut8 = 64, /**< Peripheral Output 61 */ |
| kTopEarlgreyPinmuxOutselPwmAonPwm0 = 65, /**< Peripheral Output 62 */ |
| kTopEarlgreyPinmuxOutselPwmAonPwm1 = 66, /**< Peripheral Output 63 */ |
| kTopEarlgreyPinmuxOutselPwmAonPwm2 = 67, /**< Peripheral Output 64 */ |
| kTopEarlgreyPinmuxOutselPwmAonPwm3 = 68, /**< Peripheral Output 65 */ |
| kTopEarlgreyPinmuxOutselPwmAonPwm4 = 69, /**< Peripheral Output 66 */ |
| kTopEarlgreyPinmuxOutselPwmAonPwm5 = 70, /**< Peripheral Output 67 */ |
| kTopEarlgreyPinmuxOutselOtpCtrlTest0 = 71, /**< Peripheral Output 68 */ |
| kTopEarlgreyPinmuxOutselSysrstCtrlAonBatDisable = 72, /**< Peripheral Output 69 */ |
| kTopEarlgreyPinmuxOutselSysrstCtrlAonKey0Out = 73, /**< Peripheral Output 70 */ |
| kTopEarlgreyPinmuxOutselSysrstCtrlAonKey1Out = 74, /**< Peripheral Output 71 */ |
| kTopEarlgreyPinmuxOutselSysrstCtrlAonKey2Out = 75, /**< Peripheral Output 72 */ |
| kTopEarlgreyPinmuxOutselSysrstCtrlAonPwrbOut = 76, /**< Peripheral Output 73 */ |
| kTopEarlgreyPinmuxOutselSysrstCtrlAonZ3Wakeup = 77, /**< Peripheral Output 74 */ |
| kTopEarlgreyPinmuxOutselLast = 77, /**< \internal Last valid outsel value */ |
| } top_earlgrey_pinmux_outsel_t; |
| |
| /** |
| * Power Manager Wakeup Signals |
| */ |
| typedef enum top_earlgrey_power_manager_wake_ups { |
| kTopEarlgreyPowerManagerWakeUpsSysrstCtrlAonWkupReq = 0, /**< */ |
| kTopEarlgreyPowerManagerWakeUpsAdcCtrlAonWkupReq = 1, /**< */ |
| kTopEarlgreyPowerManagerWakeUpsPinmuxAonPinWkupReq = 2, /**< */ |
| kTopEarlgreyPowerManagerWakeUpsPinmuxAonUsbWkupReq = 3, /**< */ |
| kTopEarlgreyPowerManagerWakeUpsAonTimerAonWkupReq = 4, /**< */ |
| kTopEarlgreyPowerManagerWakeUpsSensorCtrlWkupReq = 5, /**< */ |
| kTopEarlgreyPowerManagerWakeUpsLast = 5, /**< \internal Last valid pwrmgr wakeup signal */ |
| } top_earlgrey_power_manager_wake_ups_t; |
| |
| /** |
| * Reset Manager Software Controlled Resets |
| */ |
| typedef enum top_earlgrey_reset_manager_sw_resets { |
| kTopEarlgreyResetManagerSwResetsSpiDevice = 0, /**< */ |
| kTopEarlgreyResetManagerSwResetsSpiHost0 = 1, /**< */ |
| kTopEarlgreyResetManagerSwResetsSpiHost1 = 2, /**< */ |
| kTopEarlgreyResetManagerSwResetsUsb = 3, /**< */ |
| kTopEarlgreyResetManagerSwResetsUsbAon = 4, /**< */ |
| kTopEarlgreyResetManagerSwResetsI2c0 = 5, /**< */ |
| kTopEarlgreyResetManagerSwResetsI2c1 = 6, /**< */ |
| kTopEarlgreyResetManagerSwResetsI2c2 = 7, /**< */ |
| kTopEarlgreyResetManagerSwResetsLast = 7, /**< \internal Last valid rstmgr software reset request */ |
| } top_earlgrey_reset_manager_sw_resets_t; |
| |
| /** |
| * Power Manager Reset Request Signals |
| */ |
| typedef enum top_earlgrey_power_manager_reset_requests { |
| kTopEarlgreyPowerManagerResetRequestsSysrstCtrlAonAonSysrstCtrlRstReq = 0, /**< */ |
| kTopEarlgreyPowerManagerResetRequestsAonTimerAonAonTimerRstReq = 1, /**< */ |
| kTopEarlgreyPowerManagerResetRequestsLast = 1, /**< \internal Last valid pwrmgr reset_request signal */ |
| } top_earlgrey_power_manager_reset_requests_t; |
| |
| /** |
| * Clock Manager Software-Controlled ("Gated") Clocks. |
| * |
| * The Software has full control over these clocks. |
| */ |
| typedef enum top_earlgrey_gateable_clocks { |
| kTopEarlgreyGateableClocksIoDiv4Peri = 0, /**< Clock clk_io_div4_peri in group peri */ |
| kTopEarlgreyGateableClocksIoDiv2Peri = 1, /**< Clock clk_io_div2_peri in group peri */ |
| kTopEarlgreyGateableClocksIoPeri = 2, /**< Clock clk_io_peri in group peri */ |
| kTopEarlgreyGateableClocksUsbPeri = 3, /**< Clock clk_usb_peri in group peri */ |
| kTopEarlgreyGateableClocksLast = 3, /**< \internal Last Valid Gateable Clock */ |
| } top_earlgrey_gateable_clocks_t; |
| |
| /** |
| * Clock Manager Software-Hinted Clocks. |
| * |
| * The Software has partial control over these clocks. It can ask them to stop, |
| * but the clock manager is in control of whether the clock actually is stopped. |
| */ |
| typedef enum top_earlgrey_hintable_clocks { |
| kTopEarlgreyHintableClocksMainAes = 0, /**< Clock clk_main_aes in group trans */ |
| kTopEarlgreyHintableClocksMainHmac = 1, /**< Clock clk_main_hmac in group trans */ |
| kTopEarlgreyHintableClocksMainKmac = 2, /**< Clock clk_main_kmac in group trans */ |
| kTopEarlgreyHintableClocksMainOtbn = 3, /**< Clock clk_main_otbn in group trans */ |
| kTopEarlgreyHintableClocksLast = 3, /**< \internal Last Valid Hintable Clock */ |
| } top_earlgrey_hintable_clocks_t; |
| |
| // Header Extern Guard |
| #ifdef __cplusplus |
| } // extern "C" |
| #endif |
| |
| #endif // OPENTITAN_HW_TOP_EARLGREY_SW_AUTOGEN_TOP_EARLGREY_H_ |