/******************************************************************************* * Copyright (C) 2020, Huada Semiconductor Co., Ltd. All rights reserved. * * This software component is licensed by HDSC under BSD 3-Clause license * (the "License"); You may not use this file except in compliance with the * License. You may obtain a copy of the License at: * opensource.org/licenses/BSD-3-Clause */ /******************************************************************************/ /** \file hc32f460_timera.c ** ** A detailed description is available at ** @link TimeraGroup Timer A description @endlink ** ** - 2018-11-08 CDT First version for Device Driver Library of ** Timera. ** ******************************************************************************/ /******************************************************************************* * Include files ******************************************************************************/ #include "hc32f460_timera.h" #include "hc32f460_utility.h" #if (DDL_TIMERA_ENABLE == DDL_ON) /** ******************************************************************************* ** \addtogroup TimeraGroup ******************************************************************************/ //@{ /******************************************************************************* * Local type definitions ('typedef') ******************************************************************************/ /******************************************************************************* * Local pre-processor symbols/macros ('#define') ******************************************************************************/ /*!< Parameter valid check for normal timera unit */ #define IS_VALID_NORMAL_TIMERA_UNIT(x) \ ( (M4_TMRA1 == (x)) || \ (M4_TMRA2 == (x)) || \ (M4_TMRA3 == (x)) || \ (M4_TMRA4 == (x)) || \ (M4_TMRA5 == (x)) || \ (M4_TMRA6 == (x))) /*!< Parameter valid check for sync startup timera unit */ #define IS_VALID_SYNC_STARTUP_TIMERA_UNIT(x) \ ( (M4_TMRA2 == (x)) || \ (M4_TMRA3 == (x)) || \ (M4_TMRA4 == (x)) || \ (M4_TMRA5 == (x)) || \ (M4_TMRA6 == (x))) /*!< Parameter valid check for Count clock division */ #define IS_VALID_COUNT_CLK_DIV(x) \ ( (TimeraPclkDiv1 == (x)) || \ (TimeraPclkDiv2 == (x)) || \ (TimeraPclkDiv4 == (x)) || \ (TimeraPclkDiv8 == (x)) || \ (TimeraPclkDiv16 == (x)) || \ (TimeraPclkDiv32 == (x)) || \ (TimeraPclkDiv64 == (x)) || \ (TimeraPclkDiv128 == (x)) || \ (TimeraPclkDiv256 == (x)) || \ (TimeraPclkDiv512 == (x)) || \ (TimeraPclkDiv1024 == (x))) /*!< Parameter valid check for count mode */ #define IS_VALID_COUNT_MODE(x) \ ( (TimeraCountModeSawtoothWave == (x)) || \ (TimeraCountModeTriangularWave == (x))) /*!< Parameter valid check for count direction */ #define IS_VALID_COUNT_DIR(x) \ ( (TimeraCountDirUp == (x)) || \ (TimeraCountDirDown == (x))) /*!< Parameter valid check for normal timera channel */ #define IS_VALID_NORMAL_TIMERA_CHANNEL(x) \ ( (TimeraCh1 == (x)) || \ (TimeraCh2 == (x)) || \ (TimeraCh3 == (x)) || \ (TimeraCh4 == (x)) || \ (TimeraCh5 == (x)) || \ (TimeraCh6 == (x)) || \ (TimeraCh7 == (x)) || \ (TimeraCh8 == (x))) /*!< Parameter valid check for set cache channel */ #define IS_VALID_SET_CACHE_CHANNEL(x) \ ( (TimeraCh1 == (x)) || \ (TimeraCh3 == (x)) || \ (TimeraCh5 == (x)) || \ (TimeraCh7 == (x))) /*!< Parameter valid check for enable cache channel */ #define IS_VALID_ENABLE_CACHE_CHANNEL(x) \ ( (TimeraCh1 == (x)) || \ (TimeraCh3 == (x)) || \ (TimeraCh5 == (x)) || \ (TimeraCh7 == (x))) /*!< Parameter valid check for timera count start output status */ #define IS_VALID_COUNT_START_OUTPUT(x) \ ( (TimeraCountStartOutputLow == (x)) || \ (TimeraCountStartOutputHigh == (x)) || \ (TimeraCountStartOutputKeep == (x))) /*!< Parameter valid check for timera count stop output status */ #define IS_VALID_COUNT_STOP_OUTPUT(x) \ ( (TimeraCountStopOutputLow == (x)) || \ (TimeraCountStopOutputHigh == (x)) || \ (TimeraCountStopOutputKeep == (x))) /*!< Parameter valid check for compare match output status */ #define IS_VALID_COMPARE_MATCH_OUTPUT(x) \ ( (TimeraCompareMatchOutputLow == (x)) || \ (TimeraCompareMatchOutputHigh == (x)) || \ (TimeraCompareMatchOutputKeep == (x)) || \ (TimeraCompareMatchOutputReverse == (x))) /*!< Parameter valid check for period match output status */ #define IS_VALID_PERIOD_MATCH_OUTPUT(x) \ ( (TimeraPeriodMatchOutputLow == (x)) || \ (TimeraPeriodMatchOutputHigh == (x)) || \ (TimeraPeriodMatchOutputKeep == (x)) || \ (TimeraPeriodMatchOutputReverse == (x))) /*!< Parameter valid check for specify output status */ #define IS_VALID_SPECIFY_OUTPUT_STATUS(x) \ ( (TimeraSpecifyOutputInvalid == (x)) || \ (TimeraSpecifyOutputLow == (x)) || \ (TimeraSpecifyOutputHigh == (x))) /*!< Parameter valid check for port filter clock */ #define IS_VALID_PORT_FILTER_CLOCK(x) \ ( (TimeraFilterPclkDiv1 == (x)) || \ (TimeraFilterPclkDiv4 == (x)) || \ (TimeraFilterPclkDiv16 == (x)) || \ (TimeraFilterPclkDiv64 == (x))) /*!< Parameter valid check for capture filter port source */ #define IS_VALID_CAPTURE_FILTER_PORT_SOURCE(x) \ ( (TimeraFilterSourceCh1 == (x)) || \ (TimeraFilterSourceCh2 == (x)) || \ (TimeraFilterSourceCh3 == (x)) || \ (TimeraFilterSourceCh4 == (x)) || \ (TimeraFilterSourceCh5 == (x)) || \ (TimeraFilterSourceCh6 == (x)) || \ (TimeraFilterSourceCh7 == (x)) || \ (TimeraFilterSourceCh8 == (x)) || \ (TimeraFilterSourceTrig == (x))) /*!< Parameter valid check for coding filter port source */ #define IS_VALID_CODING_FILTER_PORT_SOURCE(x) \ ( (TimeraFilterSourceClkA == (x)) || \ (TimeraFilterSourceClkB == (x)) || \ (TimeraFilterSourceTrig == (x))) /*!< Parameter valid check for interrupt request source */ #define IS_VALID_IRQ_SOURCE(x) \ ( (TimeraIrqCaptureOrCompareCh1 == (x)) || \ (TimeraIrqCaptureOrCompareCh2 == (x)) || \ (TimeraIrqCaptureOrCompareCh3 == (x)) || \ (TimeraIrqCaptureOrCompareCh4 == (x)) || \ (TimeraIrqCaptureOrCompareCh5 == (x)) || \ (TimeraIrqCaptureOrCompareCh6 == (x)) || \ (TimeraIrqCaptureOrCompareCh7 == (x)) || \ (TimeraIrqCaptureOrCompareCh8 == (x)) || \ (TimeraIrqOverflow == (x)) || \ (TimeraIrqUnderflow == (x))) /*!< Parameter valid check for flag type */ #define IS_VALID_FLAG_TYPE(x) \ ( (TimeraFlagCaptureOrCompareCh1 == (x)) || \ (TimeraFlagCaptureOrCompareCh2 == (x)) || \ (TimeraFlagCaptureOrCompareCh3 == (x)) || \ (TimeraFlagCaptureOrCompareCh4 == (x)) || \ (TimeraFlagCaptureOrCompareCh5 == (x)) || \ (TimeraFlagCaptureOrCompareCh6 == (x)) || \ (TimeraFlagCaptureOrCompareCh7 == (x)) || \ (TimeraFlagCaptureOrCompareCh8 == (x)) || \ (TimeraFlagOverflow == (x)) || \ (TimeraFlagUnderflow == (x))) /*! Parameter valid check for common trigger. */ #define IS_VALID_COM_TRIGGER(x) \ ( (TimeraComTrigger_1 == (x)) || \ (TimeraComTrigger_2 == (x)) || \ (TimeraComTrigger_1_2 == (x))) /*!< Parameter valid check for event source */ #define IS_VALID_EVENT_SOURCE(x) ((x) <= 511u) /*!< Timera registers reset value */ #define TIMERA_REG_CNTER_RESET_VALUE (0x0000u) #define TIMERA_REG_PERAR_RESET_VALUE (0xFFFFu) #define TIMERA_REG_CMPAR_RESET_VALUE (0xFFFFu) #define TIMERA_REG_BCSTR_RESET_VALUE (0x0002u) #define TIMERA_REG_ICONR_RESET_VALUE (0x0000u) #define TIMERA_REG_ECONR_RESET_VALUE (0x0000u) #define TIMERA_REG_FCONR_RESET_VALUE (0x0000u) #define TIMERA_REG_STFLR_RESET_VALUE (0x0000u) #define TIMERA_REG_BCONR_RESET_VALUE (0x0000u) #define TIMERA_REG_CCONR_RESET_VALUE (0x0000u) #define TIMERA_REG_PCONR_RESET_VALUE (0x0000u) #define TIMERA_REG_HCONR_RESET_VALUE (0x0000u) #define TIMERA_REG_HCUPR_RESET_VALUE (0x0000u) #define TIMERA_REG_HCDOR_RESET_VALUE (0x0000u) #define TIMERA_REG_HTSSR0_RESET_VALUE (0x000001FFul) #define TIMERA_REG_HTSSR1_RESET_VALUE (0x000001FFul) /*!< Timera calculate register address of channel */ #define TIMERA_CALC_REG_ADDR(reg, chl) ((uint32_t)(&(reg)) + (chl)*0x4u) /******************************************************************************* * Global variable definitions (declared in header file with 'extern') ******************************************************************************/ /******************************************************************************* * Local function prototypes ('static') ******************************************************************************/ /******************************************************************************* * Local variable definitions ('static') ******************************************************************************/ /******************************************************************************* * Function implementation - global ('extern') and local ('static') ******************************************************************************/ /** ******************************************************************************* ** \brief De-Initialize Timera unit ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_DeInit(M4_TMRA_TypeDef *TIMERAx) { en_result_t enRet = ErrorInvalidParameter; uint32_t u32Cnt = 0u; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { TIMERAx->CNTER = TIMERA_REG_CNTER_RESET_VALUE; TIMERAx->PERAR = TIMERA_REG_PERAR_RESET_VALUE; TIMERAx->BCSTR = TIMERA_REG_BCSTR_RESET_VALUE; TIMERAx->ICONR = TIMERA_REG_ICONR_RESET_VALUE; TIMERAx->ECONR = TIMERA_REG_ECONR_RESET_VALUE; TIMERAx->FCONR = TIMERA_REG_FCONR_RESET_VALUE; TIMERAx->STFLR = TIMERA_REG_STFLR_RESET_VALUE; TIMERAx->HCONR = TIMERA_REG_HCONR_RESET_VALUE; TIMERAx->HCUPR = TIMERA_REG_HCUPR_RESET_VALUE; TIMERAx->HCDOR = TIMERA_REG_HCDOR_RESET_VALUE; for (u32Cnt = 0u; u32Cnt < 8u; u32Cnt++) { *(__IO uint16_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CMPAR1, u32Cnt) = TIMERA_REG_CMPAR_RESET_VALUE; } for (u32Cnt = 0u; u32Cnt < 4u; u32Cnt++) { *(__IO uint16_t *)TIMERA_CALC_REG_ADDR(TIMERAx->BCONR1, u32Cnt * 2u) = TIMERA_REG_BCONR_RESET_VALUE; } for (u32Cnt = 0u; u32Cnt < 8u; u32Cnt++) { *(__IO uint16_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CCONR1, u32Cnt) = TIMERA_REG_CCONR_RESET_VALUE; } for (u32Cnt = 0u; u32Cnt < 8u; u32Cnt++) { *(__IO uint16_t *)TIMERA_CALC_REG_ADDR(TIMERAx->PCONR1, u32Cnt) = TIMERA_REG_PCONR_RESET_VALUE; } M4_AOS->TMRA_HTSSR0 = TIMERA_REG_HTSSR0_RESET_VALUE; M4_AOS->TMRA_HTSSR1 = TIMERA_REG_HTSSR1_RESET_VALUE; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Initialize Timera unit base function ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] pstcBaseInit Pointer to timera base init configuration ** \arg See the struct #stc_timera_base_init_t ** ** \retval Ok Process successfully done ** \retval ErrorInvalidMode Unit 1 sync startup invalid ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** - pstcBaseInit == NULL ** ******************************************************************************/ en_result_t TIMERA_BaseInit(M4_TMRA_TypeDef *TIMERAx, const stc_timera_base_init_t *pstcBaseInit) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx) && (NULL != pstcBaseInit)) { DDL_ASSERT(IS_VALID_COUNT_CLK_DIV(pstcBaseInit->enClkDiv)); DDL_ASSERT(IS_VALID_COUNT_MODE(pstcBaseInit->enCntMode)); DDL_ASSERT(IS_VALID_COUNT_DIR(pstcBaseInit->enCntDir)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcBaseInit->enSyncStartupEn)); /* Configure control status register */ TIMERAx->BCSTR_f.CKDIV = pstcBaseInit->enClkDiv; TIMERAx->BCSTR_f.MODE = pstcBaseInit->enCntMode; TIMERAx->BCSTR_f.DIR = pstcBaseInit->enCntDir; /* Unit 1 sync startup invalid */ if ((M4_TMRA1 == TIMERAx) && (Enable == pstcBaseInit->enSyncStartupEn)) { enRet = ErrorInvalidMode; } else { TIMERAx->BCSTR_f.SYNST = pstcBaseInit->enSyncStartupEn; enRet = Ok; } /* Configure period value register */ TIMERAx->PERAR = pstcBaseInit->u16PeriodVal; } return enRet; } /** ******************************************************************************* ** \brief Set Timera current count value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] u16Cnt Timera current count value ** \arg 0-0xFFFF ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_SetCurrCount(M4_TMRA_TypeDef *TIMERAx, uint16_t u16Cnt) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { TIMERAx->CNTER = u16Cnt; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Get Timera current count value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \retval uint16_t Timera current count value ** ******************************************************************************/ uint16_t TIMERA_GetCurrCount(M4_TMRA_TypeDef *TIMERAx) { uint16_t u16CurrCntVal = 0u; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { u16CurrCntVal = (uint16_t)TIMERAx->CNTER; } return u16CurrCntVal; } /** ******************************************************************************* ** \brief Set Timera period value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] u16Period Timera period value ** \arg 0-0xFFFF ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_SetPeriodValue(M4_TMRA_TypeDef *TIMERAx, uint16_t u16Period) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { TIMERAx->PERAR = u16Period; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Get Timera period count value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \retval uint16_t Timera current period value ** ******************************************************************************/ uint16_t TIMERA_GetPeriodValue(M4_TMRA_TypeDef *TIMERAx) { uint16_t u16PeriodVal = 0u; /* Check parameters */ if (IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { u16PeriodVal = (uint16_t)TIMERAx->PERAR; } return u16PeriodVal; } /** ******************************************************************************* ** \brief Enable or disable Timera software synchronous startup ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enNewSta The function new state ** \arg Disable Disable synchronous startup ** \arg Enable Enable synchronous startup ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_SyncStartupCmd(M4_TMRA_TypeDef *TIMERAx, en_functional_state_t enNewSta) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_SYNC_STARTUP_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewSta)); TIMERAx->BCSTR_f.SYNST = enNewSta; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Enable or disable Timera startup ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enNewSta The function new state ** \arg Disable Disable timera startup ** \arg Enable Enable timera startup ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_Cmd(M4_TMRA_TypeDef *TIMERAx, en_functional_state_t enNewSta) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewSta)); TIMERAx->BCSTR_f.START = enNewSta; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Initialize Timera unit compare function ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera compare channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh2 Timera channel 2 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh4 Timera channel 4 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh6 Timera channel 6 ** \arg TimeraCh7 Timera channel 7 ** \arg TimeraCh8 Timera channel 8 ** ** \param [in] pstcCompareInit Pointer to timera compare init configuration ** \arg See the struct #stc_timera_compare_init_t ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** - pstcCompareInit == NULL ** ******************************************************************************/ en_result_t TIMERA_CompareInit(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel, const stc_timera_compare_init_t *pstcCompareInit) { en_result_t enRet = ErrorInvalidParameter; __IO stc_tmra_pconr_field_t *pstcTimeraPort; __IO stc_tmra_bconr_field_t *pstcTimeraCache; __IO stc_tmra_cmpar_field_t *pstcTimeraCompare; __IO stc_tmra_cconr_field_t *pstcTimeraCapture; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx) && (NULL != pstcCompareInit)) { DDL_ASSERT(IS_VALID_NORMAL_TIMERA_CHANNEL(enChannel)); DDL_ASSERT(IS_VALID_COUNT_START_OUTPUT(pstcCompareInit->enStartCountOutput)); DDL_ASSERT(IS_VALID_COUNT_STOP_OUTPUT(pstcCompareInit->enStopCountOutput)); DDL_ASSERT(IS_VALID_COMPARE_MATCH_OUTPUT(pstcCompareInit->enCompareMatchOutput)); DDL_ASSERT(IS_VALID_PERIOD_MATCH_OUTPUT(pstcCompareInit->enPeriodMatchOutput)); DDL_ASSERT(IS_VALID_SPECIFY_OUTPUT_STATUS(pstcCompareInit->enSpecifyOutput)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCompareInit->enCacheEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCompareInit->enTriangularCrestTransEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCompareInit->enTriangularTroughTransEn)); /* Configure port control register */ pstcTimeraPort = (stc_tmra_pconr_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->PCONR1, enChannel); pstcTimeraPort->STAC = pstcCompareInit->enStartCountOutput; pstcTimeraPort->STPC = pstcCompareInit->enStopCountOutput; pstcTimeraPort->CMPC = pstcCompareInit->enCompareMatchOutput; pstcTimeraPort->PERC = pstcCompareInit->enPeriodMatchOutput; pstcTimeraPort->FORC = pstcCompareInit->enSpecifyOutput; /* Configure cache control register */ if ((TimeraCh1 == enChannel) || (TimeraCh3 == enChannel) || (TimeraCh5 == enChannel) || (TimeraCh7 == enChannel)) { pstcTimeraCache = (stc_tmra_bconr_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->BCONR1, enChannel); pstcTimeraCache->BSE0 = pstcCompareInit->enTriangularCrestTransEn; pstcTimeraCache->BSE1 = pstcCompareInit->enTriangularTroughTransEn; pstcTimeraCache->BEN = pstcCompareInit->enCacheEn; /* Configure compare cache value register */ pstcTimeraCompare = (stc_tmra_cmpar_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CMPAR1, enChannel + 1); pstcTimeraCompare->CMP = pstcCompareInit->u16CompareCacheVal; } /* Configure compare value register */ pstcTimeraCompare = (stc_tmra_cmpar_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CMPAR1, enChannel); pstcTimeraCompare->CMP = pstcCompareInit->u16CompareVal; /* Set compare output function */ pstcTimeraCapture = (stc_tmra_cconr_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CCONR1, enChannel); pstcTimeraCapture->CAPMD = 0u; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Set Timera compare value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera compare channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh2 Timera channel 2 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh4 Timera channel 4 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh6 Timera channel 6 ** \arg TimeraCh7 Timera channel 7 ** \arg TimeraCh8 Timera channel 8 ** ** \param [in] u16CompareVal Timera campare value ** \arg 0-0xFFFF ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_SetCompareValue(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel, uint16_t u16CompareVal) { en_result_t enRet = ErrorInvalidParameter; __IO stc_tmra_cmpar_field_t *pstcTimeraCompare; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_NORMAL_TIMERA_CHANNEL(enChannel)); pstcTimeraCompare = (stc_tmra_cmpar_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CMPAR1, enChannel); pstcTimeraCompare->CMP = u16CompareVal; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Get Timera compare value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera compare channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh2 Timera channel 2 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh4 Timera channel 4 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh6 Timera channel 6 ** \arg TimeraCh7 Timera channel 7 ** \arg TimeraCh8 Timera channel 8 ** ** \retval uint16_t Timera compare value ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ uint16_t TIMERA_GetCompareValue(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel) { uint16_t u16CompareVal = 0u; __IO stc_tmra_cmpar_field_t *pstcTimeraCompare; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_NORMAL_TIMERA_CHANNEL(enChannel)); pstcTimeraCompare = (stc_tmra_cmpar_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CMPAR1, enChannel); u16CompareVal = (uint16_t)pstcTimeraCompare->CMP; } return u16CompareVal; } /** ******************************************************************************* ** \brief Set Timera compare cache value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera compare channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh7 Timera channel 7 ** ** \param [in] u16CompareCache Timera compare cache value ** \arg 0-0xFFFF ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_SetCacheValue(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel, uint16_t u16CompareCache) { en_result_t enRet = ErrorInvalidParameter; __IO stc_tmra_cmpar_field_t *pstcTimeraCompare; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_SET_CACHE_CHANNEL(enChannel)); pstcTimeraCompare = (stc_tmra_cmpar_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CMPAR1, enChannel + 1); pstcTimeraCompare->CMP = u16CompareCache; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Enable or disable Timera compare cache ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera compare channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh7 Timera channel 7 ** ** \param [in] enNewSta The function new state ** \arg Disable Disable timera compare cache ** \arg Enable Enable timera compare cache ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_CompareCacheCmd(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel, en_functional_state_t enNewSta) { en_result_t enRet = ErrorInvalidParameter; __IO stc_tmra_bconr_field_t *pstcTimeraCache; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_ENABLE_CACHE_CHANNEL(enChannel)); DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewSta)); /* Configure cache control register */ pstcTimeraCache = (stc_tmra_bconr_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->BCONR1, enChannel); pstcTimeraCache->BEN = enNewSta; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Specify Timera port output status ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera compare channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh2 Timera channel 2 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh4 Timera channel 4 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh6 Timera channel 6 ** \arg TimeraCh7 Timera channel 7 ** \arg TimeraCh8 Timera channel 8 ** ** \param [in] enOutputSta Timera port output status ** \arg TimeraSpecifyOutputInvalid Port output invalid ** \arg TimeraSpecifyOutputLow Port output low level from next period ** \arg TimeraSpecifyOutputHigh Port output high level from next period ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_SpecifyOutputSta(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel, en_timera_specify_output_t enOutputSta) { en_result_t enRet = ErrorInvalidParameter; __IO stc_tmra_pconr_field_t *pstcTimeraPort; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_NORMAL_TIMERA_CHANNEL(enChannel)); DDL_ASSERT(IS_VALID_SPECIFY_OUTPUT_STATUS(enOutputSta)); pstcTimeraPort = (stc_tmra_pconr_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->PCONR1, enChannel); pstcTimeraPort->FORC = enOutputSta; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Enable or disable Timera compare function ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera compare channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh2 Timera channel 2 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh4 Timera channel 4 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh6 Timera channel 6 ** \arg TimeraCh7 Timera channel 7 ** \arg TimeraCh8 Timera channel 8 ** ** \param [in] enNewSta The function new state ** \arg Disable Disable timera compare function ** \arg Enable Enable timera compare function ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_CompareCmd(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel, en_functional_state_t enNewSta) { en_result_t enRet = ErrorInvalidParameter; __IO stc_tmra_pconr_field_t *pstcTimeraPort; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_NORMAL_TIMERA_CHANNEL(enChannel)); DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewSta)); pstcTimeraPort = (stc_tmra_pconr_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->PCONR1, enChannel); pstcTimeraPort->OUTEN = enNewSta; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Initialize Timera unit capture function ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera capture channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh2 Timera channel 2 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh4 Timera channel 4 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh6 Timera channel 6 ** \arg TimeraCh7 Timera channel 7 ** \arg TimeraCh8 Timera channel 8 ** ** \param [in] pstcCapInit Pointer to timera capture init configuration ** \arg See the struct #stc_timera_capture_init_t ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** - pstcCapInit == NULL ** ******************************************************************************/ en_result_t TIMERA_CaptureInit(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel, const stc_timera_capture_init_t *pstcCapInit) { en_result_t enRet = ErrorInvalidParameter; __IO stc_tmra_cconr_field_t *pstcTimeraCapture; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx) && (NULL != pstcCapInit)) { DDL_ASSERT(IS_VALID_NORMAL_TIMERA_CHANNEL(enChannel)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCapInit->enCapturePwmRisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCapInit->enCapturePwmFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCapInit->enCaptureSpecifyEventEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCapInit->enCaptureTrigFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCapInit->enCaptureTrigRisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCapInit->enPwmFilterEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCapInit->enTrigFilterEn)); DDL_ASSERT(IS_VALID_PORT_FILTER_CLOCK(pstcCapInit->enPwmClkDiv)); DDL_ASSERT(IS_VALID_PORT_FILTER_CLOCK(pstcCapInit->enTrigClkDiv)); /* Configure capture control register */ pstcTimeraCapture = (stc_tmra_cconr_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CCONR1, enChannel); pstcTimeraCapture->HICP0 = pstcCapInit->enCapturePwmRisingEn; pstcTimeraCapture->HICP1 = pstcCapInit->enCapturePwmFallingEn; pstcTimeraCapture->HICP2 = pstcCapInit->enCaptureSpecifyEventEn; pstcTimeraCapture->NOFICKCP = pstcCapInit->enPwmClkDiv; pstcTimeraCapture->NOFIENCP = pstcCapInit->enPwmFilterEn; /* TIMA__TRIG port capture function only valid for TimeraCh3 */ if (TimeraCh3 == enChannel) { pstcTimeraCapture->HICP3 = pstcCapInit->enCaptureTrigRisingEn; pstcTimeraCapture->HICP4 = pstcCapInit->enCaptureTrigFallingEn; /* Configure filter control register */ TIMERAx->FCONR_f.NOFICKTG = pstcCapInit->enTrigClkDiv; TIMERAx->FCONR_f.NOFIENTG = pstcCapInit->enTrigFilterEn; } /* Set capture input function */ pstcTimeraCapture->CAPMD = 1u; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Enable or disable Timera capture filter ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enFilterPort Timera capture filter input port ** \arg TimeraFilterSourceCh1 TIMA__PWM1 input port ** \arg TimeraFilterSourceCh2 TIMA__PWM2 input port ** \arg TimeraFilterSourceCh3 TIMA__PWM3 input port ** \arg TimeraFilterSourceCh4 TIMA__PWM4 input port ** \arg TimeraFilterSourceCh5 TIMA__PWM5 input port ** \arg TimeraFilterSourceCh6 TIMA__PWM6 input port ** \arg TimeraFilterSourceCh7 TIMA__PWM7 input port ** \arg TimeraFilterSourceCh8 TIMA__PWM8 input port ** \arg TimeraFilterSourceTrig TIMA__TRIG input port ** ** \param [in] enNewSta The function new state ** \arg Disable Disable timera capture filter ** \arg Enable Enable timera capture filter ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_CaptureFilterCmd(M4_TMRA_TypeDef *TIMERAx, en_timera_filter_source_t enFilterPort, en_functional_state_t enNewSta) { en_result_t enRet = ErrorInvalidParameter; __IO stc_tmra_cconr_field_t *pstcTimeraCapture; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_CAPTURE_FILTER_PORT_SOURCE(enFilterPort)); DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewSta)); if (TimeraFilterSourceTrig == enFilterPort) { TIMERAx->FCONR_f.NOFIENTG = enNewSta; } else { pstcTimeraCapture = (stc_tmra_cconr_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CCONR1, enFilterPort); pstcTimeraCapture->NOFIENCP = enNewSta; } enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Get Timera capture value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera capture channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh2 Timera channel 2 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh4 Timera channel 4 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh6 Timera channel 6 ** \arg TimeraCh7 Timera channel 7 ** \arg TimeraCh8 Timera channel 8 ** ** \retval uint16_t Timera capture value ** ******************************************************************************/ uint16_t TIMERA_GetCaptureValue(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel) { uint16_t u16CapVal = 0u; __IO stc_tmra_cmpar_field_t *pstcTimeraCompare; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_NORMAL_TIMERA_CHANNEL(enChannel)); pstcTimeraCompare = (stc_tmra_cmpar_field_t *)TIMERA_CALC_REG_ADDR(TIMERAx->CMPAR1, enChannel); u16CapVal = (uint16_t)pstcTimeraCompare->CMP; } return u16CapVal; } /** ******************************************************************************* ** \brief Initialize Timera unit orthogonal coding function ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] pstcCodingInit Pointer to timera orthogonal coding configuration ** \arg See the struct #stc_timera_orthogonal_coding_init_t ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** - pstcCodingInit == NULL ** ******************************************************************************/ en_result_t TIMERA_OrthogonalCodingInit(M4_TMRA_TypeDef *TIMERAx, const stc_timera_orthogonal_coding_init_t *pstcCodingInit) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx) && (NULL != pstcCodingInit)) { DDL_ASSERT(IS_VALID_PORT_FILTER_CLOCK(pstcCodingInit->enTrigClkDiv)); DDL_ASSERT(IS_VALID_PORT_FILTER_CLOCK(pstcCodingInit->enClkBClkDiv)); DDL_ASSERT(IS_VALID_PORT_FILTER_CLOCK(pstcCodingInit->enClkAClkDiv)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enTrigFilterEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enClkBFilterEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enClkAFilterEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncClkALowAndClkBRisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncClkALowAndClkBFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncClkAHighAndClkBRisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncClkAHighAndClkBFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncClkBLowAndClkARisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncClkBLowAndClkAFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncClkBHighAndClkARisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncClkBHighAndClkAFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncTrigRisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncTrigFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncSpecifyEventTriggerEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncAnotherUnitOverflowEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enIncAnotherUnitUnderflowEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecClkALowAndClkBRisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecClkALowAndClkBFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecClkAHighAndClkBRisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecClkAHighAndClkBFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecClkBLowAndClkARisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecClkBLowAndClkAFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecClkBHighAndClkARisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecClkBHighAndClkAFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecTrigRisingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecTrigFallingEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecSpecifyEventTriggerEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecAnotherUnitOverflowEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcCodingInit->enDecAnotherUnitUnderflowEn)); /* Configure hardware increase event register */ TIMERAx->HCUPR_f.HCUP0 = pstcCodingInit->enIncClkALowAndClkBRisingEn; TIMERAx->HCUPR_f.HCUP1 = pstcCodingInit->enIncClkALowAndClkBFallingEn; TIMERAx->HCUPR_f.HCUP2 = pstcCodingInit->enIncClkAHighAndClkBRisingEn; TIMERAx->HCUPR_f.HCUP3 = pstcCodingInit->enIncClkAHighAndClkBFallingEn; TIMERAx->HCUPR_f.HCUP4 = pstcCodingInit->enIncClkBLowAndClkARisingEn; TIMERAx->HCUPR_f.HCUP5 = pstcCodingInit->enIncClkBLowAndClkAFallingEn; TIMERAx->HCUPR_f.HCUP6 = pstcCodingInit->enIncClkBHighAndClkARisingEn; TIMERAx->HCUPR_f.HCUP7 = pstcCodingInit->enIncClkBHighAndClkAFallingEn; TIMERAx->HCUPR_f.HCUP8 = pstcCodingInit->enIncTrigRisingEn; TIMERAx->HCUPR_f.HCUP9 = pstcCodingInit->enIncTrigFallingEn; TIMERAx->HCUPR_f.HCUP10 = pstcCodingInit->enIncSpecifyEventTriggerEn; TIMERAx->HCUPR_f.HCUP11 = pstcCodingInit->enIncAnotherUnitOverflowEn; TIMERAx->HCUPR_f.HCUP12 = pstcCodingInit->enIncAnotherUnitUnderflowEn; /* Configure hardware decrease event register */ TIMERAx->HCDOR_f.HCDO0 = pstcCodingInit->enDecClkALowAndClkBRisingEn; TIMERAx->HCDOR_f.HCDO1 = pstcCodingInit->enDecClkALowAndClkBFallingEn; TIMERAx->HCDOR_f.HCDO2 = pstcCodingInit->enDecClkAHighAndClkBRisingEn; TIMERAx->HCDOR_f.HCDO3 = pstcCodingInit->enDecClkAHighAndClkBFallingEn; TIMERAx->HCDOR_f.HCDO4 = pstcCodingInit->enDecClkBLowAndClkARisingEn; TIMERAx->HCDOR_f.HCDO5 = pstcCodingInit->enDecClkBLowAndClkAFallingEn; TIMERAx->HCDOR_f.HCDO6 = pstcCodingInit->enDecClkBHighAndClkARisingEn; TIMERAx->HCDOR_f.HCDO7 = pstcCodingInit->enDecClkBHighAndClkAFallingEn; TIMERAx->HCDOR_f.HCDO8 = pstcCodingInit->enDecTrigRisingEn; TIMERAx->HCDOR_f.HCDO9 = pstcCodingInit->enDecTrigFallingEn; TIMERAx->HCDOR_f.HCDO10 = pstcCodingInit->enDecSpecifyEventTriggerEn; TIMERAx->HCDOR_f.HCDO11 = pstcCodingInit->enDecAnotherUnitOverflowEn; TIMERAx->HCDOR_f.HCDO12 = pstcCodingInit->enDecAnotherUnitUnderflowEn; /* Configure filter control register */ TIMERAx->FCONR_f.NOFICKTG = pstcCodingInit->enTrigClkDiv; TIMERAx->FCONR_f.NOFIENTG = pstcCodingInit->enTrigFilterEn; TIMERAx->FCONR_f.NOFICKCB = pstcCodingInit->enClkBClkDiv; TIMERAx->FCONR_f.NOFIENCB = pstcCodingInit->enClkBFilterEn; TIMERAx->FCONR_f.NOFICKCA = pstcCodingInit->enClkAClkDiv; TIMERAx->FCONR_f.NOFIENCA = pstcCodingInit->enClkAFilterEn; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Set Timera orthogonal coding value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] u16CodingCnt Timera orthogonal coding value ** \arg 0-0xFFFF ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_SetOrthogonalCodingCount(M4_TMRA_TypeDef *TIMERAx, uint16_t u16CodingCnt) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { TIMERAx->CNTER = u16CodingCnt; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Get Timera orthogonal coding value ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \retval uint16_t Timera orthogonal coding value ** ******************************************************************************/ uint16_t TIMERA_GetOrthogonalCodingCount(M4_TMRA_TypeDef *TIMERAx) { uint16_t u16CodingCnt = 0u; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { u16CodingCnt = (uint16_t)TIMERAx->CNTER; } return u16CodingCnt; } /** ******************************************************************************* ** \brief Enable or disable Timera orthogonal coding filter ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enFilterPort Timera orthogonal coding filter input port ** \arg TimeraFilterSourceClkA TIMA__CLKA input port ** \arg TimeraFilterSourceClkB TIMA__CLKB input port ** \arg TimeraFilterSourceTrig TIMA__TRIG input port ** ** \param [in] enNewSta The function new state ** \arg Disable Disable timera orthogonal coding filter ** \arg Enable Enable timera orthogonal coding filter ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_OrthogonalCodingFilterCmd(M4_TMRA_TypeDef *TIMERAx, en_timera_filter_source_t enFilterPort, en_functional_state_t enNewSta) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_CODING_FILTER_PORT_SOURCE(enFilterPort)); DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewSta)); switch (enFilterPort) { case TimeraFilterSourceClkA: TIMERAx->FCONR_f.NOFIENCA = enNewSta; break; case TimeraFilterSourceClkB: TIMERAx->FCONR_f.NOFIENCB = enNewSta; break; case TimeraFilterSourceTrig: TIMERAx->FCONR_f.NOFIENTG = enNewSta; break; default: break; } enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Initialize Timera unit hardware trigger event function ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] pstcHwTriggerInit Pointer to timera hardware trigger event configuration ** \arg See the struct #stc_timera_hw_trigger_init_t ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** - pstcHwTriggerInit == NULL ** ** \note If sync startup(BCSTR.SYNST) bit set 1 trigger hardware sync startup when HCONR.HSTA1~0 bit set ** ******************************************************************************/ en_result_t TIMERA_HwTriggerInit(M4_TMRA_TypeDef *TIMERAx, const stc_timera_hw_trigger_init_t *pstcHwTriggerInit) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx) && (NULL != pstcHwTriggerInit)) { DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwStartup.enTrigRisingStartupEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwStartup.enTrigFallingStartupEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwStartup.enSpecifyEventStartupEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwStop.enTrigRisingStopEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwStop.enTrigFallingStopEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwStop.enSpecifyEventStopEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwClear.enTrigRisingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwClear.enTrigFallingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwClear.enSpecifyEventClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwClear.enAnotherUnitTrigRisingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwClear.enAnotherUnitTrigFallingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwClear.enChannel3RisingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwTriggerInit->stcHwClear.enChannel3FallingClearEn)); /* Configure hardware startup conditions */ TIMERAx->HCONR_f.HSTA0 = pstcHwTriggerInit->stcHwStartup.enTrigRisingStartupEn; TIMERAx->HCONR_f.HSTA1 = pstcHwTriggerInit->stcHwStartup.enTrigFallingStartupEn; TIMERAx->HCONR_f.HSTA2 = pstcHwTriggerInit->stcHwStartup.enSpecifyEventStartupEn; /* Configure hardware stop conditions */ TIMERAx->HCONR_f.HSTP0 = pstcHwTriggerInit->stcHwStop.enTrigRisingStopEn; TIMERAx->HCONR_f.HSTP1 = pstcHwTriggerInit->stcHwStop.enTrigFallingStopEn; TIMERAx->HCONR_f.HSTP2 = pstcHwTriggerInit->stcHwStop.enSpecifyEventStopEn; /* Configure hardware clear conditions */ TIMERAx->HCONR_f.HCLE0 = pstcHwTriggerInit->stcHwClear.enTrigRisingClearEn; TIMERAx->HCONR_f.HCLE1 = pstcHwTriggerInit->stcHwClear.enTrigFallingClearEn; TIMERAx->HCONR_f.HCLE2 = pstcHwTriggerInit->stcHwClear.enSpecifyEventClearEn; TIMERAx->HCONR_f.HCLE3 = pstcHwTriggerInit->stcHwClear.enAnotherUnitTrigRisingClearEn; TIMERAx->HCONR_f.HCLE4 = pstcHwTriggerInit->stcHwClear.enAnotherUnitTrigFallingClearEn; TIMERAx->HCONR_f.HCLE5 = pstcHwTriggerInit->stcHwClear.enChannel3RisingClearEn; TIMERAx->HCONR_f.HCLE6 = pstcHwTriggerInit->stcHwClear.enChannel3FallingClearEn; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Timera hardware startup Config ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] pstcHwStartup Pointer to timera hardware startup configuration ** \arg See the struct #stc_timera_hw_startup_config_t ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** - pstcHwStartup == NULL ** ******************************************************************************/ en_result_t TIMERA_HwStartupConfig(M4_TMRA_TypeDef *TIMERAx, const stc_timera_hw_startup_config_t *pstcHwStartup) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx) && (NULL != pstcHwStartup)) { DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwStartup->enTrigRisingStartupEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwStartup->enTrigFallingStartupEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwStartup->enSpecifyEventStartupEn)); TIMERAx->HCONR_f.HSTA0 = pstcHwStartup->enTrigRisingStartupEn; TIMERAx->HCONR_f.HSTA1 = pstcHwStartup->enTrigFallingStartupEn; TIMERAx->HCONR_f.HSTA2 = pstcHwStartup->enSpecifyEventStartupEn; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Timera hardware stop Config ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] pstcHwStop Pointer to timera hardware stop configuration ** \arg See the struct #stc_timera_hw_stop_config_t ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** - pstcHwStop == NULL ** ******************************************************************************/ en_result_t TIMERA_HwStopConfig(M4_TMRA_TypeDef *TIMERAx, const stc_timera_hw_stop_config_t *pstcHwStop) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx) && (NULL != pstcHwStop)) { DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwStop->enTrigRisingStopEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwStop->enTrigFallingStopEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwStop->enSpecifyEventStopEn)); TIMERAx->HCONR_f.HSTP0 = pstcHwStop->enTrigRisingStopEn; TIMERAx->HCONR_f.HSTP1 = pstcHwStop->enTrigFallingStopEn; TIMERAx->HCONR_f.HSTP2 = pstcHwStop->enSpecifyEventStopEn; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Timera hardware clear Config ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] pstcHwClear Pointer to timera hardware clear configuration ** \arg See the struct #stc_timera_hw_clear_config_t ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** - pstcHwClear == NULL ** ******************************************************************************/ en_result_t TIMERA_HwClearConfig(M4_TMRA_TypeDef *TIMERAx, const stc_timera_hw_clear_config_t *pstcHwClear) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx) && (NULL != pstcHwClear)) { DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwClear->enTrigRisingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwClear->enTrigFallingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwClear->enSpecifyEventClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwClear->enAnotherUnitTrigRisingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwClear->enAnotherUnitTrigFallingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwClear->enChannel3RisingClearEn)); DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcHwClear->enChannel3FallingClearEn)); TIMERAx->HCONR_f.HCLE0 = pstcHwClear->enTrigRisingClearEn; TIMERAx->HCONR_f.HCLE1 = pstcHwClear->enTrigFallingClearEn; TIMERAx->HCONR_f.HCLE2 = pstcHwClear->enSpecifyEventClearEn; TIMERAx->HCONR_f.HCLE3 = pstcHwClear->enAnotherUnitTrigRisingClearEn; TIMERAx->HCONR_f.HCLE4 = pstcHwClear->enAnotherUnitTrigFallingClearEn; TIMERAx->HCONR_f.HCLE5 = pstcHwClear->enChannel3RisingClearEn; TIMERAx->HCONR_f.HCLE6 = pstcHwClear->enChannel3FallingClearEn; enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Enable or disable Timera interrupt request ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enIrq Timera interrupt request ** \arg TimeraIrqCaptureOrCompareCh1 Channel 1 interrupt request ** \arg TimeraIrqCaptureOrCompareCh2 Channel 2 interrupt request ** \arg TimeraIrqCaptureOrCompareCh3 Channel 3 interrupt request ** \arg TimeraIrqCaptureOrCompareCh4 Channel 4 interrupt request ** \arg TimeraIrqCaptureOrCompareCh5 Channel 5 interrupt request ** \arg TimeraIrqCaptureOrCompareCh6 Channel 6 interrupt request ** \arg TimeraIrqCaptureOrCompareCh7 Channel 7 interrupt request ** \arg TimeraIrqCaptureOrCompareCh8 Channel 8 interrupt request ** \arg TimeraIrqOverflow Count overflow interrupt request ** \arg TimeraIrqUnderflow Count underflow interrupt request ** ** \param [in] enNewSta The function new state ** \arg Disable Disable timera interrupt request ** \arg Enable Enable timera interrupt request ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_IrqCmd(M4_TMRA_TypeDef *TIMERAx, en_timera_irq_type_t enIrq, en_functional_state_t enNewSta) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_IRQ_SOURCE(enIrq)); DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewSta)); switch (enIrq) { case TimeraIrqCaptureOrCompareCh1: TIMERAx->ICONR_f.ITEN1 = enNewSta; break; case TimeraIrqCaptureOrCompareCh2: TIMERAx->ICONR_f.ITEN2 = enNewSta; break; case TimeraIrqCaptureOrCompareCh3: TIMERAx->ICONR_f.ITEN3 = enNewSta; break; case TimeraIrqCaptureOrCompareCh4: TIMERAx->ICONR_f.ITEN4 = enNewSta; break; case TimeraIrqCaptureOrCompareCh5: TIMERAx->ICONR_f.ITEN5 = enNewSta; break; case TimeraIrqCaptureOrCompareCh6: TIMERAx->ICONR_f.ITEN6 = enNewSta; break; case TimeraIrqCaptureOrCompareCh7: TIMERAx->ICONR_f.ITEN7 = enNewSta; break; case TimeraIrqCaptureOrCompareCh8: TIMERAx->ICONR_f.ITEN8 = enNewSta; break; case TimeraIrqOverflow: TIMERAx->BCSTR_f.ITENOVF = enNewSta; break; case TimeraIrqUnderflow: TIMERAx->BCSTR_f.ITENUDF = enNewSta; break; default: break; } enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Enable or disable Timera event request ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enChannel Timera event request channel ** \arg TimeraCh1 Timera channel 1 ** \arg TimeraCh2 Timera channel 2 ** \arg TimeraCh3 Timera channel 3 ** \arg TimeraCh4 Timera channel 4 ** \arg TimeraCh5 Timera channel 5 ** \arg TimeraCh6 Timera channel 6 ** \arg TimeraCh7 Timera channel 7 ** \arg TimeraCh8 Timera channel 8 ** ** \param [in] enNewSta The function new state ** \arg Disable Disable timera event request ** \arg Enable Enable timera event request ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_EventCmd(M4_TMRA_TypeDef *TIMERAx, en_timera_channel_t enChannel, en_functional_state_t enNewSta) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_NORMAL_TIMERA_CHANNEL(enChannel)); switch (enChannel) { case TimeraCh1: TIMERAx->ECONR_f.ETEN1 = enNewSta; break; case TimeraCh2: TIMERAx->ECONR_f.ETEN2 = enNewSta; break; case TimeraCh3: TIMERAx->ECONR_f.ETEN3 = enNewSta; break; case TimeraCh4: TIMERAx->ECONR_f.ETEN4 = enNewSta; break; case TimeraCh5: TIMERAx->ECONR_f.ETEN5 = enNewSta; break; case TimeraCh6: TIMERAx->ECONR_f.ETEN6 = enNewSta; break; case TimeraCh7: TIMERAx->ECONR_f.ETEN7 = enNewSta; break; case TimeraCh8: TIMERAx->ECONR_f.ETEN8 = enNewSta; break; default: break; } enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Get Timera flag status ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enFlag Timera flag type ** \arg TimeraFlagCaptureOrCompareCh1 Channel 1 match flag ** \arg TimeraFlagCaptureOrCompareCh2 Channel 2 match flag ** \arg TimeraFlagCaptureOrCompareCh3 Channel 3 match flag ** \arg TimeraFlagCaptureOrCompareCh4 Channel 4 match flag ** \arg TimeraFlagCaptureOrCompareCh5 Channel 5 match flag ** \arg TimeraFlagCaptureOrCompareCh6 Channel 6 match flag ** \arg TimeraFlagCaptureOrCompareCh7 Channel 7 match flag ** \arg TimeraFlagCaptureOrCompareCh8 Channel 8 match flag ** \arg TimeraFlagOverflow Count overflow flag ** \arg TimeraFlagUnderflow Count underflow flag ** ** \retval Set Flag is set ** \retval Reset Flag is reset ** ******************************************************************************/ en_flag_status_t TIMERA_GetFlag(M4_TMRA_TypeDef *TIMERAx, en_timera_flag_type_t enFlag) { en_flag_status_t enFlagSta = Reset; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_FLAG_TYPE(enFlag)); switch (enFlag) { case TimeraFlagCaptureOrCompareCh1: enFlagSta = (en_flag_status_t)TIMERAx->STFLR_f.CMPF1; break; case TimeraFlagCaptureOrCompareCh2: enFlagSta = (en_flag_status_t)TIMERAx->STFLR_f.CMPF2; break; case TimeraFlagCaptureOrCompareCh3: enFlagSta = (en_flag_status_t)TIMERAx->STFLR_f.CMPF3; break; case TimeraFlagCaptureOrCompareCh4: enFlagSta = (en_flag_status_t)TIMERAx->STFLR_f.CMPF4; break; case TimeraFlagCaptureOrCompareCh5: enFlagSta = (en_flag_status_t)TIMERAx->STFLR_f.CMPF5; break; case TimeraFlagCaptureOrCompareCh6: enFlagSta = (en_flag_status_t)TIMERAx->STFLR_f.CMPF6; break; case TimeraFlagCaptureOrCompareCh7: enFlagSta = (en_flag_status_t)TIMERAx->STFLR_f.CMPF7; break; case TimeraFlagCaptureOrCompareCh8: enFlagSta = (en_flag_status_t)TIMERAx->STFLR_f.CMPF8; break; case TimeraFlagOverflow: enFlagSta = (en_flag_status_t)TIMERAx->BCSTR_f.OVFF; break; case TimeraFlagUnderflow: enFlagSta = (en_flag_status_t)TIMERAx->BCSTR_f.UDFF; break; default: break; } } return enFlagSta; } /** ******************************************************************************* ** \brief Clear Timera flag status ** ** \param [in] TIMERAx Pointer to timera unit configuration address ** \arg M4_TMRA1 Timera unit 1 configuration Address ** \arg M4_TMRA2 Timera unit 2 configuration Address ** \arg M4_TMRA3 Timera unit 3 configuration Address ** \arg M4_TMRA4 Timera unit 4 configuration Address ** \arg M4_TMRA5 Timera unit 5 configuration Address ** \arg M4_TMRA6 Timera unit 6 configuration Address ** ** \param [in] enFlag Timera flag type ** \arg TimeraFlagCaptureOrCompareCh1 Channel 1 match flag ** \arg TimeraFlagCaptureOrCompareCh2 Channel 2 match flag ** \arg TimeraFlagCaptureOrCompareCh3 Channel 3 match flag ** \arg TimeraFlagCaptureOrCompareCh4 Channel 4 match flag ** \arg TimeraFlagCaptureOrCompareCh5 Channel 5 match flag ** \arg TimeraFlagCaptureOrCompareCh6 Channel 6 match flag ** \arg TimeraFlagCaptureOrCompareCh7 Channel 7 match flag ** \arg TimeraFlagCaptureOrCompareCh8 Channel 8 match flag ** \arg TimeraFlagOverflow Count overflow flag ** \arg TimeraFlagUnderflow Count underflow flag ** ** \retval Ok Process successfully done ** \retval ErrorInvalidParameter If one of following cases matches: ** - TIMERAx is invalid ** ******************************************************************************/ en_result_t TIMERA_ClearFlag(M4_TMRA_TypeDef *TIMERAx, en_timera_flag_type_t enFlag) { en_result_t enRet = ErrorInvalidParameter; /* Check parameters */ if(IS_VALID_NORMAL_TIMERA_UNIT(TIMERAx)) { DDL_ASSERT(IS_VALID_FLAG_TYPE(enFlag)); switch (enFlag) { case TimeraFlagCaptureOrCompareCh1: TIMERAx->STFLR_f.CMPF1 = 0u; break; case TimeraFlagCaptureOrCompareCh2: TIMERAx->STFLR_f.CMPF2 = 0u; break; case TimeraFlagCaptureOrCompareCh3: TIMERAx->STFLR_f.CMPF3 = 0u; break; case TimeraFlagCaptureOrCompareCh4: TIMERAx->STFLR_f.CMPF4 = 0u; break; case TimeraFlagCaptureOrCompareCh5: TIMERAx->STFLR_f.CMPF5 = 0u; break; case TimeraFlagCaptureOrCompareCh6: TIMERAx->STFLR_f.CMPF6 = 0u; break; case TimeraFlagCaptureOrCompareCh7: TIMERAx->STFLR_f.CMPF7 = 0u; break; case TimeraFlagCaptureOrCompareCh8: TIMERAx->STFLR_f.CMPF8 = 0u; break; case TimeraFlagOverflow: TIMERAx->BCSTR_f.OVFF = 0u; break; case TimeraFlagUnderflow: TIMERAx->BCSTR_f.UDFF = 0u; break; default: break; } enRet = Ok; } return enRet; } /** ******************************************************************************* ** \brief Set counter event trigger source ** ** \param [in] enTriggerSrc Counter event trigger source ** \arg 0-511 Used to trigger counter start/stop/clear/increment/decrement ** ** \retval Ok Process successfully done ** ******************************************************************************/ en_result_t TIMERA_SetCountTriggerSrc(en_event_src_t enTriggerSrc) { en_result_t enRet = Ok; /* Check parameters */ DDL_ASSERT(IS_VALID_EVENT_SOURCE(enTriggerSrc)); M4_AOS->TMRA_HTSSR0_f.TRGSEL = enTriggerSrc; return enRet; } /** ******************************************************************************* ** \brief Set capture event trigger source ** ** \param [in] enTriggerSrc Capture event trigger source ** \arg 0-511 Used to trigger the capture function ** ** \retval Ok Process successfully done ** ******************************************************************************/ en_result_t TIMERA_SetCaptureTriggerSrc(en_event_src_t enTriggerSrc) { en_result_t enRet = Ok; /* Check parameters */ DDL_ASSERT(IS_VALID_EVENT_SOURCE(enTriggerSrc)); M4_AOS->TMRA_HTSSR1_f.TRGSEL = enTriggerSrc; return enRet; } /** ******************************************************************************* ** \brief Enable or disable TimerA counter common trigger. ** ** \param [in] enComTrigger TimerA common trigger selection. ** \arg TimeraComTrigger_1 Select common trigger 1 ** \arg TimeraComTrigger_2 Select common trigger 2 ** \arg TimeraComTrigger_1_2 Select common trigger 1 and 2 ** ** \param [in] enNewSta The function new state ** \arg Disable Disable the specified common trigger. ** \arg Enable Enable the specified common trigger. ** ** \retval Ok Process successfully done ** ******************************************************************************/ en_result_t TIMERA_CountComTriggerCmd(en_timera_com_trigger_t enComTrigger, en_functional_state_t enNewSta) { en_result_t enRet = Ok; uint32_t u32ComTrig; /* Check parameters */ DDL_ASSERT(IS_VALID_COM_TRIGGER(enComTrigger)); DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewSta)); u32ComTrig = (uint32_t)enComTrigger << 30u; if (enNewSta == Enable) { M4_AOS->TMRA_HTSSR0 |= u32ComTrig; } else { M4_AOS->TMRA_HTSSR0 &= ~u32ComTrig; } return enRet; } /** ******************************************************************************* ** \brief Enable or disable TimerA capture common trigger. ** ** \param [in] enComTrigger TimerA common trigger selection. ** \arg TimeraComTrigger_1 Select common trigger 1 ** \arg TimeraComTrigger_2 Select common trigger 2 ** \arg TimeraComTrigger_1_2 Select common trigger 1 and 2 ** ** \param [in] enNewSta The function new state ** \arg Disable Disable the specified common trigger. ** \arg Enable Enable the specified common trigger. ** ** \retval Ok Process successfully done ** ******************************************************************************/ en_result_t TIMERA_CaptureComTriggerCmd(en_timera_com_trigger_t enComTrigger, en_functional_state_t enNewSta) { en_result_t enRet = Ok; uint32_t u32ComTrig; /* Check parameters */ DDL_ASSERT(IS_VALID_COM_TRIGGER(enComTrigger)); DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewSta)); u32ComTrig = (uint32_t)enComTrigger << 30u; if (enNewSta == Enable) { M4_AOS->TMRA_HTSSR1 |= u32ComTrig; } else { M4_AOS->TMRA_HTSSR1 &= ~u32ComTrig; } return enRet; } //@} // TimeraGroup #endif /* DDL_TIMERA_ENABLE */ /******************************************************************************* * EOF (not truncated) ******************************************************************************/