123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359 |
- /*==================================================================================================
- * Project : RTD AUTOSAR 4.4
- * Platform : CORTEXM
- * Peripheral :
- * 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 INTCTRL_IP_H_
- #define INTCTRL_IP_H_
- /**
- * @file
- *
- * @defgroup IntCtrl_Ip Interrupt Controller IP
- * @ingroup Platform
- *
- * @addtogroup IntCtrl_Ip
- * @{
- */
- /*==================================================================================================
- * INCLUDE FILES
- ==================================================================================================*/
- #include "IntCtrl_Ip_Cfg.h"
- #include "Devassert.h"
- /*==================================================================================================
- * SOURCE FILE VERSION INFORMATION
- ==================================================================================================*/
- #define PLATFORM_INTCTRL_IP_VENDOR_ID 43
- #define PLATFORM_INTCTRL_IP_SW_MAJOR_VERSION 1
- #define PLATFORM_INTCTRL_IP_SW_MINOR_VERSION 0
- #define PLATFORM_INTCTRL_IP_SW_PATCH_VERSION 0
- /*==================================================================================================
- FILE VERSION CHECKS
- ==================================================================================================*/
- /* Check if current file and IntCtrl_Ip_Cfg header file are of the same vendor */
- #if (PLATFORM_INTCTRL_IP_VENDOR_ID != PLATFORM_INTCTRL_IP_CFG_VENDOR_ID)
- #error "IntCtrl_Ip.h and IntCtrl_Ip_Cfg.h have different vendor ids"
- #endif
- /* Check if current file and IntCtrl_Ip_Cfg header file are of the same Software version */
- #if ((PLATFORM_INTCTRL_IP_SW_MAJOR_VERSION != PLATFORM_INTCTRL_IP_CFG_SW_MAJOR_VERSION) || \
- (PLATFORM_INTCTRL_IP_SW_MINOR_VERSION != PLATFORM_INTCTRL_IP_CFG_SW_MINOR_VERSION) || \
- (PLATFORM_INTCTRL_IP_SW_PATCH_VERSION != PLATFORM_INTCTRL_IP_CFG_SW_PATCH_VERSION) \
- )
- #error "Software Version Numbers of IntCtrl_Ip.h and IntCtrl_Ip_Cfg.h are different"
- #endif
- /*==================================================================================================
- * FUNCTION PROTOTYPES
- ==================================================================================================*/
- #if defined(__cplusplus)
- extern "C" {
- #endif /* __cplusplus*/
- #define PLATFORM_START_SEC_CODE
- #include "Platform_MemMap.h"
- /**
- * @brief Initializes the configured interrupts at interrupt controller level.
- *
- * @details This function is non-reentrant and initializes the interrupts.
- *
- * @param[in] pIntCtrlCtrlConfig: pointer to configuration structure for interrupts.
- * @return IntCtrl_Ip_StatusType: error code.
- *
- * @api
- *
- * */
- IntCtrl_Ip_StatusType IntCtrl_Ip_Init(const IntCtrl_Ip_CtrlConfigType *pIntCtrlCtrlConfig);
- #if (INT_CTRL_IP_MSCM_SYSTEM_INTERRUPT_ROUTER == STD_ON)
- /**
- * @brief Initializes the configured routing interrupts .
- *
- * @details This function is non-reentrant and initializes the routing interrupts.
- *
- * @param[in] routeConfig: pointer to configuration structure for interrupts.
- * @return IntCtrl_Ip_StatusType: error code.
- *
- * @api
- *
- * */
- IntCtrl_Ip_StatusType IntCtrl_Ip_ConfigIrqRouting(const IntCtrl_Ip_GlobalRouteConfigType *routeConfig);
- #endif
- /**
- * @brief Installs a handler for an IRQ.
- *
- * @details This function is non-reentrant; it installs an new ISR for an interrupt line.
- * @note This function works only when the interrupt vector table resides in RAM.
- *
- * @param[in] eIrqNumber: interrupt number.
- * @param[in] pfNewHandler: function pointer for the new handler.
- * @param[out] pfOldHandler: stores the address of the old interrupt handler.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_InstallHandler(IRQn_Type eIrqNumber,
- const IntCtrl_Ip_IrqHandlerType pfNewHandler,
- IntCtrl_Ip_IrqHandlerType* const pfOldHandler);
- /**
- * @brief Enables an interrupt request.
- *
- * @details This function is non-reentrant; it enables the interrupt request at
- * interrupt controller level.
- *
- * @param[in] eIrqNumber: interrupt number to be enabled.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_EnableIrq(IRQn_Type eIrqNumber);
- /**
- * @brief Disables an interrupt request.
- *
- * @details This function is non-reentrant; it disables the interrupt request at
- * interrupt controller level.
- *
- * @param[in] eIrqNumber: interrupt number to be disabled.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_DisableIrq(IRQn_Type eIrqNumber);
- /**
- * @brief Sets the priority for an interrupt request.
- *
- * @details This function is non-reentrant; it sets the priority for the
- * interrupt request.
- *
- * @param[in] eIrqNumber: interrupt number for which the priority is set.
- * @param[in] u8Priority: the priority to be set.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_SetPriority(IRQn_Type eIrqNumber, uint8 u8Priority);
- /**
- * @brief Gets the priority for an interrupt request.
- *
- * @details This function is non-reentrant; it retrieves the priority for the
- * interrupt request.
- *
- * @param[in] eIrqNumber: interrupt number for which the priority is set.
- * @return uint8: the priority of the interrupt.
- *
- * @api
- *
- * */
- uint8 IntCtrl_Ip_GetPriority(IRQn_Type eIrqNumber);
- /**
- * @brief Clears the pending flag for an interrupt request.
- *
- * @details This function is reentrant; it clears the pending flag for the
- * interrupt request.
- *
- * @param[in] eIrqNumber: interrupt number for which the pending flag is cleared.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_ClearPending(IRQn_Type eIrqNumber);
- #if (INT_CTRL_IP_CORTEXR == STD_ON)
- /**
- * @brief Set ID interrupt to group1.
- *
- * @details This function is reentrant; it set the ID for the
- * interrupt request.
- *
- * @param[in] eIrqNumber: interrupt number for which ID need to write to group1.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_Group1(IRQn_Type eIrqNumber);
- /**
- * @brief Configures the specified ID as being level or edge triggered for an interrupt.
- *
- * @details This function is reentrant; the software must specify whether the interrupt is edge-triggered or level-sensitive. SGIs are always
- * treated as edge-triggered, and therefore GICR_ICFGR0 behaves as Read-As-One, Writes Ignored (RAO/WI) for these
- * interrupts.
- *
- * @param[in] eIrqNumber: interrupt number for which configures the specified ID asbeing level or edge triggered for an interrupt.
- * @param[in] conf: Configure the interrupt to be edge-triggered or level-sensitive.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_ConfigureSpi(IRQn_Type eIrqNumber, IntCtrl_Ip_TriggerType conf);
- /**
- * @brief Sets the target CPUs of the specified ID
- *
- * @details This function is reentrant; The SPI is delivered to the PE A.B.C.D, which are the affinity co-ordinates specified in the register. the affinity co-ordinates specified in the register
- *
- * @param[in] eIrqNumber: interrupt number for which Sets the target CPUs.
- * @param[in] target: the target of the interrupt routing mode
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_SetIntTarget(IRQn_Type eIrqNumber, IntCtrl_Ip_Routing_ModeType target);
- #endif
- #if (INT_CTRL_IP_STANDALONE_APIS == STD_ON)
- /**
- * @brief Sets the pending flag for an interrupt request.
- *
- * @details This function is reentrant; it sets the pending flag for the
- * interrupt request.
- *
- * @param[in] eIrqNumber: interrupt number for which the pending flag is set.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_SetPending(IRQn_Type eIrqNumber);
- /**
- * @brief Gets the pending flag for an interrupt request.
- *
- * @details This function is reentrant; it retrieves the pending flag for the
- * interrupt request.
- *
- * @param[in] eIrqNumber: interrupt number for which the pending flag is returned.
- * @return boolean: TRUE - pending flag set, FALSE - pending flag cleared.
- *
- * @api
- *
- * */
- boolean IntCtrl_Ip_GetPending(IRQn_Type eIrqNumber);
- /**
- * @brief Gets the active flag for an interrupt request.
- *
- * @details This function is reentrant; it retrieves the active flag for the
- * interrupt request.
- *
- * @param[in] eIrqNumber: interrupt number for which the active flag is returned.
- * @return boolean: TRUE - active flag set, FALSE - active flag cleared.
- *
- * @api
- *
- * */
- #if !defined(S32K116) && !defined(S32K118)
- boolean IntCtrl_Ip_GetActive(IRQn_Type eIrqNumber);
- #endif
- #endif /* INT_CTRL_IP_STANDALONE_APIS*/
- #if ((INT_CTRL_IP_MSCM_SYSTEM_INTERRUPT_ROUTER == STD_ON) && (INT_CTRL_IP_ROUTING_CONTROL_REGISTER == STD_ON))
- /**
- * @brief Sets the target cores for an interrupt request.
- *
- * @details This function is non-reentrant; it configures the target cores for the
- * interrupt request.
- *
- * @param[in] eIrqNumber: interrupt number for which the target cores are set.
- * @param[in] u8TargetCores: uint8 mask to defining the target cores.
- * @note u8TargetCores parameter encodes the CPU targets as defined in each platform
- * (see MSCM IRSPRCx register) - the function writes this value to the corresponding
- * IRSPRCx register directly.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_SetTargetCores(IRQn_Type eIrqNumber, uint8 u8TargetCores);
- #endif
- #if (INT_CTRL_IP_MSI_AVAILABLE == STD_ON)
- /**
- * @brief Clear directed cpu Interrupt interrupt flag.
- *
- * @details This function is non-reentrant; it is provided for clearing directed cpu Interrupt interrupt flag.
- *
- * @param[in] eIrqNumber: interrupt number
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_ClearDirectedCpuInterrupt(IRQn_Type eIrqNumber);
- /**
- * @brief Get directed cpu Interrupt interrupt flag.
- *
- * @details This function is non-reentrant; it is provided for getting directed cpu Interrupt interrupt flag.
- *
- * @param[in] eIrqNumber: interrupt number
- * @return boolean: TRUE - flag set, FALSE - flag cleared.
- *
- * @api
- *
- * */
- boolean IntCtrl_Ip_GetDirectedCpuInterrupt(IRQn_Type eIrqNumber);
- /**
- * @brief Generates an interrupt request to a CPU target.
- *
- * @details This function is non-reentrant; it is provided for generating a directed interrupt
- * to a CPU defined by target parameter.
- *
- * @param[in] eIrqNumber: interrupt number to be triggered.
- * @param[in] eCpuTarget: target core for the interrupt request.
- * @return void.
- *
- * @api
- *
- * */
- void IntCtrl_Ip_GenerateDirectedCpuInterrupt(IRQn_Type eIrqNumber, IntCtrl_Ip_IrqTargetType eCpuTarget);
- #endif
- #define PLATFORM_STOP_SEC_CODE
- #include "Platform_MemMap.h"
- #if defined(__cplusplus)
- }
- #endif /* __cplusplus*/
- #endif /* INTCTRL_IP_H_ */
- /** @} */
|