/*==================================================================================================
*   Project              : RTD AUTOSAR 4.4
*   Platform             : CORTEXM
*   Peripheral           : DMA,CACHE,TRGMUX,FLEXIO
*   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 CACHE_IP_CFG_DEFINES_H_
#define CACHE_IP_CFG_DEFINES_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 "Cache_Ip_Types.h"

/*==================================================================================================
                               SOURCE FILE VERSION INFORMATION
==================================================================================================*/
#define CACHE_IP_CFG_DEFINES_VENDOR_ID_H                       43
#define CACHE_IP_CFG_DEFINES_AR_RELEASE_MAJOR_VERSION_H        4
#define CACHE_IP_CFG_DEFINES_AR_RELEASE_MINOR_VERSION_H        4
#define CACHE_IP_CFG_DEFINES_AR_RELEASE_REVISION_VERSION_H     0
#define CACHE_IP_CFG_DEFINES_SW_MAJOR_VERSION_H                1
#define CACHE_IP_CFG_DEFINES_SW_MINOR_VERSION_H                0
#define CACHE_IP_CFG_DEFINES_SW_PATCH_VERSION_H                0

/*==================================================================================================
                                      FILE VERSION CHECKS
==================================================================================================*/
/* Check if header file and Cache_Ip_Types.h file are of the same vendor */
#if (CACHE_IP_CFG_DEFINES_VENDOR_ID_H != CACHE_IP_TYPES_VENDOR_ID_H)
    #error "Cache_Ip_Cfg_Defines.h and Cache_Ip_Types.h have different vendor ids"
#endif

/* Check if header file and Cache_Ip_Types.h file are of the same Autosar version */
#if ((CACHE_IP_CFG_DEFINES_AR_RELEASE_MAJOR_VERSION_H != CACHE_IP_TYPES_AR_RELEASE_MAJOR_VERSION_H) || \
     (CACHE_IP_CFG_DEFINES_AR_RELEASE_MINOR_VERSION_H != CACHE_IP_TYPES_AR_RELEASE_MINOR_VERSION_H) || \
     (CACHE_IP_CFG_DEFINES_AR_RELEASE_REVISION_VERSION_H != CACHE_IP_TYPES_AR_RELEASE_REVISION_VERSION_H) \
    )
    #error "AutoSar Version Numbers of Cache_Ip_Cfg_Defines.h and Cache_Ip_Types.h are different"
#endif

/* Check if header file and Cache_Ip_Types.h file are of the same Software version */
#if ((CACHE_IP_CFG_DEFINES_SW_MAJOR_VERSION_H != CACHE_IP_TYPES_SW_MAJOR_VERSION_H) || \
     (CACHE_IP_CFG_DEFINES_SW_MINOR_VERSION_H != CACHE_IP_TYPES_SW_MINOR_VERSION_H) || \
     (CACHE_IP_CFG_DEFINES_SW_PATCH_VERSION_H != CACHE_IP_TYPES_SW_PATCH_VERSION_H) \
    )
    #error "Software Version Numbers of Cache_Ip_Cfg_Defines.h and Cache_Ip_Types.h are different"
#endif

/*==================================================================================================
                                       DEFINES AND MACROS
==================================================================================================*/
/*-----------------------------------------------/
/  CACHE IP USER MODE SUPPORT                    /
/-----------------------------------------------*/
#define CACHE_IP_USER_MODE_SUPPORT_IS_AVAILABLE      STD_OFF


/*-----------------------------------------------/
/  CACHE IP SUPPORT                              /
/-----------------------------------------------*/

#define CACHE_IP_IS_AVAILABLE                  STD_ON

#define CACHE_IP_ARMCOREMX_IS_AVAILABLE        STD_OFF
#define CACHE_IP_LMEM_IS_AVAILABLE             STD_ON

#define CACHE_IP_ALL_IS_AVAILABLE              STD_ON
#define CACHE_IP_INSTRUCTION_IS_AVAILABLE      STD_OFF
#define CACHE_IP_DATA_IS_AVAILABLE             STD_OFF
#define CACHE_IP_LMEM_PC_IS_AVAILABLE          STD_ON
#define CACHE_IP_LMEM_PS_IS_AVAILABLE          STD_OFF

#define CACHE_IP_DEV_ERROR_DETECT              STD_OFF
/*-----------------------------------------------/
/  CACHE IP SPECIFIC                             /
/-----------------------------------------------*/
#define CACHE_IP_LMEM_LINE_SIZE                16U
#define CACHE_IP_LMEM_COMMAND_TIMEOUT_VAL      100000
#define CACHE_IP_LMEM_COMMAND_TIMEOUT_TYPE     OSIF_COUNTER_DUMMY


#ifdef __cplusplus
}
#endif

#endif /* CACHE_IP_CFG_DEFINES_H_ */