/*==================================================================================================
    *   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_ASR_REL_4_4_REV_0000_20210810
    *
    *   (c) Copyright 2020 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       Clock_Ip_Cfg_Defines.h
*   @version    1.0.0
*
*   @brief   AUTOSAR Mcu - Post-Build(PB) configuration file code template.
*   @details Code template for Post-Build(PB) configuration file generation.
*
*   @addtogroup CLOCK_DRIVER_CONFIGURATION Clock Driver
*   @{
*/

#ifndef CLOCK_IP_CFG_DEFINES_H
#define CLOCK_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
==================================================================================================*/

/*==================================================================================================
                               SOURCE FILE VERSION INFORMATION
==================================================================================================*/
#define CLOCK_IP_CFG_DEFINES_VENDOR_ID                       43
#define CLOCK_IP_CFG_DEFINES_AR_RELEASE_MAJOR_VERSION        4
#define CLOCK_IP_CFG_DEFINES_AR_RELEASE_MINOR_VERSION        4
#define CLOCK_IP_CFG_DEFINES_AR_RELEASE_REVISION_VERSION     0
#define CLOCK_IP_CFG_DEFINES_SW_MAJOR_VERSION                1
#define CLOCK_IP_CFG_DEFINES_SW_MINOR_VERSION                0
#define CLOCK_IP_CFG_DEFINES_SW_PATCH_VERSION                0

/*==================================================================================================
                                           DEFINES AND MACROS
==================================================================================================*/
/**
* @brief            Derivative used.
*/
#define CLOCK_IP_S32K146
/**
* @brief            HW sseries used.
*/
#define CLOCK_IP_S32K1
/**
* @brief            Max number of internal oscillators
*/
#define FEATURE_CLOCK_IRCOSCS_COUNT       (2U)

/**
* @brief            Max number of external oscillators
*/
#define FEATURE_CLOCK_XOSCS_COUNT       (1U)

/**
* @brief            Max number of pll devices
*/
#define FEATURE_CLOCK_PLLS_COUNT       (1U)

/**
* @brief            Max number of selectors
*/
#define FEATURE_CLOCK_SELECTORS_COUNT       (32U)

/**
* @brief            Max number of dividers
*/
#define FEATURE_CLOCK_DIVIDERS_COUNT       (20U)

/**
* @brief            Max number of divider triggers
*/
#define FEATURE_CLOCK_DIVIDER_TRIGGERS_COUNT       (0U)

/**
* @brief            Max number of fractional dividers
*/
#define FEATURE_CLOCK_FRACTIONAL_DIVIDERS_COUNT       (0U)

/**
* @brief            Max number of external clocks
*/
#define FEATURE_CLOCK_EXT_CLKS_COUNT       (4U)

/**
* @brief            Max number of pcfs
*/
#define FEATURE_CLOCK_PCFS_COUNT       (0U)

/**
* @brief            Max number of clock gates
*/
#define FEATURE_CLOCK_GATES_COUNT       (42U)

/**
* @brief            Max number of clock monitoring units
*/
#define FEATURE_CLOCK_CMUS_COUNT       (0U)

/**
* @brief            Max number of configured frequencies values
*/
#define FEATURE_CLOCK_CONFIGURED_FREQUENCIES_COUNT       0U

/**
* @brief             Max number of specific peripheral (eMIOS) units
*/
#define FEATURE_CLOCK_SPECIFIC_PERIPH_COUNT       (0U)

/**
* @brief             Max number of consumer clocks
*/
#define FEATURE_CLOCK_CONSUMER_COUNT     (41U)

/**
* @brief            Supported power mode.
*/
#define FEATURE_CLOCK_IP_HAS_RUN_MODE                  0U

#define FEATURE_CLOCK_IP_LPO_128K_FREQUENCY            128000U

#define FEATURE_CLOCK_IP_FIRC_FREQUENCY                48000000U

#define FEATURE_CLOCK_IP_SIRC_FREQUENCY                8000000U

#define FEATURE_CLOCK_IP_DEFAULT_SOSC_FREQUENCY        40000000U

#define FEATURE_CLOCK_IP_HAS_LOW_GAIN                  0U

#define FEATURE_CLOCK_IP_HAS_HIGH_GAIN                 1U

#define FEATURE_CLOCK_IP_HAS_MONITOR_DISABLE           0U

#define FEATURE_CLOCK_IP_HAS_MONITOR_INT               1U

#define FEATURE_CLOCK_IP_HAS_MONITOR_RESET             2U

