/*================================================================================================== * Project : RTD AUTOSAR 4.4 * Platform : CORTEXM * Peripheral : Ftm Lpit Lptmr Port_Ci LpCmp * Dependencies : none * * Autosar Version : 4.4.0 * Autosar Revision : ASR_REL_4_4_REV_0000 * Autosar Conf.Variant : * SW Version : 1.0.0 * Build Version : S32K1_RTD_1_0_0_HF01_D2109_ASR_REL_4_4_REV_0000_20210907 * * (c) Copyright 2020-2021 NXP Semiconductors * All Rights Reserved. * * NXP Confidential. This software is owned or controlled by NXP and may only be * used strictly in accordance with the applicable license terms. By expressly * accepting such terms or by downloading, installing, activating and/or otherwise * using the software, you are agreeing that you have read, and that you agree to * comply with and are bound by, such license terms. If you do not agree to be * bound by the applicable license terms, then you may not retain, install, * activate or otherwise use the software. ==================================================================================================*/ #ifndef FTM_ICU_IP_IRQ_H #define FTM_ICU_IP_IRQ_H /** * @file Interrupt functions description. * @details This file contains the signature of interrups functions that can be used on the * FTM module. * @addtogroup ftm_icu_ip FTM IPL * @{ */ #ifdef __cplusplus extern "C"{ #endif /*================================================================================================== * INCLUDE FILES * 1) system and project includes * 2) needed interfaces from external units * 3) internal and external interfaces from this unit ==================================================================================================*/ #include "OsIf.h" #include "Ftm_Icu_Ip_Cfg.h" #include "Ftm_Icu_Ip_Types.h" /*================================================================================================== * SOURCE FILE VERSION INFORMATION ==================================================================================================*/ #define FTM_ICU_IP_IRQ_VENDOR_ID 43 #define FTM_ICU_IP_IRQ_AR_RELEASE_MAJOR_VERSION 4 #define FTM_ICU_IP_IRQ_AR_RELEASE_MINOR_VERSION 4 #define FTM_ICU_IP_IRQ_AR_RELEASE_REVISION_VERSION 0 #define FTM_ICU_IP_IRQ_SW_MAJOR_VERSION 1 #define FTM_ICU_IP_IRQ_SW_MINOR_VERSION 0 #define FTM_ICU_IP_IRQ_SW_PATCH_VERSION 0 /*================================================================================================== * FILE VERSION CHECKS ==================================================================================================*/ #ifndef DISABLE_MCAL_INTERMODULE_ASR_CHECK /* Check if header file and OsIf.h file are of the same Autosar version */ #if ((FTM_ICU_IP_IRQ_AR_RELEASE_MAJOR_VERSION != OSIF_AR_RELEASE_MAJOR_VERSION) || \ (FTM_ICU_IP_IRQ_AR_RELEASE_MINOR_VERSION != OSIF_AR_RELEASE_MINOR_VERSION)) #error "AutoSar Version Numbers of Ftm_Icu_Ip_Irq.h and OsIf.h are different" #endif #endif /* Check if source file and ICU header file are of the same vendor */ #if (FTM_ICU_IP_IRQ_VENDOR_ID != FTM_ICU_IP_CFG_VENDOR_ID) #error "Ftm_Icu_Ip_Irq.h and Ftm_Icu_Ip_Cfg.h have different vendor IDs" #endif /* Check if source file and ICU header file are of the same AutoSar version */ #if ((FTM_ICU_IP_IRQ_AR_RELEASE_MAJOR_VERSION != FTM_ICU_IP_CFG_AR_RELEASE_MAJOR_VERSION) || \ (FTM_ICU_IP_IRQ_AR_RELEASE_MINOR_VERSION != FTM_ICU_IP_CFG_AR_RELEASE_MINOR_VERSION) || \ (FTM_ICU_IP_IRQ_AR_RELEASE_REVISION_VERSION != FTM_ICU_IP_CFG_AR_RELEASE_REVISION_VERSION)) #error "AutoSar Version Numbers of Ftm_Icu_Ip_Irq.h and Ftm_Icu_Ip_Cfg.h are different" #endif /* Check if source file and ICU header file are of the same Software version */ #if ((FTM_ICU_IP_IRQ_SW_MAJOR_VERSION != FTM_ICU_IP_CFG_SW_MAJOR_VERSION) || \ (FTM_ICU_IP_IRQ_SW_MINOR_VERSION != FTM_ICU_IP_CFG_SW_MINOR_VERSION) || \ (FTM_ICU_IP_IRQ_SW_PATCH_VERSION != FTM_ICU_IP_CFG_SW_PATCH_VERSION)) #error "Software Version Numbers of Ftm_Icu_Ip_Irq.h and Ftm_Icu_Ip_Cfg.h are different" #endif /* Check if source file and ICU header file are of the same vendor */ #if (FTM_ICU_IP_IRQ_VENDOR_ID != FTM_ICU_IP_TYPES_VENDOR_ID) #error "Ftm_Icu_Ip_Irq.h and Ftm_Icu_Ip_Types.h have different vendor IDs" #endif /* Check if source file and ICU header file are of the same AutoSar version */ #if ((FTM_ICU_IP_IRQ_AR_RELEASE_MAJOR_VERSION != FTM_ICU_IP_TYPES_AR_RELEASE_MAJOR_VERSION) || \ (FTM_ICU_IP_IRQ_AR_RELEASE_MINOR_VERSION != FTM_ICU_IP_TYPES_AR_RELEASE_MINOR_VERSION) || \ (FTM_ICU_IP_IRQ_AR_RELEASE_REVISION_VERSION != FTM_ICU_IP_TYPES_AR_RELEASE_REVISION_VERSION)) #error "AutoSar Version Numbers of Ftm_Icu_Ip_Irq.h and Ftm_Icu_Ip_Types.h are different" #endif /* Check if source file and ICU header file are of the same Software version */ #if ((FTM_ICU_IP_IRQ_SW_MAJOR_VERSION != FTM_ICU_IP_TYPES_SW_MAJOR_VERSION) || \ (FTM_ICU_IP_IRQ_SW_MINOR_VERSION != FTM_ICU_IP_TYPES_SW_MINOR_VERSION) || \ (FTM_ICU_IP_IRQ_SW_PATCH_VERSION != FTM_ICU_IP_TYPES_SW_PATCH_VERSION)) #error "Software Version Numbers of Ftm_Icu_Ip_Irq.h and Ftm_Icu_Ip_Types.h are different" #endif /*================================================================================================== * CONSTANTS ==================================================================================================*/ /*================================================================================================== * DEFINES AND MACROS ==================================================================================================*/ /*================================================================================================== * ENUMS ==================================================================================================*/ /*================================================================================================== * STRUCTURES AND OTHER TYPEDEFS ==================================================================================================*/ /*================================================================================================== * GLOBAL VARIABLE DECLARATIONS ==================================================================================================*/ /*================================================================================================== * FUNCTION PROTOTYPES ==================================================================================================*/ #define ICU_START_SEC_CODE #include "Icu_MemMap.h" #if (defined FTM_ICU_0_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 0. */ ISR(FTM_0_ISR); #endif #if (defined FTM_ICU_1_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 1. */ ISR(FTM_1_ISR); #endif #if (defined FTM_ICU_0_CH_0_CH_1_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 0 channel 0 - channel 1. */ ISR(FTM_0_CH_0_CH_1_ISR); #endif #if (defined FTM_ICU_0_CH_2_CH_3_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 0 channel 2 - channel 3. */ ISR(FTM_0_CH_2_CH_3_ISR); #endif #if (defined FTM_ICU_0_CH_4_CH_5_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 0 channel 4 - channel 5. */ ISR(FTM_0_CH_4_CH_5_ISR); #endif #if (defined FTM_ICU_0_CH_6_CH_7_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 0 channel 6 - channel 7. */ ISR(FTM_0_CH_6_CH_7_ISR); #endif #if (defined FTM_ICU_1_CH_0_CH_1_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 1 channel 0 - channel 1. */ ISR(FTM_1_CH_0_CH_1_ISR); #endif #if (defined FTM_ICU_1_CH_2_CH_3_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 1 channel 2 - channel 3. */ ISR(FTM_1_CH_2_CH_3_ISR); #endif #if (defined FTM_ICU_1_CH_4_CH_5_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 1 channel 4 - channel 5. */ ISR(FTM_1_CH_4_CH_5_ISR); #endif #if (defined FTM_ICU_1_CH_6_CH_7_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 1 channel 6 - channel 7. */ ISR(FTM_1_CH_6_CH_7_ISR); #endif #if (defined FTM_ICU_2_CH_0_CH_1_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 2 channel 0 - channel 1. */ ISR(FTM_2_CH_0_CH_1_ISR); #endif #if (defined FTM_ICU_2_CH_2_CH_3_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 2 channel 2 - channel 3. */ ISR(FTM_2_CH_2_CH_3_ISR); #endif #if (defined FTM_ICU_2_CH_4_CH_5_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 2 channel 4 - channel 5. */ ISR(FTM_2_CH_4_CH_5_ISR); #endif #if (defined FTM_ICU_2_CH_6_CH_7_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 2 channel 6 - channel 7. */ ISR(FTM_2_CH_6_CH_7_ISR); #endif #if (defined FTM_ICU_3_CH_0_CH_1_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 3 channel 0 - channel 1. */ ISR(FTM_3_CH_0_CH_1_ISR); #endif #if (defined FTM_ICU_3_CH_2_CH_3_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 3 channel 2 - channel 3. */ ISR(FTM_3_CH_2_CH_3_ISR); #endif #if (defined FTM_ICU_3_CH_4_CH_5_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 3 channel 4 - channel 5. */ ISR(FTM_3_CH_4_CH_5_ISR); #endif #if (defined FTM_ICU_3_CH_6_CH_7_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 3 channel 6 - channel 7. */ ISR(FTM_3_CH_6_CH_7_ISR); #endif #if (defined FTM_ICU_4_CH_0_CH_1_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 4 channel 0 - channel 1. */ ISR(FTM_4_CH_0_CH_1_ISR); #endif #if (defined FTM_ICU_4_CH_2_CH_3_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 4 channel 2 - channel 3. */ ISR(FTM_4_CH_2_CH_3_ISR); #endif #if (defined FTM_ICU_4_CH_4_CH_5_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 4 channel 4 - channel 5. */ ISR(FTM_4_CH_4_CH_5_ISR); #endif #if (defined FTM_ICU_4_CH_6_CH_7_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 4 channel 6 - channel 7. */ ISR(FTM_4_CH_6_CH_7_ISR); #endif #if (defined FTM_ICU_5_CH_0_CH_1_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 5 channel 0 - channel 1. */ ISR(FTM_5_CH_0_CH_1_ISR); #endif #if (defined FTM_ICU_5_CH_2_CH_3_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 5 channel 2 - channel 3. */ ISR(FTM_5_CH_2_CH_3_ISR); #endif #if (defined FTM_ICU_5_CH_4_CH_5_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 5 channel 4 - channel 5. */ ISR(FTM_5_CH_4_CH_5_ISR); #endif #if (defined FTM_ICU_5_CH_6_CH_7_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 5 channel 6 - channel 7. */ ISR(FTM_5_CH_6_CH_7_ISR); #endif #if (defined FTM_ICU_6_CH_0_CH_1_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 6 channel 0 - channel 1. */ ISR(FTM_6_CH_0_CH_1_ISR); #endif #if (defined FTM_ICU_6_CH_2_CH_3_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 6 channel 2 - channel 3. */ ISR(FTM_6_CH_2_CH_3_ISR); #endif #if (defined FTM_ICU_6_CH_4_CH_5_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 6 channel 4 - channel 5. */ ISR(FTM_6_CH_4_CH_5_ISR); #endif #if (defined FTM_ICU_6_CH_6_CH_7_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 6 channel 6 - channel 7. */ ISR(FTM_6_CH_6_CH_7_ISR); #endif #if (defined FTM_ICU_7_CH_0_CH_1_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 7 channel 0 - channel 1. */ ISR(FTM_7_CH_0_CH_1_ISR); #endif #if (defined FTM_ICU_7_CH_2_CH_3_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 7 channel 2 - channel 3. */ ISR(FTM_7_CH_2_CH_3_ISR); #endif #if (defined FTM_ICU_7_CH_4_CH_5_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 7 channel 4 - channel 5. */ ISR(FTM_7_CH_4_CH_5_ISR); #endif #if (defined FTM_ICU_7_CH_6_CH_7_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 7 channel 6 - channel 7. */ ISR(FTM_7_CH_6_CH_7_ISR); #endif #if (defined FTM_ICU_0_OVF_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 0 overflow. */ ISR(FTM_0_OVF_ISR); #endif #if (defined FTM_ICU_1_OVF_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 1 overflow. */ ISR(FTM_1_OVF_ISR); #endif #if (defined FTM_ICU_2_OVF_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 2 overflow. */ ISR(FTM_2_OVF_ISR); #endif #if (defined FTM_ICU_3_OVF_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 3 overflow. */ ISR(FTM_3_OVF_ISR); #endif #if (defined FTM_ICU_4_OVF_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 4 overflow. */ ISR(FTM_4_OVF_ISR); #endif #if (defined FTM_ICU_5_OVF_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 5 overflow. */ ISR(FTM_5_OVF_ISR); #endif #if (defined FTM_ICU_6_OVF_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 6 overflow. */ ISR(FTM_6_OVF_ISR); #endif #if (defined FTM_ICU_7_OVF_ISR_USED) /** * @brief Independent interrupt handler. * @details Interrupt handler for FTM module 7 overflow. */ ISR(FTM_7_OVF_ISR); #endif #define ICU_STOP_SEC_CODE #include "Icu_MemMap.h" #ifdef __cplusplus } #endif /** @} */ #endif /* FTM_ICU_IP_IRQ_H */