/*==================================================================================================
*   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))<<CM4_AIRCR_VECTKEY_SHIFT))&CM4_AIRCR_VECTKEY_MASK)

#define CM4_SCR_SLEEPONEXIT_MASK32  ((uint32)0x00000002U)
#define CM4_SCR_SLEEPDEEP_MASK32    ((uint32)0x00000004U)

/*==================================================================================================
*                                 STRUCTURES AND OTHER TYPEDEFS
==================================================================================================*/

typedef struct{
    volatile uint32 AIRCR;                             /**< Application Interrupt and Reset Control Register , offset: 0xC */
    volatile uint32 SCR;                               /**< System Control Register, offset: 0x0 */
} Power_Ip_CM4_Type;
/*==================================================================================================
*                                      FUNCTION PROTOTYPES
==================================================================================================*/
#define MCU_START_SEC_CODE
#include "Mcu_MemMap.h"


#ifdef POWER_IP_SLEEPONEXIT_SUPPORT
#if (POWER_IP_SLEEPONEXIT_SUPPORT == STD_ON)
#ifdef POWER_IP_ENABLE_USER_MODE_SUPPORT
#if (STD_ON == POWER_IP_ENABLE_USER_MODE_SUPPORT)
#define  Call_Power_Ip_CM4_EnableSleepOnExit()  OsIf_Trusted_Call(Power_Ip_CM4_EnableSleepOnExit)
#define  Call_Power_Ip_CM4_DisableSleepOnExit() OsIf_Trusted_Call(Power_Ip_CM4_DisableSleepOnExit)
#else
#define  Call_Power_Ip_CM4_EnableSleepOnExit()  Power_Ip_CM4_EnableSleepOnExit()
#define  Call_Power_Ip_CM4_DisableSleepOnExit() Power_Ip_CM4_DisableSleepOnExit()
#endif /* (STD_ON == POWER_IP_ENABLE_USER_MODE_SUPPORT) */
#else /* POWER_IP_ENABLE_USER_MODE_SUPPORT */
#define  Call_Power_Ip_CM4_EnableSleepOnExit()  Power_Ip_CM4_EnableSleepOnExit()
#define  Call_Power_Ip_CM4_DisableSleepOnExit() Power_Ip_CM4_DisableSleepOnExit()
#endif /* POWER_IP_ENABLE_USER_MODE_SUPPORT */
#endif /* POWER_IP_SLEEPONEXIT_SUPPORT == STD_ON */
#endif /* POWER_IP_SLEEPONEXIT_SUPPORT */

#ifdef POWER_IP_ENABLE_USER_MODE_SUPPORT
#if (STD_ON == POWER_IP_ENABLE_USER_MODE_SUPPORT)
#define  Call_Power_Ip_CM4_EnableDeepSleep() \
do\
{ \
        OsIf_Trusted_Call(Power_Ip_CM4_EnableDeepSleep); \
}\
while(0)

#define  Call_Power_Ip_CM4_DisableDeepSleep() \
do\
{ \
        OsIf_Trusted_Call(Power_Ip_CM4_DisableDeepSleep); \
}\
while(0)

#else
#define  Call_Power_Ip_CM4_EnableDeepSleep() \
do\
{ \
        Power_Ip_CM4_EnableDeepSleep(); \
}\
while(0)

#define  Call_Power_Ip_CM4_DisableDeepSleep() \
do\
{ \
        Power_Ip_CM4_DisableDeepSleep(); \
}\
while(0)
#endif
#endif



#if (MCU_PERFORM_RESET_API == STD_ON)

#ifdef POWER_IP_ENABLE_USER_MODE_SUPPORT
#if (STD_ON == POWER_IP_ENABLE_USER_MODE_SUPPORT)
#define  Call_Power_Ip_CM4_SystemReset() \
do\
{ \
        OsIf_Trusted_Call(Power_Ip_CM4_SystemReset); \
}\
while(0)
#else
#define  Call_Power_Ip_CM4_SystemReset() \
do\
{ \
        Power_Ip_CM4_SystemReset(); \
}\
while(0)
#endif
#endif

#endif /* (MCU_PERFORM_RESET_API == STD_ON) */


#if (MCU_PERFORM_RESET_API == STD_ON)
 /**
* @brief        The function initiates a system reset request to reset the SoC.
* @details      The function initiates a system reset request to reset the SoC
*
* @param[in]    none
*
* @return void
*
*/
void Power_Ip_CM4_SystemReset(void);

#endif

#ifdef POWER_IP_SLEEPONEXIT_SUPPORT
#if (POWER_IP_SLEEPONEXIT_SUPPORT == STD_ON)

void Power_Ip_CM4_EnableSleepOnExit(void);
void Power_Ip_CM4_DisableSleepOnExit(void);
  #endif
#endif

void Power_Ip_CM4_EnableDeepSleep(void);
void Power_Ip_CM4_DisableDeepSleep(void);


#define MCU_STOP_SEC_CODE
#include "Mcu_MemMap.h"

#ifdef __cplusplus
}
#endif

#endif /* POWER_IP_CORTEXM4_H */

/** @} */