#define FEATURE_CLOCK_IP_HAS_SAFE_CLOCK_DISABLEMENT    1U

#if FEATURE_CLOCK_CMUS_COUNT > 0U
/**
* @brief            Cmu formula constant values.
*/
#define FEATURE_OFFSET_REFERENCE_COUNT_FORMULA1               1U
#define FEATURE_MULTIPLIER_REFERENCE_COUNT_FORMULA1           3U
#define FEATURE_OFFSET_REFERENCE_COUNT_FORMULA2               7U
#define FEATURE_MULTIPLIER_REFERENCE_COUNT_FORMULA2           3U
#endif

/**
* @brief            Clock ip supports clock frequency.
*/
#define CLOCK_IP_GET_FREQUENCY_API                (STD_OFF)

/**
* @brief            Supported clocks.
*/
#define FEATURE_CLOCK_IP_HAS_LPO_128K_CLK         1U
#define FEATURE_CLOCK_IP_HAS_SIRC_CLK         2U
#define FEATURE_CLOCK_IP_HAS_SIRC_VLP_CLK         3U
#define FEATURE_CLOCK_IP_HAS_SIRC_STOP_CLK         4U
#define FEATURE_CLOCK_IP_HAS_FIRC_CLK         5U
#define FEATURE_CLOCK_IP_HAS_FIRC_VLP_CLK         6U
#define FEATURE_CLOCK_IP_HAS_FIRC_STOP_CLK         7U
#define FEATURE_CLOCK_IP_HAS_SOSC_CLK         8U
#define FEATURE_CLOCK_IP_HAS_SPLL_CLK         9U
#define FEATURE_CLOCK_IP_HAS_SIRCDIV1_CLK         10U
#define FEATURE_CLOCK_IP_HAS_SIRCDIV2_CLK         11U
#define FEATURE_CLOCK_IP_HAS_FIRCDIV1_CLK         12U
#define FEATURE_CLOCK_IP_HAS_FIRCDIV2_CLK         13U
#define FEATURE_CLOCK_IP_HAS_SOSCDIV1_CLK         14U
#define FEATURE_CLOCK_IP_HAS_SOSCDIV2_CLK         15U
#define FEATURE_CLOCK_IP_HAS_SPLLDIV1_CLK         16U
#define FEATURE_CLOCK_IP_HAS_SPLLDIV2_CLK         17U
#define FEATURE_CLOCK_IP_HAS_LPO_32K_CLK         18U
#define FEATURE_CLOCK_IP_HAS_LPO_1K_CLK         19U
#define FEATURE_CLOCK_IP_HAS_TCLK0_REF_CLK         20U
#define FEATURE_CLOCK_IP_HAS_TCLK1_REF_CLK         21U
#define FEATURE_CLOCK_IP_HAS_TCLK2_REF_CLK         22U
#define FEATURE_CLOCK_IP_HAS_RTC_CLKIN         23U
#define FEATURE_CLOCK_IP_HAS_SCS_CLK         24U
#define FEATURE_CLOCK_IP_HAS_SCS_RUN_CLK         25U
#define FEATURE_CLOCK_IP_HAS_SCS_VLPR_CLK         26U
#define FEATURE_CLOCK_IP_HAS_SCS_HSRUN_CLK         27U
#define FEATURE_CLOCK_IP_HAS_CORE_CLK         28U
#define FEATURE_CLOCK_IP_HAS_CORE_RUN_CLK         29U
#define FEATURE_CLOCK_IP_HAS_CORE_VLPR_CLK         30U
#define FEATURE_CLOCK_IP_HAS_CORE_HSRUN_CLK         31U
#define FEATURE_CLOCK_IP_HAS_BUS_CLK         32U
#define FEATURE_CLOCK_IP_HAS_BUS_RUN_CLK         33U
#define FEATURE_CLOCK_IP_HAS_BUS_VLPR_CLK         34U
#define FEATURE_CLOCK_IP_HAS_BUS_HSRUN_CLK         35U
#define FEATURE_CLOCK_IP_HAS_SLOW_CLK         36U
#define FEATURE_CLOCK_IP_HAS_SLOW_RUN_CLK         37U
#define FEATURE_CLOCK_IP_HAS_SLOW_VLPR_CLK         38U
#define FEATURE_CLOCK_IP_HAS_SLOW_HSRUN_CLK         39U
#define FEATURE_CLOCK_IP_HAS_RTC_CLK         40U
#define FEATURE_CLOCK_IP_HAS_LPO_CLK         41U
#define FEATURE_CLOCK_IP_HAS_SCG_CLKOUT_CLK         42U
#define FEATURE_CLOCK_IP_HAS_FTM0_EXT_CLK         43U
#define FEATURE_CLOCK_IP_HAS_FTM1_EXT_CLK         44U
#define FEATURE_CLOCK_IP_HAS_FTM2_EXT_CLK         45U
#define FEATURE_CLOCK_IP_HAS_FTM3_EXT_CLK         46U
#define FEATURE_CLOCK_IP_HAS_FTM4_EXT_CLK         47U
#define FEATURE_CLOCK_IP_HAS_FTM5_EXT_CLK         48U
#define FEATURE_CLOCK_PRODUCERS_NO         49U
#define FEATURE_CLOCK_IP_HAS_ADC0_CLK         50U
#define FEATURE_CLOCK_IP_HAS_ADC1_CLK         51U
#define FEATURE_CLOCK_IP_HAS_CLKOUT0_CLK         52U
#define FEATURE_CLOCK_IP_HAS_CMP0_CLK         53U
#define FEATURE_CLOCK_IP_HAS_CRC0_CLK         54U
#define FEATURE_CLOCK_IP_HAS_DMA0_CLK         55U
#define FEATURE_CLOCK_IP_HAS_DMAMUX0_CLK         56U
#define FEATURE_CLOCK_IP_HAS_EIM0_CLK         57U
#define FEATURE_CLOCK_IP_HAS_ERM0_CLK         58U
#define FEATURE_CLOCK_IP_HAS_EWM0_CLK         59U
#define FEATURE_CLOCK_IP_HAS_FLEXCAN0_CLK         60U
#define FEATURE_CLOCK_IP_HAS_FLEXCAN1_CLK         61U
#define FEATURE_CLOCK_IP_HAS_FLEXCAN2_CLK         62U
#define FEATURE_CLOCK_IP_HAS_FlexIO_CLK         63U
#define FEATURE_CLOCK_IP_HAS_FTFC_CLK         64U
#define FEATURE_CLOCK_IP_HAS_FTM0_CLK         65U
#define FEATURE_CLOCK_IP_HAS_FTM1_CLK         66U
#define FEATURE_CLOCK_IP_HAS_FTM2_CLK         67U
#define FEATURE_CLOCK_IP_HAS_FTM3_CLK         68U
#define FEATURE_CLOCK_IP_HAS_FTM4_CLK         69U
#define FEATURE_CLOCK_IP_HAS_FTM5_CLK         70U
#define FEATURE_CLOCK_IP_HAS_LPI2C0_CLK         71U
#define FEATURE_CLOCK_IP_HAS_LPIT0_CLK         72U
#define FEATURE_CLOCK_IP_HAS_LPSPI0_CLK         73U
#define FEATURE_CLOCK_IP_HAS_LPSPI1_CLK         74U
#define FEATURE_CLOCK_IP_HAS_LPSPI2_CLK         75U
#define FEATURE_CLOCK_IP_HAS_LPTMR0_CLK         76U
#define FEATURE_CLOCK_IP_HAS_LPUART0_CLK         77U
#define FEATURE_CLOCK_IP_HAS_LPUART1_CLK         78U
#define FEATURE_CLOCK_IP_HAS_LPUART2_CLK         79U
#define FEATURE_CLOCK_IP_HAS_MPU0_CLK         80U
#define FEATURE_CLOCK_IP_HAS_MSCM0_CLK         81U
#define FEATURE_CLOCK_IP_HAS_PDB0_CLK         82U
#define FEATURE_CLOCK_IP_HAS_PDB1_CLK         83U
#define FEATURE_CLOCK_IP_HAS_PORTA_CLK         84U
#define FEATURE_CLOCK_IP_HAS_PORTB_CLK         85U
#define FEATURE_CLOCK_IP_HAS_PORTC_CLK         86U
#define FEATURE_CLOCK_IP_HAS_PORTD_CLK         87U
#define FEATURE_CLOCK_IP_HAS_PORTE_CLK         88U
#define FEATURE_CLOCK_IP_HAS_RTC0_CLK         89U
#define FEATURE_CLOCK_IP_HAS_TRACE_CLK         90U
#define FEATURE_CLOCKS_NO         91U

/*==================================================================================================
                                             ENUMS
==================================================================================================*/


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



#ifdef __cplusplus
}
#endif

#endif /* #ifndef CLOCK_IP_CFG_DEFINES_H */

/** @} */