123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262 |
- /*==================================================================================================
- * Project : RTD AUTOSAR 4.4
- * Platform : CORTEXM
- * Peripheral : ADC
- * 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_D2108_ASR_REL_4_4_REV_0000_20210810
- *
- * (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 ADC_IP_HW_ACCESS_H
- #define ADC_IP_HW_ACCESS_H
- /**
- * @file
- *
- * @internal
- * @addtogroup adc_ip Adc IPL
- * @{
- */
- #include "StandardTypes.h"
- /*******************************************************************************
- * Source file version information
- ******************************************************************************/
- #define ADC_IP_VENDOR_ID_HWACCESS_H 43
- #define ADC_IP_AR_RELEASE_MAJOR_VERSION_HWACCESS_H 4
- #define ADC_IP_AR_RELEASE_MINOR_VERSION_HWACCESS_H 4
- #define ADC_IP_AR_RELEASE_REVISION_VERSION_HWACCESS_H 0
- #define ADC_IP_SW_MAJOR_VERSION_HWACCESS_H 1
- #define ADC_IP_SW_MINOR_VERSION_HWACCESS_H 0
- #define ADC_IP_SW_PATCH_VERSION_HWACCESS_H 0
- /*******************************************************************************
- * File version checks
- ******************************************************************************/
- #ifndef DISABLE_MCAL_INTERMODULE_ASR_CHECK
- /* Check if Adc_Ip_HwAccess.h file and StandardTypes.h file are of the same Autosar version */
- #if ((ADC_IP_AR_RELEASE_MAJOR_VERSION_HWACCESS_H != STD_AR_RELEASE_MAJOR_VERSION) || \
- (ADC_IP_AR_RELEASE_MINOR_VERSION_HWACCESS_H != STD_AR_RELEASE_MINOR_VERSION) \
- )
- #error "AutoSar Version Numbers of Adc_Ip_HwAccess.h and StandardTypes.h are different"
- #endif
- #endif /* DISABLE_MCAL_INTERMODULE_ASR_CHECK */
- #if defined (__cplusplus)
- extern "C" {
- #endif
- /*******************************************************************************
- * Code
- ******************************************************************************/
- #define ADC_START_SEC_CODE
- #include "Adc_MemMap.h"
- static inline void Adc_HwAcc_SetSC2Reg(ADC_Type * const Base, const uint32 ClearMask, const uint32 Value)
- {
- /* Clear and set SC2 register based on ClearMask and Value */
- uint32 Sc2Reg = Base->SC2;
- Sc2Reg &= ~(ClearMask);
- Sc2Reg |= Value;
- Base->SC2 = Sc2Reg;
- }
- static inline void Adc_HwAcc_SetClock(ADC_Type * const Base, const Adc_Ip_ClockSelType ClockDivide, const Adc_Ip_ClkSourceType InputClock)
- {
- /* Update ClockDivide and InputClock values found in CFG1 register */
- uint32 Cfg1Reg = Base->CFG1;
- Cfg1Reg &= ~(ADC_CFG1_ADIV_MASK | ADC_CFG1_ADICLK_MASK);
- Cfg1Reg |= ADC_CFG1_ADIV(ClockDivide);
- Cfg1Reg |= ADC_CFG1_ADICLK(InputClock);
- Base->CFG1 = Cfg1Reg;
- }
- static inline Adc_Ip_ClockSelType Adc_HwAcc_GetClockDivide(const uint32 Reg)
- {
- /*
- * Retrieve ClockDivide value found in CFG1 register
- * Note: Reg should be the value of CFG1 register
- */
- Adc_Ip_ClockSelType ReturnValue = ADC_IP_CLK_FULL_BUS;
- switch ((Reg & ADC_CFG1_ADIV_MASK) >> ADC_CFG1_ADIV_SHIFT)
- {
- case 1u:
- ReturnValue = ADC_IP_CLK_HALF_BUS;
- break;
- case 2u:
- ReturnValue = ADC_IP_CLK_QUARTER_BUS;
- break;
- case 3u:
- ReturnValue = ADC_IP_CLK_EIGHTH_BUS;
- break;
- default:
- ; /* no-op */
- break;
- }
- return ReturnValue;
- }
- static inline Adc_Ip_ClkSourceType Adc_HwAcc_GetInputClock(const uint32 Reg)
- {
- /*
- * Retrieve InputClock value found in CFG1 register
- * Note: Reg should be the value of CFG1 register
- */
- Adc_Ip_ClkSourceType ReturnValue = ADC_IP_CLK_ALT_1;
- switch ((Reg & ADC_CFG1_ADICLK_MASK) >> ADC_CFG1_ADICLK_SHIFT)
- {
- case 1u:
- ReturnValue = ADC_IP_CLK_ALT_2;
- break;
- case 2u:
- ReturnValue = ADC_IP_CLK_ALT_3;
- break;
- case 3u:
- ReturnValue = ADC_IP_CLK_ALT_4;
- break;
- default:
- ; /* no-op */
- break;
- }
- return ReturnValue;
- }
- static inline void Adc_HwAcc_SetSampleTime(ADC_Type * const Base, const uint8 SampleTime)
- {
- /* Clip sample time to minimum value */
- uint8 ClippedSampleTime = (uint8)((SampleTime > 0U) ? SampleTime : 1U);
- /* Update SampleTime values found in SC3 register */
- uint32 Cfg2Reg = Base->CFG2;
- Cfg2Reg &= ~(ADC_CFG2_SMPLTS_MASK);
- Cfg2Reg |= ADC_CFG2_SMPLTS(ClippedSampleTime);
- Base->CFG2 = Cfg2Reg;
- }
- static inline void Adc_HwAcc_SetAveraging(ADC_Type * const Base, const boolean AvgEn, const Adc_Ip_AvgSelectType AvgSel)
- {
- /* Update AvgEn and AvgSel values found in SC3 register */
- uint32 Sc3Reg = Base->SC3;
- Sc3Reg &= ~(ADC_SC3_AVGE_MASK | ADC_SC3_AVGS_MASK);
- Sc3Reg |= ADC_SC3_AVGE(AvgEn ? 1u : 0u);
- Sc3Reg |= ADC_SC3_AVGS(AvgSel);
- Base->SC3 = Sc3Reg;
- }
- static inline Adc_Ip_AvgSelectType Adc_HwAcc_GetAverageSelect(const uint32 Reg)
- {
- /*
- * Retrieve AvgSelect value found in SC3 register
- * Note: Reg should be the value of SC3 register
- */
- Adc_Ip_AvgSelectType ReturnValue = ADC_IP_AVG_4_CONV;
- switch ((Reg & ADC_SC3_AVGS_MASK) >> ADC_SC3_AVGS_SHIFT)
- {
- case 1u:
- ReturnValue = ADC_IP_AVG_8_CONV;
- break;
- case 2u:
- ReturnValue = ADC_IP_AVG_16_CONV;
- break;
- case 3u:
- ReturnValue = ADC_IP_AVG_32_CONV;
- break;
- default:
- ; /* no-op */
- break;
- }
- return ReturnValue;
- }
- static inline void Adc_HwAcc_SetTriggerMode(ADC_Type * const Base, const Adc_Ip_TrigType TriggerMode)
- {
- /* Update TriggerMode value found in SC2 register */
- uint32 Sc2Reg = Base->SC2;
- Sc2Reg &= ~(ADC_SC2_ADTRG_MASK);
- Sc2Reg |= ADC_SC2_ADTRG(TriggerMode);
- Base->SC2 = Sc2Reg;
- }
- static inline Adc_Ip_TrigType Adc_HwAcc_GetTriggerMode(const uint32 Reg)
- {
- /* Retrieve TriggerMode value found in SC2 register */
- Adc_Ip_TrigType ReturnValue = ADC_IP_TRIGGER_SOFTWARE;
- if (((Reg & ADC_SC2_ADTRG_MASK) >> ADC_SC2_ADTRG_SHIFT) == 1u)
- {
- ReturnValue = ADC_IP_TRIGGER_HARDWARE;
- }
- return ReturnValue;
- }
- static inline void Adc_HwAcc_SetChannel(ADC_Type * const Base, const uint8 ChnIdx, const Adc_Ip_InputChannelType InputChannel, const boolean InterruptEnable)
- {
- /* Configure channel by writing all SC1n register fields */
- uint32 Sc1Reg = SC1(Base, ChnIdx);
- Sc1Reg &= ~(ADC_SC1_ADCH_MASK | ADC_SC1_AIEN_MASK);
- Sc1Reg |= ADC_SC1_ADCH(InputChannel);
- Sc1Reg |= ADC_SC1_AIEN(InterruptEnable ? 1u : 0u);
- SC1(Base, ChnIdx) = Sc1Reg;
- }
- static inline void Adc_HwAcc_SetUserGainAndOffset(ADC_Type * const Base, const uint16 UsrGain, const uint16 UsrOffset)
- {
- /*
- * Currently, user gain and user offset values are set at config time.
- * If user gain is to be changed at runtime (e.g. after a calibration was
- * already executed) then the G register should also be updated.
- * To calculate the new value of this register, it is necessary execute
- * the following algorithm:
- * 1. Sum <- UsrGain + Clp0 + Clp1 + Clp2 + Clp3 + ClpS
- * 2. RegVal <- Sum & 0xF800U
- * 3. if RegVal != 0x0000U then RegVal <- 0xFFFFU
- * 4. Base->G <- RegVal
- */
- Base->USR_OFS = ADC_USR_OFS_USR_OFS(UsrOffset);
- Base->UG = ADC_UG_UG(UsrGain);
- }
- static inline boolean Adc_HwAcc_GetAIEN(const uint32 Reg)
- {
- /* Retrive AIEN flag from given SC1 register */
- return (((Reg & ADC_SC1_AIEN_MASK) >> ADC_SC1_AIEN_SHIFT) != 0u) ? TRUE : FALSE;
- }
- static inline boolean Adc_HwAcc_GetCOCO(const uint32 Reg)
- {
- /* Retrive COCO flag from given SC1 register */
- return (((Reg & ADC_SC1_COCO_MASK) >> ADC_SC1_COCO_SHIFT) != 0u) ? TRUE : FALSE;
- }
- static inline uint16 Adc_HwAcc_GetData(const ADC_Type * const Base, const uint8 ChnIdx)
- {
- /* Retrieve the conversion result of a given channel */
- uint16 Result = (uint16) R(Base, ChnIdx);
- Result = (uint16) ((Result & ADC_R_D_MASK) >> ADC_R_D_SHIFT);
- return Result;
- }
- #define ADC_STOP_SEC_CODE
- #include "Adc_MemMap.h"
- #if defined (__cplusplus)
- }
- #endif
- /** @} */
- #endif /* ADC_IP_HW_ACCESS_H */
|