1973 lines
90 KiB
C
1973 lines
90 KiB
C
|
/*******************************************************************************
|
||
|
* 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_<t>_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_<t>_PWM1 input port
|
||
|
** \arg TimeraFilterSourceCh2 TIMA_<t>_PWM2 input port
|
||
|
** \arg TimeraFilterSourceCh3 TIMA_<t>_PWM3 input port
|
||
|
** \arg TimeraFilterSourceCh4 TIMA_<t>_PWM4 input port
|
||
|
** \arg TimeraFilterSourceCh5 TIMA_<t>_PWM5 input port
|
||
|
** \arg TimeraFilterSourceCh6 TIMA_<t>_PWM6 input port
|
||
|
** \arg TimeraFilterSourceCh7 TIMA_<t>_PWM7 input port
|
||
|
** \arg TimeraFilterSourceCh8 TIMA_<t>_PWM8 input port
|
||
|
** \arg TimeraFilterSourceTrig TIMA_<t>_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_<t>_CLKA input port
|
||
|
** \arg TimeraFilterSourceClkB TIMA_<t>_CLKB input port
|
||
|
** \arg TimeraFilterSourceTrig TIMA_<t>_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)
|
||
|
******************************************************************************/
|