/*================================================================================================== * 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. ==================================================================================================*/ /** * @file Power_Ip_CotexM4.h * @version 1.0.0 * * @brief POWER IP driver header file. * @details POWER IP driver header file. * * @addtogroup POWER_DRIVER Power Ip Driver * @{ */ #ifndef POWER_IP_CORTEXM4_H #define POWER_IP_CORTEXM4_H #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 "Power_Ip_Types.h" /*================================================================================================== SOURCE FILE VERSION INFORMATION ==================================================================================================*/ #define POWER_IP_CORTEXM4_VENDOR_ID 43 #define POWER_IP_CORTEXM4_AR_RELEASE_MAJOR_VERSION 4 #define POWER_IP_CORTEXM4_AR_RELEASE_MINOR_VERSION 4 #define POWER_IP_CORTEXM4_AR_RELEASE_REVISION_VERSION 0 #define POWER_IP_CORTEXM4_SW_MAJOR_VERSION 1 #define POWER_IP_CORTEXM4_SW_MINOR_VERSION 0 #define POWER_IP_CORTEXM4_SW_PATCH_VERSION 0 /*================================================================================================== FILE VERSION CHECKS ==================================================================================================*/ /* Check if Power_Ip_CortexM4.h file and Power_Ip_Types.h file have same versions */ #if (POWER_IP_CORTEXM4_VENDOR_ID != POWER_IP_TYPES_VENDOR_ID) #error "Power_Ip_CortexM4.h and Power_Ip_Types.h have different vendor IDs" #endif /* Check if Power_Ip_CortexM4.h file and Power_Ip_Types.h file are of the same Autosar version */ #if ((POWER_IP_CORTEXM4_AR_RELEASE_MAJOR_VERSION != POWER_IP_TYPES_AR_RELEASE_MAJOR_VERSION) || \ (POWER_IP_CORTEXM4_AR_RELEASE_MINOR_VERSION != POWER_IP_TYPES_AR_RELEASE_MINOR_VERSION) || \ (POWER_IP_CORTEXM4_AR_RELEASE_REVISION_VERSION != POWER_IP_TYPES_AR_RELEASE_REVISION_VERSION)) #error "AutoSar Version Numbers of Power_Ip_CortexM4.h and Power_Ip_Types.h are different" #endif /* Check if Power_Ip_CortexM4.h file and Power_Ip_Types.h file are of the same Software version */ #if ((POWER_IP_CORTEXM4_SW_MAJOR_VERSION != POWER_IP_TYPES_SW_MAJOR_VERSION) || \ (POWER_IP_CORTEXM4_SW_MINOR_VERSION != POWER_IP_TYPES_SW_MINOR_VERSION) || \ (POWER_IP_CORTEXM4_SW_PATCH_VERSION != POWER_IP_TYPES_SW_PATCH_VERSION)) #error "Software Version Numbers of Power_Ip_CortexM4.h and Power_Ip_Types.h are different" #endif /*================================================================================================== * GLOBAL VARIABLE DECLARATIONS ==================================================================================================*/ /*================================================================================================== * ENUMS ==================================================================================================*/ /*================================================================================================== * CONSTANTS ==================================================================================================*/ /*================================================================================================== * DEFINES AND MACROS ==================================================================================================*/ /***********************************************************/ /* CortexM4 System Control Register */ /***********************************************************/ #define CM4_AIRCR_BASEADDR ((uint32)0xE000ED0CU) #define CM4_AIRCR_SYSRESETREQ_MASK 0x4u #define CM4_AIRCR_PRIGROUP_MASK 0x700u #define CM4_AIRCR_VECTKEY_MASK 0xFFFF0000u #define CM4_AIRCR_VECTKEY_SHIFT 16u #define CM4_AIRCR_VECTKEY(x) (((uint32)(((uint32)(x))<