/* * Copyright (c) 2020 - 2025 Renesas Electronics Corporation and/or its affiliates * * SPDX-License-Identifier: BSD-3-Clause */ #ifndef BSP_ELC_H #define BSP_ELC_H /*******************************************************************************************************************//** * @addtogroup BSP_MCU_RA4L1 * @{ **********************************************************************************************************************/ /*********************************************************************************************************************** * Macro definitions **********************************************************************************************************************/ /*********************************************************************************************************************** * Typedef definitions **********************************************************************************************************************/ /*********************************************************************************************************************** * Exported global variables **********************************************************************************************************************/ /*********************************************************************************************************************** * Exported global functions (to be accessed by other files) **********************************************************************************************************************/ /* UNCRUSTIFY-OFF */ /** Sources of event signals to be linked to other peripherals or the CPU * @note This list is device specific. * */ typedef enum e_elc_event_ra4l1 { ELC_EVENT_NONE = (0x0), // Link disabled ELC_EVENT_ICU_IRQ0 = (0x001), // External pin interrupt 0 ELC_EVENT_ICU_IRQ1 = (0x002), // External pin interrupt 1 ELC_EVENT_ICU_IRQ2 = (0x003), // External pin interrupt 2 ELC_EVENT_ICU_IRQ3 = (0x004), // External pin interrupt 3 ELC_EVENT_ICU_IRQ4 = (0x005), // External pin interrupt 4 ELC_EVENT_ICU_IRQ5 = (0x006), // External pin interrupt 5 ELC_EVENT_ICU_IRQ6 = (0x007), // External pin interrupt 6 ELC_EVENT_ICU_IRQ7 = (0x008), // External pin interrupt 7 ELC_EVENT_ICU_IRQ8 = (0x009), // External pin interrupt 8 ELC_EVENT_ICU_IRQ9 = (0x00A), // External pin interrupt 9 ELC_EVENT_ICU_IRQ10 = (0x00B), // External pin interrupt 10 ELC_EVENT_ICU_IRQ11 = (0x00C), // External pin interrupt 11 ELC_EVENT_ICU_IRQ12 = (0x00D), // External pin interrupt 12 ELC_EVENT_ICU_IRQ13 = (0x00E), // External pin interrupt 13 ELC_EVENT_ICU_IRQ14 = (0x00F), // External pin interrupt 14 ELC_EVENT_ICU_IRQ15 = (0x010), // External pin interrupt 15 ELC_EVENT_DMAC0_INT = (0x020), // DMAC0 transfer end ELC_EVENT_DMAC1_INT = (0x021), // DMAC1 transfer end ELC_EVENT_DMAC2_INT = (0x022), // DMAC2 transfer end ELC_EVENT_DMAC3_INT = (0x023), // DMAC3 transfer end ELC_EVENT_DMAC4_INT = (0x024), // DMAC4 transfer end ELC_EVENT_DMAC5_INT = (0x025), // DMAC5 transfer end ELC_EVENT_DMAC6_INT = (0x026), // DMAC6 transfer end ELC_EVENT_DMAC7_INT = (0x027), // DMAC7 transfer end ELC_EVENT_DTC_COMPLETE = (0x029), // DTC transfer complete ELC_EVENT_DTC_END = (0x02A), // DTC transfer end ELC_EVENT_DMA_TRANSERR = (0x02B), // DMA/DTC transfer error ELC_EVENT_ICU_SNOOZE_CANCEL = (0x02D), // Canceling from Snooze mode ELC_EVENT_FCU_FIFERR = (0x030), // Flash access error interrupt ELC_EVENT_FCU_FRDYI = (0x031), // Flash ready interrupt ELC_EVENT_LVD_LVD1 = (0x038), // Voltage monitor 1 interrupt ELC_EVENT_LVD_LVD2 = (0x039), // Voltage monitor 2 interrupt ELC_EVENT_CGC_MOSC_STOP = (0x03B), // Main Clock oscillation stop ELC_EVENT_LPM_SNOOZE_REQUEST = (0x03C), // Snooze entry ELC_EVENT_CGC_SOSC_STOP = (0x03D), // Sub oscillation stop ELC_EVENT_AGT0_INT = (0x040), // AGT interrupt ELC_EVENT_AGT0_COMPARE_A = (0x041), // Compare match A ELC_EVENT_AGT0_COMPARE_B = (0x042), // Compare match B ELC_EVENT_AGT1_INT = (0x043), // AGT interrupt ELC_EVENT_AGT1_COMPARE_A = (0x044), // Compare match A ELC_EVENT_AGT1_COMPARE_B = (0x045), // Compare match B ELC_EVENT_IWDT_UNDERFLOW = (0x052), // IWDT underflow ELC_EVENT_WDT_UNDERFLOW = (0x053), // WDT underflow ELC_EVENT_RTC_ALARM = (0x054), // Alarm interrupt ELC_EVENT_RTC_PERIOD = (0x055), // Periodic interrupt ELC_EVENT_RTC_CARRY = (0x056), // Carry interrupt ELC_EVENT_CAN_RXF = (0x059), // Global receive FIFO interrupt ELC_EVENT_CAN_GLERR = (0x05A), // Global error ELC_EVENT_CAN_DMAREQ0 = (0x05B), // RX fifo DMA request 0 ELC_EVENT_CAN_DMAREQ1 = (0x05C), // RX fifo DMA request 1 ELC_EVENT_CAN0_TX = (0x063), // Transmit interrupt ELC_EVENT_CAN0_CHERR = (0x064), // Channel error ELC_EVENT_CAN0_COMFRX = (0x065), // Common FIFO receive interrupt ELC_EVENT_CAN0_CF_DMAREQ = (0x066), // Channel DMA request ELC_EVENT_CAN0_RXMB = (0x067), // Receive message buffer interrupt ELC_EVENT_USBFS_FIFO_0 = (0x06B), // DMA/DTC transfer request 0 ELC_EVENT_USBFS_FIFO_1 = (0x06C), // DMA/DTC transfer request 1 ELC_EVENT_USBFS_INT = (0x06D), // USBFS interrupt ELC_EVENT_USBFS_RESUME = (0x06E), // USBFS resume interrupt ELC_EVENT_IIC0_RXI = (0x073), // Receive data full ELC_EVENT_IIC0_TXI = (0x074), // Transmit data empty ELC_EVENT_IIC0_TEI = (0x075), // Transmit end ELC_EVENT_IIC0_ERI = (0x076), // Transfer error ELC_EVENT_IIC0_WUI = (0x077), // Wakeup interrupt ELC_EVENT_SSI0_TXI = (0x08A), // Transmit data empty ELC_EVENT_SSI0_RXI = (0x08B), // Receive data full ELC_EVENT_SSI0_INT = (0x08D), // Error interrupt ELC_EVENT_UARTA0_TXI = (0x08E), // UARTA0 transmission transfer end or buffer empty interrupt ELC_EVENT_UARTA0_RXI = (0x08F), // UARTA0 reception transfer end ELC_EVENT_UARTA0_ERRI = (0x090), // UARTA0 reception communication error occurrence ELC_EVENT_UARTA1_TXI = (0x091), // UARTA1 transmission transfer end or buffer empty interrupt ELC_EVENT_UARTA1_RXI = (0x092), // UARTA1 reception transfer end ELC_EVENT_UARTA1_ERRI = (0x093), // UARTA1 reception communication error occurrence ELC_EVENT_ACMPLP0_INT = (0x094), // Low Power Comparator channel 0 interrupt ELC_EVENT_ACMPLP1_INT = (0x095), // Low Power Comparator channel 1 interrupt ELC_EVENT_CTSU_WRITE = (0x09A), // Write request interrupt ELC_EVENT_CTSU_READ = (0x09B), // Measurement data transfer request interrupt ELC_EVENT_CTSU_END = (0x09C), // Measurement end interrupt ELC_EVENT_CAC_FREQUENCY_ERROR = (0x09E), // Frequency error interrupt ELC_EVENT_CAC_MEASUREMENT_END = (0x09F), // Measurement end interrupt ELC_EVENT_CAC_OVERFLOW = (0x0A0), // Overflow interrupt ELC_EVENT_IOPORT_EVENT_1 = (0x0B1), // Port 1 event ELC_EVENT_IOPORT_EVENT_2 = (0x0B2), // Port 2 event ELC_EVENT_IOPORT_EVENT_3 = (0x0B3), // Port 3 event ELC_EVENT_IOPORT_EVENT_4 = (0x0B4), // Port 4 event ELC_EVENT_ELC_SOFTWARE_EVENT_0 = (0x0B5), // Software event 0 ELC_EVENT_ELC_SOFTWARE_EVENT_1 = (0x0B6), // Software event 1 ELC_EVENT_POEG0_EVENT = (0x0B7), // Port Output disable 0 interrupt ELC_EVENT_POEG1_EVENT = (0x0B8), // Port Output disable 1 interrupt ELC_EVENT_POEG2_EVENT = (0x0B9), // Port Output disable 2 interrupt ELC_EVENT_POEG3_EVENT = (0x0BA), // Port Output disable 3 interrupt ELC_EVENT_GPT0_CAPTURE_COMPARE_A = (0x0C0), // Capture/Compare match A ELC_EVENT_GPT0_CAPTURE_COMPARE_B = (0x0C1), // Capture/Compare match B ELC_EVENT_GPT0_COMPARE_C = (0x0C2), // Compare match C ELC_EVENT_GPT0_COMPARE_D = (0x0C3), // Compare match D ELC_EVENT_GPT0_COMPARE_E = (0x0C4), // Compare match E ELC_EVENT_GPT0_COMPARE_F = (0x0C5), // Compare match F ELC_EVENT_GPT0_COUNTER_OVERFLOW = (0x0C6), // Overflow ELC_EVENT_GPT0_COUNTER_UNDERFLOW = (0x0C7), // Underflow ELC_EVENT_GPT0_PC = (0x0C8), // Period count function finish ELC_EVENT_GPT1_CAPTURE_COMPARE_A = (0x0C9), // Capture/Compare match A ELC_EVENT_GPT1_CAPTURE_COMPARE_B = (0x0CA), // Capture/Compare match B ELC_EVENT_GPT1_COMPARE_C = (0x0CB), // Compare match C ELC_EVENT_GPT1_COMPARE_D = (0x0CC), // Compare match D ELC_EVENT_GPT1_COMPARE_E = (0x0CD), // Compare match E ELC_EVENT_GPT1_COMPARE_F = (0x0CE), // Compare match F ELC_EVENT_GPT1_COUNTER_OVERFLOW = (0x0CF), // Overflow ELC_EVENT_GPT1_COUNTER_UNDERFLOW = (0x0D0), // Underflow ELC_EVENT_GPT1_PC = (0x0D1), // Period count function finish ELC_EVENT_GPT2_CAPTURE_COMPARE_A = (0x0D2), // Capture/Compare match A ELC_EVENT_GPT2_CAPTURE_COMPARE_B = (0x0D3), // Capture/Compare match B ELC_EVENT_GPT2_COMPARE_C = (0x0D4), // Compare match C ELC_EVENT_GPT2_COMPARE_D = (0x0D5), // Compare match D ELC_EVENT_GPT2_COMPARE_E = (0x0D6), // Compare match E ELC_EVENT_GPT2_COMPARE_F = (0x0D7), // Compare match F ELC_EVENT_GPT2_COUNTER_OVERFLOW = (0x0D8), // Overflow ELC_EVENT_GPT2_COUNTER_UNDERFLOW = (0x0D9), // Underflow ELC_EVENT_GPT2_PC = (0x0DA), // Period count function finish ELC_EVENT_GPT3_CAPTURE_COMPARE_A = (0x0DB), // Capture/Compare match A ELC_EVENT_GPT3_CAPTURE_COMPARE_B = (0x0DC), // Capture/Compare match B ELC_EVENT_GPT3_COMPARE_C = (0x0DD), // Compare match C ELC_EVENT_GPT3_COMPARE_D = (0x0DE), // Compare match D ELC_EVENT_GPT3_COMPARE_E = (0x0DF), // Compare match E ELC_EVENT_GPT3_COMPARE_F = (0x0E0), // Compare match F ELC_EVENT_GPT3_COUNTER_OVERFLOW = (0x0E1), // Overflow ELC_EVENT_GPT3_COUNTER_UNDERFLOW = (0x0E2), // Underflow ELC_EVENT_GPT3_PC = (0x0E3), // Period count function finish ELC_EVENT_GPT4_CAPTURE_COMPARE_A = (0x0E4), // Capture/Compare match A ELC_EVENT_GPT4_CAPTURE_COMPARE_B = (0x0E5), // Capture/Compare match B ELC_EVENT_GPT4_COMPARE_C = (0x0E6), // Compare match C ELC_EVENT_GPT4_COMPARE_D = (0x0E7), // Compare match D ELC_EVENT_GPT4_COMPARE_E = (0x0E8), // Compare match E ELC_EVENT_GPT4_COMPARE_F = (0x0E9), // Compare match F ELC_EVENT_GPT4_COUNTER_OVERFLOW = (0x0EA), // Overflow ELC_EVENT_GPT4_COUNTER_UNDERFLOW = (0x0EB), // Underflow ELC_EVENT_GPT4_PC = (0x0EC), // Period count function finish ELC_EVENT_GPT5_CAPTURE_COMPARE_A = (0x0ED), // Capture/Compare match A ELC_EVENT_GPT5_CAPTURE_COMPARE_B = (0x0EE), // Capture/Compare match B ELC_EVENT_GPT5_COMPARE_C = (0x0EF), // Compare match C ELC_EVENT_GPT5_COMPARE_D = (0x0F0), // Compare match D ELC_EVENT_GPT5_COMPARE_E = (0x0F1), // Compare match E ELC_EVENT_GPT5_COMPARE_F = (0x0F2), // Compare match F ELC_EVENT_GPT5_COUNTER_OVERFLOW = (0x0F3), // Overflow ELC_EVENT_GPT5_COUNTER_UNDERFLOW = (0x0F4), // Underflow ELC_EVENT_OPS_UVW_EDGE = (0x150), // UVW edge event ELC_EVENT_ADC0_SCAN_END = (0x160), // End of A/D scanning operation ELC_EVENT_ADC0_SCAN_END_B = (0x161), // A/D scan end interrupt for group B ELC_EVENT_ADC0_WINDOW_A = (0x162), // Window A Compare match interrupt ELC_EVENT_ADC0_WINDOW_B = (0x163), // Window B Compare match interrupt ELC_EVENT_ADC0_COMPARE_MATCH = (0x164), // Compare match ELC_EVENT_ADC0_COMPARE_MISMATCH = (0x165), // Compare mismatch ELC_EVENT_SCI0_RXI = (0x180), // Receive data full ELC_EVENT_SCI0_TXI = (0x181), // Transmit data empty ELC_EVENT_SCI0_TEI = (0x182), // Transmit end ELC_EVENT_SCI0_ERI = (0x183), // Receive error ELC_EVENT_SCI0_AM = (0x184), // Address match event ELC_EVENT_SCI0_RXI_OR_ERI = (0x185), // Receive data full/Receive error ELC_EVENT_SCI1_RXI = (0x186), // Receive data full ELC_EVENT_SCI1_TXI = (0x187), // Transmit data empty ELC_EVENT_SCI1_TEI = (0x188), // Transmit end ELC_EVENT_SCI1_ERI = (0x189), // Receive error ELC_EVENT_SCI3_RXI = (0x192), // Receive data full ELC_EVENT_SCI3_TXI = (0x193), // Transmit data empty ELC_EVENT_SCI3_TEI = (0x194), // Transmit end ELC_EVENT_SCI3_ERI = (0x195), // Receive error ELC_EVENT_SCI3_AM = (0x196), // Address match event ELC_EVENT_SCI4_RXI = (0x198), // Receive data full ELC_EVENT_SCI4_TXI = (0x199), // Transmit data empty ELC_EVENT_SCI4_TEI = (0x19A), // Transmit end ELC_EVENT_SCI4_ERI = (0x19B), // Receive error ELC_EVENT_SCI4_AM = (0x19C), // Address match event ELC_EVENT_SCI5_RXI = (0x19E), // Receive data full ELC_EVENT_SCI5_TXI = (0x19F), // Transmit data empty ELC_EVENT_SCI5_TEI = (0x1A0), // Transmit end ELC_EVENT_SCI5_ERI = (0x1A1), // Receive error ELC_EVENT_SCI5_AM = (0x1A2), // Address match event ELC_EVENT_SCI9_RXI = (0x1B6), // Receive data full ELC_EVENT_SCI9_TXI = (0x1B7), // Transmit data empty ELC_EVENT_SCI9_TEI = (0x1B8), // Transmit end ELC_EVENT_SCI9_ERI = (0x1B9), // Receive error ELC_EVENT_SCI9_AM = (0x1BA), // Address match event ELC_EVENT_SCIX0_SCIX0 = (0x1BC), // SCI0 extended serial mode event 0 ELC_EVENT_SCI1_SCIX0 = (0x1BC), // SCI0 extended serial mode event 0 ELC_EVENT_SCIX0_SCIX1 = (0x1BD), // SCI0 extended serial mode event 1 ELC_EVENT_SCI1_SCIX1 = (0x1BD), // SCI0 extended serial mode event 1 ELC_EVENT_SCIX0_SCIX2 = (0x1BE), // SCI0 extended serial mode event 2 ELC_EVENT_SCI1_SCIX2 = (0x1BE), // SCI0 extended serial mode event 2 ELC_EVENT_SCIX0_SCIX3 = (0x1BF), // SCI0 extended serial mode event 3 ELC_EVENT_SCI1_SCIX3 = (0x1BF), // SCI0 extended serial mode event 3 ELC_EVENT_SPI0_RXI = (0x1C4), // Receive buffer full ELC_EVENT_SPI0_TXI = (0x1C5), // Transmit buffer empty ELC_EVENT_SPI0_IDLE = (0x1C6), // Idle ELC_EVENT_SPI0_ERI = (0x1C7), // Error ELC_EVENT_SPI0_TEI = (0x1C8), // Transmission complete event ELC_EVENT_CAN0_MRAM_ERI = (0x1D0), // CANFD0 ECC error ELC_EVENT_QSPI_INT = (0x1DA), // QSPI interrupt ELC_EVENT_DOC_INT = (0x1DB), // Data operation circuit interrupt ELC_EVENT_I3C0_RESPONSE = (0x1DC), // Response status buffer full ELC_EVENT_I3C0_COMMAND = (0x1DD), // Command buffer empty ELC_EVENT_I3C0_IBI = (0x1DE), // IBI status buffer full ELC_EVENT_I3C0_RX = (0x1DF), // Receive ELC_EVENT_IICB0_RXI = (0x1DF), // Receive ELC_EVENT_I3C0_TX = (0x1E0), // Transmit ELC_EVENT_IICB0_TXI = (0x1E0), // Transmit ELC_EVENT_I3C0_RCV_STATUS = (0x1E1), // Receive status buffer full ELC_EVENT_I3C0_TEND = (0x1E6), // Transmit end ELC_EVENT_IICB0_TEI = (0x1E6), // Transmit end ELC_EVENT_I3C0_EEI = (0x1E7), // Error ELC_EVENT_IICB0_ERI = (0x1E7), // Error ELC_EVENT_I3C0_WU = (0x1EC), // Wake-up Condition Detection interrupt ELC_EVENT_RSIP_TADI = (0x1EE) // RSIP Tamper Detection } elc_event_t; #define BSP_PRV_VECT_ENUM(event,group) (ELC_ ## event) #define ELC_PERIPHERAL_NUM (19U) #define BSP_OVERRIDE_ELC_PERIPHERAL_T /** Possible peripherals to be linked to event signals * @note This list is device specific. * */ typedef enum e_elc_peripheral { ELC_PERIPHERAL_GPT_A = (0), ELC_PERIPHERAL_GPT_B = (1), ELC_PERIPHERAL_GPT_C = (2), ELC_PERIPHERAL_GPT_D = (3), ELC_PERIPHERAL_GPT_E = (4), ELC_PERIPHERAL_GPT_F = (5), ELC_PERIPHERAL_GPT_G = (6), ELC_PERIPHERAL_GPT_H = (7), ELC_PERIPHERAL_ADC0 = (8), ELC_PERIPHERAL_ADC0_B = (9), ELC_PERIPHERAL_DAC0 = (12), ELC_PERIPHERAL_IOPORT1 = (14), ELC_PERIPHERAL_IOPORT2 = (15), ELC_PERIPHERAL_IOPORT3 = (16), ELC_PERIPHERAL_IOPORT4 = (17), ELC_PERIPHERAL_CTSU = (18) } elc_peripheral_t; /** Positions of event link set registers (ELSRs) available on this MCU */ #define BSP_ELC_PERIPHERAL_MASK (0x0007D3FFU) /* UNCRUSTIFY-ON */ /** @} (end addtogroup BSP_MCU_RA4L1) */ #endif