1369 lines
43 KiB
C
1369 lines
43 KiB
C
/******************************************************************************
|
||
*Copyright(C)2018, Huada Semiconductor Co.,Ltd All rights reserved.
|
||
*
|
||
* This software is owned and published by:
|
||
* Huada Semiconductor Co.,Ltd("HDSC").
|
||
*
|
||
* BY DOWNLOADING, INSTALLING OR USING THIS SOFTWARE, YOU AGREE TO BE BOUND
|
||
* BY ALL THE TERMS AND CONDITIONS OF THIS AGREEMENT.
|
||
*
|
||
* This software contains source code for use with HDSC
|
||
* components. This software is licensed by HDSC to be adapted only
|
||
* for use in systems utilizing HDSC components. HDSC shall not be
|
||
* responsible for misuse or illegal use of this software for devices not
|
||
* supported herein. HDSC is providing this software "AS IS" and will
|
||
* not be responsible for issues arising from incorrect user implementation
|
||
* of the software.
|
||
*
|
||
* Disclaimer:
|
||
* HDSC MAKES NO WARRANTY, EXPRESS OR IMPLIED, ARISING BY LAW OR OTHERWISE,
|
||
* REGARDING THE SOFTWARE (INCLUDING ANY ACOOMPANYING WRITTEN MATERIALS),
|
||
* ITS PERFORMANCE OR SUITABILITY FOR YOUR INTENDED USE, INCLUDING,
|
||
* WITHOUT LIMITATION, THE IMPLIED WARRANTY OF MERCHANTABILITY, THE IMPLIED
|
||
* WARRANTY OF FITNESS FOR A PARTICULAR PURPOSE OR USE, AND THE IMPLIED
|
||
* WARRANTY OF NONINFRINGEMENT.
|
||
* HDSC SHALL HAVE NO LIABILITY (WHETHER IN CONTRACT, WARRANTY, TORT,
|
||
* NEGLIGENCE OR OTHERWISE) FOR ANY DAMAGES WHATSOEVER (INCLUDING, WITHOUT
|
||
* LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS INTERRUPTION,
|
||
* LOSS OF BUSINESS INFORMATION, OR OTHER PECUNIARY LOSS) ARISING FROM USE OR
|
||
* INABILITY TO USE THE SOFTWARE, INCLUDING, WITHOUT LIMITATION, ANY DIRECT,
|
||
* INDIRECT, INCIDENTAL, SPECIAL OR CONSEQUENTIAL DAMAGES OR LOSS OF DATA,
|
||
* SAVINGS OR PROFITS,
|
||
* EVEN IF Disclaimer HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
|
||
* YOU ASSUME ALL RESPONSIBILITIES FOR SELECTION OF THE SOFTWARE TO ACHIEVE YOUR
|
||
* INTENDED RESULTS, AND FOR THE INSTALLATION OF, USE OF, AND RESULTS OBTAINED
|
||
* FROM, THE SOFTWARE.
|
||
*
|
||
* This software may be replicated in part or whole for the licensed use,
|
||
* with the restriction that this Disclaimer and Copyright notice must be
|
||
* included with each copy of this software, whether used in part or whole,
|
||
* at all times.
|
||
*/
|
||
|
||
/** \file timer3.c
|
||
**
|
||
** Common API of base timer.
|
||
** @link Tiemr3 Group Some description @endlink
|
||
**
|
||
** - 2019-04-18 Husj First Version
|
||
**
|
||
******************************************************************************/
|
||
|
||
/*******************************************************************************
|
||
* Include files
|
||
******************************************************************************/
|
||
#include "hc32l196_timer3.h"
|
||
/**
|
||
*******************************************************************************
|
||
** \addtogroup Tim3Group
|
||
******************************************************************************/
|
||
//@{
|
||
|
||
/*******************************************************************************
|
||
* Local pre-processor symbols/macros ('#define')
|
||
******************************************************************************/
|
||
|
||
|
||
/*******************************************************************************
|
||
* Global variable definitions (declared in header file with 'extern')
|
||
******************************************************************************/
|
||
|
||
/*******************************************************************************
|
||
* Local type definitions ('typedef')
|
||
******************************************************************************/
|
||
|
||
/*******************************************************************************
|
||
* Local variable definitions ('static')
|
||
******************************************************************************/
|
||
|
||
|
||
/*******************************************************************************
|
||
* Local function prototypes ('static')
|
||
******************************************************************************/
|
||
|
||
|
||
/*******************************************************************************
|
||
* Function implementation - global ('extern') and local ('static')
|
||
******************************************************************************/
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 中断标志获取(模式0/1/23)
|
||
**
|
||
**
|
||
** \param [in] enTim3Irq 中断类型
|
||
**
|
||
** \retval TRUE or FALSE
|
||
*****************************************************************************/
|
||
boolean_t Tim3_GetIntFlag(en_tim3_irq_type_t enTim3Irq)
|
||
{
|
||
boolean_t bRetVal = FALSE;
|
||
uint32_t u32Val;
|
||
|
||
u32Val = M0P_TIM3_MODE23->IFR;
|
||
bRetVal = (u32Val>>enTim3Irq) & 0x1;
|
||
|
||
return bRetVal;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 中断标志清除(模式0/1/23)
|
||
**
|
||
**
|
||
** \param [in] enTim3Irq 中断类型
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_ClearIntFlag(en_tim3_irq_type_t enTim3Irq)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->ICLR = ~(1u<<enTim3Irq);
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 中断所有标志清除(模式23)
|
||
**
|
||
**
|
||
**
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_ClearAllIntFlag(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->ICLR = 0;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 中断使能(模式0)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_Mode0_EnableIrq(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE0->M0CR_f.UIE = TRUE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 中断禁止(模式0)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_Mode0_DisableIrq(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE0->M0CR_f.UIE = FALSE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 中断使能(模式1)
|
||
**
|
||
**
|
||
** \param [in] enTim3Irq 中断类型
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_Mode1_EnableIrq (en_tim3_irq_type_t enTim3Irq)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
|
||
switch (enTim3Irq)
|
||
{
|
||
case Tim3UevIrq:
|
||
M0P_TIM3_MODE1->M1CR_f.UIE = TRUE;
|
||
break;
|
||
case Tim3CA0Irq:
|
||
M0P_TIM3_MODE1->CR0_f.CIEA = TRUE;
|
||
break;
|
||
default:
|
||
enResult = Error;
|
||
break;
|
||
}
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 中断禁止(模式1)
|
||
**
|
||
**
|
||
** \param [in] enTim3Irq 中断类型
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_Mode1_DisableIrq (en_tim3_irq_type_t enTim3Irq)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
|
||
switch (enTim3Irq)
|
||
{
|
||
case Tim3UevIrq:
|
||
M0P_TIM3_MODE1->M1CR_f.UIE = FALSE;
|
||
break;
|
||
case Tim3CA0Irq:
|
||
M0P_TIM3_MODE1->CR0_f.CIEA = FALSE;
|
||
break;
|
||
default:
|
||
enResult = Error;
|
||
break;
|
||
}
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 中断使能(模式23)
|
||
**
|
||
**
|
||
** \param [in] enTim3Irq 中断类型
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_Mode23_EnableIrq (en_tim3_irq_type_t enTim3Irq)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
|
||
switch (enTim3Irq)
|
||
{
|
||
case Tim3UevIrq:
|
||
M0P_TIM3_MODE23->M23CR_f.UIE = TRUE;
|
||
break;
|
||
case Tim3CA0Irq:
|
||
M0P_TIM3_MODE23->CRCH0_f.CIEA = TRUE;
|
||
break;
|
||
case Tim3CB0Irq:
|
||
M0P_TIM3_MODE23->CRCH0_f.CIEB = TRUE;
|
||
break;
|
||
case Tim3CA1Irq:
|
||
M0P_TIM3_MODE23->CRCH1_f.CIEA = TRUE;
|
||
break;
|
||
case Tim3CB1Irq:
|
||
M0P_TIM3_MODE23->CRCH1_f.CIEB = TRUE;
|
||
break;
|
||
case Tim3CA2Irq:
|
||
M0P_TIM3_MODE23->CRCH2_f.CIEA = TRUE;
|
||
break;
|
||
case Tim3CB2Irq:
|
||
M0P_TIM3_MODE23->CRCH2_f.CIEB = TRUE;
|
||
break;
|
||
case Tim3BkIrq:
|
||
M0P_TIM3_MODE23->M23CR_f.BIE = TRUE;
|
||
break;
|
||
case Tim3TrigIrq:
|
||
M0P_TIM3_MODE23->M23CR_f.TIE = TRUE;
|
||
break;
|
||
default:
|
||
enResult = Error;
|
||
break;
|
||
}
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 中断禁止(模式23)
|
||
**
|
||
**
|
||
** \param [in] enTim3Irq 中断类型
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_Mode23_DisableIrq (en_tim3_irq_type_t enTim3Irq)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
|
||
switch (enTim3Irq)
|
||
{
|
||
case Tim3UevIrq:
|
||
M0P_TIM3_MODE23->M23CR_f.UIE = FALSE;
|
||
break;
|
||
case Tim3CA0Irq:
|
||
M0P_TIM3_MODE23->CRCH0_f.CIEA = FALSE;
|
||
break;
|
||
case Tim3CB0Irq:
|
||
M0P_TIM3_MODE23->CRCH0_f.CIEB = FALSE;
|
||
break;
|
||
case Tim3CA1Irq:
|
||
M0P_TIM3_MODE23->CRCH1_f.CIEA = FALSE;
|
||
break;
|
||
case Tim3CB1Irq:
|
||
M0P_TIM3_MODE23->CRCH1_f.CIEB = FALSE;
|
||
break;
|
||
case Tim3CA2Irq:
|
||
M0P_TIM3_MODE23->CRCH2_f.CIEA = FALSE;
|
||
break;
|
||
case Tim3CB2Irq:
|
||
M0P_TIM3_MODE23->CRCH2_f.CIEB = FALSE;
|
||
break;
|
||
case Tim3BkIrq:
|
||
M0P_TIM3_MODE23->M23CR_f.BIE = FALSE;
|
||
break;
|
||
case Tim3TrigIrq:
|
||
M0P_TIM3_MODE23->M23CR_f.TIE = FALSE;
|
||
break;
|
||
default:
|
||
enResult = Error;
|
||
break;
|
||
}
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 初始化配置(模式0)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_Mode0_Init(stc_tim3_mode0_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE0->M0CR_f.MODE = pstcCfg->enWorkMode;
|
||
M0P_TIM3_MODE0->M0CR_f.GATEP = pstcCfg->enGateP;
|
||
M0P_TIM3_MODE0->M0CR_f.GATE = pstcCfg->bEnGate;
|
||
M0P_TIM3_MODE0->M0CR_f.PRS = pstcCfg->enPRS;
|
||
M0P_TIM3_MODE0->M0CR_f.TOGEN = pstcCfg->bEnTog;
|
||
M0P_TIM3_MODE0->M0CR_f.CT = pstcCfg->enCT;
|
||
M0P_TIM3_MODE0->M0CR_f.MD = pstcCfg->enCntMode;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 启动运行(模式0)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M0_Run(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE0->M0CR_f.CTEN = TRUE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 停止运行(模式0)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M0_Stop(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE0->M0CR_f.CTEN = FALSE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 端口输出使能/禁止设定(模式0)
|
||
**
|
||
**
|
||
** \param [in] bEnOutput 翻转输出设定 TRUE:使能, FALSE:禁止
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M0_Enable_Output(boolean_t bEnOutput)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
|
||
M0P_TIM3_MODE0->DTR_f.MOE = bEnOutput;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 翻转使能/禁止(低电平)设定(模式0)
|
||
**
|
||
**
|
||
** \param [in] bEnTOG 翻转输出设定 TRUE:使能, FALSE:禁止
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M0_EnTOG(boolean_t bEnTOG)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE0->M0CR_f.TOGEN = bEnTOG;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 16位计数器初值设置(模式0)
|
||
**
|
||
**
|
||
** \param [in] u16Data CNT 16位初值
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M0_Cnt16Set(uint16_t u16Data)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE0->CNT_f.CNT = u16Data;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 16位计数值获取(模式0)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval 16bits计数值
|
||
*****************************************************************************/
|
||
uint16_t Tim3_M0_Cnt16Get(void)
|
||
{
|
||
uint16_t u16CntData = 0;
|
||
|
||
u16CntData = M0P_TIM3_MODE0->CNT_f.CNT;
|
||
|
||
return u16CntData;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 重载值设置(模式0)
|
||
**
|
||
**
|
||
** \param [in] u16Data 16bits重载值
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M0_ARRSet(uint16_t u16Data)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE0->ARR_f.ARR = u16Data;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 32位计数器初值设置(模式0)
|
||
**
|
||
**
|
||
** \param [in] u32Data 32位初值
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M0_Cnt32Set(uint32_t u32Data)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE0->CNT32_f.CNT32 = u32Data;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 32位计数值获取(模式0)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval 32bits计数值
|
||
*****************************************************************************/
|
||
uint32_t Tim3_M0_Cnt32Get(void)
|
||
{
|
||
uint32_t u32CntData = 0;
|
||
|
||
u32CntData = M0P_TIM3_MODE0->CNT32_f.CNT32;
|
||
|
||
return u32CntData;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 初始化配置(模式1)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_Mode1_Init(stc_tim3_mode1_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE1->M1CR_f.MODE = pstcCfg->enWorkMode;
|
||
M0P_TIM3_MODE1->M1CR_f.PRS = pstcCfg->enPRS;
|
||
M0P_TIM3_MODE1->M1CR_f.CT = pstcCfg->enCT;
|
||
M0P_TIM3_MODE1->M1CR_f.ONESHOT = pstcCfg->enOneShot;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 PWC 输入配置(模式1)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M1_Input_Cfg(stc_tim3_pwc_input_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE1->MSCR_f.TS = pstcCfg->enTsSel;
|
||
M0P_TIM3_MODE1->MSCR_f.IA0S = pstcCfg->enIA0Sel;
|
||
M0P_TIM3_MODE1->MSCR_f.IB0S = pstcCfg->enIB0Sel;
|
||
M0P_TIM3_MODE1->FLTR_f.ETP = pstcCfg->enETRPhase;
|
||
M0P_TIM3_MODE1->FLTR_f.FLTET = pstcCfg->enFltETR;
|
||
M0P_TIM3_MODE1->FLTR_f.FLTA0 = pstcCfg->enFltIA0;
|
||
M0P_TIM3_MODE1->FLTR_f.FLTB0 = pstcCfg->enFltIB0;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 PWC测量边沿起始结束选择(模式1)
|
||
**
|
||
**
|
||
** \param [in] enEdgeSel pwc测量起始终止电平
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M1_PWC_Edge_Sel(en_tim3_m1cr_Edge_t enEdgeSel)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
switch (enEdgeSel)
|
||
{
|
||
case 0: ///< 上升沿到上升沿(周期)
|
||
M0P_TIM3_MODE1->M1CR_f.EDG1ST = 0; //上升沿
|
||
M0P_TIM3_MODE1->M1CR_f.EDG2ND = 0; //上升沿
|
||
break;
|
||
case 1: ///< 下降沿到上升沿(低电平)
|
||
M0P_TIM3_MODE1->M1CR_f.EDG1ST = 1; //下降沿
|
||
M0P_TIM3_MODE1->M1CR_f.EDG2ND = 0; //上升沿
|
||
break;
|
||
case 2: ///< 上升沿到下降沿(高电平)
|
||
M0P_TIM3_MODE1->M1CR_f.EDG1ST = 0; //上升沿
|
||
M0P_TIM3_MODE1->M1CR_f.EDG2ND = 1; //下降沿
|
||
break;
|
||
case 3: ///< 下降沿到下降沿(周期)
|
||
M0P_TIM3_MODE1->M1CR_f.EDG1ST = 1; //下降沿
|
||
M0P_TIM3_MODE1->M1CR_f.EDG2ND = 1; //下降沿
|
||
break;
|
||
default:
|
||
;
|
||
break;
|
||
}
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 启动运行(模式1)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M1_Run(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE1->M1CR_f.CTEN = TRUE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 停止运行(模式1)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M1_Stop(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE1->M1CR_f.CTEN = FALSE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 16位计数器初值设置(模式1)
|
||
**
|
||
**
|
||
** \param [in] u16Data 16位初值
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M1_Cnt16Set(uint16_t u16Data)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE1->CNT_f.CNT = u16Data;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 16位计数值获取(模式1)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval 16bits计数值
|
||
*****************************************************************************/
|
||
uint16_t Tim3_M1_Cnt16Get(void)
|
||
{
|
||
uint16_t u16CntData = 0;
|
||
|
||
u16CntData = M0P_TIM3_MODE1->CNT_f.CNT;
|
||
|
||
return u16CntData;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 脉冲宽度测量结果数值获取(模式1)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval 16bits脉冲宽度测量结果
|
||
*****************************************************************************/
|
||
uint16_t Tim3_M1_PWC_CapValueGet(void)
|
||
{
|
||
uint16_t u16CapData = 0;
|
||
|
||
u16CapData = M0P_TIM3_MODE1->CCR0A_f.CCR0A;
|
||
|
||
return u16CapData;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 初始化配置(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_Mode23_Init(stc_tim3_mode23_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.MODE = pstcCfg->enWorkMode;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.PRS = pstcCfg->enPRS;
|
||
M0P_TIM3_MODE23->M23CR_f.CT = pstcCfg->enCT;
|
||
M0P_TIM3_MODE23->M23CR_f.COMP = pstcCfg->enPWMTypeSel;
|
||
M0P_TIM3_MODE23->M23CR_f.PWM2S = pstcCfg->enPWM2sSel;
|
||
M0P_TIM3_MODE23->M23CR_f.ONESHOT = pstcCfg->bOneShot;
|
||
M0P_TIM3_MODE23->M23CR_f.URS = pstcCfg->bURSSel;
|
||
M0P_TIM3_MODE23->M23CR_f.DIR = pstcCfg->enCntDir;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 PWM输出使能(模式23)
|
||
**
|
||
**
|
||
** \param [in] bEnOutput PWM输出使能/禁止设定
|
||
** \param [in] bEnAutoOutput PWM自动输出使能/禁止设定
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_EnPWM_Output(boolean_t bEnOutput, boolean_t bEnAutoOutput)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->DTR_f.MOE = bEnOutput;
|
||
M0P_TIM3_MODE23->DTR_f.AOE = bEnAutoOutput;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 启动运行(模式23)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_Run(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.CTEN = TRUE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 停止运行(模式23)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_Stop(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.CTEN = FALSE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 重载值设置(模式23)
|
||
**
|
||
**
|
||
** \param [in] u16Data 16bits重载值
|
||
** \param [in] bArrBufEn ARR重载缓存使能TRUE/禁止FALSE
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_ARRSet(uint16_t u16Data, boolean_t bArrBufEn)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->ARR_f.ARR = u16Data;
|
||
M0P_TIM3_MODE23->M23CR_f.BUFPEN = bArrBufEn;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 16位计数器初值设置(模式23)
|
||
**
|
||
**
|
||
** \param [in] u16Data 16位初值
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_Cnt16Set(uint16_t u16Data)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->CNT_f.CNT = u16Data;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 16位计数值获取(模式23)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval 16bits计数值
|
||
*****************************************************************************/
|
||
uint16_t Tim3_M23_Cnt16Get(void)
|
||
{
|
||
uint16_t u16CntData = 0;
|
||
|
||
u16CntData = M0P_TIM3_MODE23->CNT_f.CNT;
|
||
|
||
return u16CntData;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 比较捕获寄存器CCRxA/CCRxB设置(模式23)
|
||
**
|
||
**
|
||
** \param [in] enCCRSel CCRxA/CCRxB设定
|
||
** \param [in] u16Data CCRxA/CCRxB 16位初始值
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_CCR_Set(en_tim3_m23_ccrx_t enCCRSel, uint16_t u16Data)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
if(Tim3CCR0A == enCCRSel)
|
||
{
|
||
M0P_TIM3_MODE23->CCR0A_f.CCR0A = u16Data;
|
||
}
|
||
else if(Tim3CCR0B == enCCRSel)
|
||
{
|
||
M0P_TIM3_MODE23->CCR0B_f.CCR0B = u16Data;
|
||
}
|
||
else if(Tim3CCR1A == enCCRSel)
|
||
{
|
||
M0P_TIM3_MODE23->CCR1A_f.CCR1A = u16Data;
|
||
}
|
||
else if(Tim3CCR1B == enCCRSel)
|
||
{
|
||
M0P_TIM3_MODE23->CCR1B_f.CCR1B = u16Data;
|
||
}
|
||
else if(Tim3CCR2A == enCCRSel)
|
||
{
|
||
M0P_TIM3_MODE23->CCR2A_f.CCR2A = u16Data;
|
||
}
|
||
else if(Tim3CCR2B == enCCRSel)
|
||
{
|
||
M0P_TIM3_MODE23->CCR2B_f.CCR2B = u16Data;
|
||
}
|
||
else
|
||
{
|
||
enResult = Error;
|
||
}
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 比较捕获寄存器CCRxA/CCRxB读取(模式23)
|
||
**
|
||
**
|
||
** \param [in] enCCRSel CCRxA/CCRxB设定
|
||
**
|
||
** \retval 16bitsCCRxA/CCRxB捕获值
|
||
*****************************************************************************/
|
||
uint16_t Tim3_M23_CCR_Get(en_tim3_m23_ccrx_t enCCRSel)
|
||
{
|
||
uint16_t u16Data = 0;
|
||
|
||
if(Tim3CCR0A == enCCRSel)
|
||
{
|
||
u16Data = M0P_TIM3_MODE23->CCR0A_f.CCR0A;
|
||
}
|
||
else if(Tim3CCR0B == enCCRSel)
|
||
{
|
||
u16Data = M0P_TIM3_MODE23->CCR0B_f.CCR0B;
|
||
}
|
||
else if(Tim3CCR1A == enCCRSel)
|
||
{
|
||
u16Data = M0P_TIM3_MODE23->CCR1A_f.CCR1A;
|
||
}
|
||
else if(Tim3CCR1B == enCCRSel)
|
||
{
|
||
u16Data = M0P_TIM3_MODE23->CCR1B_f.CCR1B;
|
||
}
|
||
else if(Tim3CCR2A == enCCRSel)
|
||
{
|
||
u16Data = M0P_TIM3_MODE23->CCR2A_f.CCR2A;
|
||
}
|
||
else if(Tim3CCR2B == enCCRSel)
|
||
{
|
||
u16Data = M0P_TIM3_MODE23->CCR2B_f.CCR2B;
|
||
}
|
||
else
|
||
{
|
||
u16Data = 0;
|
||
}
|
||
|
||
return u16Data;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 PWM互补输出模式下,GATE功能选择(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_GateFuncSel(stc_tim3_m23_gate_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.CSG = pstcCfg->enGateFuncSel;
|
||
M0P_TIM3_MODE23->M23CR_f.CRG = pstcCfg->bGateRiseCap;
|
||
M0P_TIM3_MODE23->M23CR_f.CFG = pstcCfg->bGateFallCap;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 主从模式配置(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_MasterSlave_Set(stc_tim3_m23_master_slave_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->MSCR_f.MSM = pstcCfg->enMasterSlaveSel;
|
||
M0P_TIM3_MODE23->MSCR_f.MMS = pstcCfg->enMasterSrc;
|
||
M0P_TIM3_MODE23->MSCR_f.SMS = pstcCfg->enSlaveModeSel;
|
||
M0P_TIM3_MODE23->MSCR_f.TS = pstcCfg->enTsSel;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 CHxA/CHxB比较通道控制(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
** \param [in] enTim3Chx Timer3通道(Tim3CH0, Tim3CH1, Tim3CH2)
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_PortOutput_Cfg(en_tim3_channel_t enTim3Chx, stc_tim3_m23_compare_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
switch (enTim3Chx)
|
||
{
|
||
case Tim3CH0:
|
||
M0P_TIM3_MODE23->CRCH0_f.CSA = 0;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMA0_FLTA0 = pstcCfg->enCHxACmpCtrl;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPA0 = pstcCfg->enCHxAPolarity;
|
||
M0P_TIM3_MODE23->CRCH0_f.BUFEA = pstcCfg->bCHxACmpBufEn;
|
||
M0P_TIM3_MODE23->M23CR_f.CIS = pstcCfg->enCHxACmpIntSel;
|
||
|
||
M0P_TIM3_MODE23->CRCH0_f.CSB = 0;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMB0_FLTB0 = pstcCfg->enCHxBCmpCtrl;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPB0 = pstcCfg->enCHxBPolarity;
|
||
M0P_TIM3_MODE23->CRCH0_f.BUFEB = pstcCfg->bCHxBCmpBufEn;
|
||
M0P_TIM3_MODE23->CRCH0_f.CISB = pstcCfg->enCHxBCmpIntSel;
|
||
break;
|
||
case Tim3CH1:
|
||
M0P_TIM3_MODE23->CRCH1_f.CSA = 0;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMA1_FLTA1 = pstcCfg->enCHxACmpCtrl;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPA1 = pstcCfg->enCHxAPolarity;
|
||
M0P_TIM3_MODE23->CRCH1_f.BUFEA = pstcCfg->bCHxACmpBufEn;
|
||
M0P_TIM3_MODE23->M23CR_f.CIS = pstcCfg->enCHxACmpIntSel;
|
||
|
||
M0P_TIM3_MODE23->CRCH1_f.CSB = 0;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMB1_FLTB1 = pstcCfg->enCHxBCmpCtrl;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPB1 = pstcCfg->enCHxBPolarity;
|
||
M0P_TIM3_MODE23->CRCH1_f.BUFEB = pstcCfg->bCHxBCmpBufEn;
|
||
M0P_TIM3_MODE23->CRCH1_f.CISB = pstcCfg->enCHxBCmpIntSel;
|
||
break;
|
||
case Tim3CH2:
|
||
M0P_TIM3_MODE23->CRCH2_f.CSA = 0;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMA2_FLTA2 = pstcCfg->enCHxACmpCtrl;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPA2 = pstcCfg->enCHxAPolarity;
|
||
M0P_TIM3_MODE23->CRCH2_f.BUFEA = pstcCfg->bCHxACmpBufEn;
|
||
M0P_TIM3_MODE23->M23CR_f.CIS = pstcCfg->enCHxACmpIntSel;
|
||
|
||
M0P_TIM3_MODE23->CRCH2_f.CSB = 0;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMB2_FLTB2 = pstcCfg->enCHxBCmpCtrl;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPB2 = pstcCfg->enCHxBPolarity;
|
||
M0P_TIM3_MODE23->CRCH2_f.BUFEB = pstcCfg->bCHxBCmpBufEn;
|
||
M0P_TIM3_MODE23->CRCH2_f.CISB = pstcCfg->enCHxBCmpIntSel;
|
||
break;
|
||
default:
|
||
enResult = Error;
|
||
break;
|
||
}
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 CHxA/CHxB输入控制(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
** \param [in] enTim3Chx Timer3通道(Tim3CH0, Tim3CH1, Tim3CH2)
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_PortInput_Cfg(en_tim3_channel_t enTim3Chx, stc_tim3_m23_input_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
switch (enTim3Chx)
|
||
{
|
||
case Tim3CH0:
|
||
M0P_TIM3_MODE23->CRCH0_f.CSA = 1;
|
||
M0P_TIM3_MODE23->CRCH0_f.CFA_CRA_BKSA = pstcCfg->enCHxACapSel;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMA0_FLTA0 = pstcCfg->enCHxAInFlt;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPA0 = pstcCfg->enCHxAPolarity;
|
||
|
||
M0P_TIM3_MODE23->CRCH0_f.CSB = 1;
|
||
M0P_TIM3_MODE23->CRCH0_f.CFB_CRB_BKSB = pstcCfg->enCHxBCapSel;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMB0_FLTB0 = pstcCfg->enCHxBInFlt;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPB0 = pstcCfg->enCHxBPolarity;
|
||
break;
|
||
case Tim3CH1:
|
||
M0P_TIM3_MODE23->CRCH1_f.CSA = 1;
|
||
M0P_TIM3_MODE23->CRCH1_f.CFA_CRA_BKSA = pstcCfg->enCHxACapSel;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMA1_FLTA1 = pstcCfg->enCHxAInFlt;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPA1 = pstcCfg->enCHxAPolarity;
|
||
|
||
M0P_TIM3_MODE23->CRCH1_f.CSB = 1;
|
||
M0P_TIM3_MODE23->CRCH1_f.CFB_CRB_BKSB = pstcCfg->enCHxBCapSel;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMB1_FLTB1 = pstcCfg->enCHxBInFlt;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPB1 = pstcCfg->enCHxBPolarity;
|
||
break;
|
||
case Tim3CH2:
|
||
M0P_TIM3_MODE23->CRCH2_f.CSA = 1;
|
||
M0P_TIM3_MODE23->CRCH2_f.CFA_CRA_BKSA = pstcCfg->enCHxACapSel;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMA2_FLTA2 = pstcCfg->enCHxAInFlt;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPA2 = pstcCfg->enCHxAPolarity;
|
||
|
||
M0P_TIM3_MODE23->CRCH2_f.CSB = 1;
|
||
M0P_TIM3_MODE23->CRCH2_f.CFB_CRB_BKSB = pstcCfg->enCHxBCapSel;
|
||
M0P_TIM3_MODE23->FLTR_f.OCMB2_FLTB2 = pstcCfg->enCHxBInFlt;
|
||
M0P_TIM3_MODE23->FLTR_f.CCPB2 = pstcCfg->enCHxBPolarity;
|
||
break;
|
||
default:
|
||
enResult = Error;
|
||
break;
|
||
}
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 ERT输入控制(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_ETRInput_Cfg(stc_tim3_m23_etr_input_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->FLTR_f.ETP = pstcCfg->enETRPolarity;
|
||
M0P_TIM3_MODE23->FLTR_f.FLTET = pstcCfg->enETRFlt;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 刹车BK输入控制(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcBkCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_BrakeInput_Cfg(stc_tim3_m23_bk_input_cfg_t* pstcBkCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->DTR_f.BKE = pstcBkCfg->bEnBrake;
|
||
M0P_TIM3_MODE23->DTR_f.VCE = pstcBkCfg->bEnVCBrake;
|
||
M0P_TIM3_MODE23->DTR_f.SAFEEN = pstcBkCfg->bEnSafetyBk;
|
||
M0P_TIM3_MODE23->DTR_f.BKSEL = pstcBkCfg->bEnBKSync;
|
||
M0P_TIM3_MODE23->CRCH0_f.CFA_CRA_BKSA = pstcBkCfg->enBkCH0AStat;
|
||
M0P_TIM3_MODE23->CRCH0_f.CFB_CRB_BKSB = pstcBkCfg->enBkCH0BStat;
|
||
M0P_TIM3_MODE23->CRCH1_f.CFA_CRA_BKSA = pstcBkCfg->enBkCH1AStat;
|
||
M0P_TIM3_MODE23->CRCH1_f.CFB_CRB_BKSB = pstcBkCfg->enBkCH1BStat;
|
||
M0P_TIM3_MODE23->CRCH2_f.CFA_CRA_BKSA = pstcBkCfg->enBkCH2AStat;
|
||
M0P_TIM3_MODE23->CRCH2_f.CFB_CRB_BKSB = pstcBkCfg->enBkCH2BStat;
|
||
M0P_TIM3_MODE23->FLTR_f.BKP = pstcBkCfg->enBrakePolarity;
|
||
M0P_TIM3_MODE23->FLTR_f.FLTBK = pstcBkCfg->enBrakeFlt;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Base Timer3 触发ADC控制(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_TrigADC_Cfg(stc_tim3_m23_adc_trig_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->ADTR_f.ADTE = pstcCfg->bEnTrigADC;
|
||
M0P_TIM3_MODE23->ADTR_f.UEVE = pstcCfg->bEnUevTrigADC;
|
||
M0P_TIM3_MODE23->ADTR_f.CMA0E = pstcCfg->bEnCH0ACmpTrigADC;
|
||
M0P_TIM3_MODE23->ADTR_f.CMB0E = pstcCfg->bEnCH0BCmpTrigADC;
|
||
M0P_TIM3_MODE23->ADTR_f.CMA1E = pstcCfg->bEnCH1ACmpTrigADC;
|
||
M0P_TIM3_MODE23->ADTR_f.CMB1E = pstcCfg->bEnCH1BCmpTrigADC;
|
||
M0P_TIM3_MODE23->ADTR_f.CMA2E = pstcCfg->bEnCH2ACmpTrigADC;
|
||
M0P_TIM3_MODE23->ADTR_f.CMB2E = pstcCfg->bEnCH2BCmpTrigADC;
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 死区功能(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_DT_Cfg(stc_tim3_m23_dt_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->DTR_f.DTEN = pstcCfg->bEnDeadTime;
|
||
M0P_TIM3_MODE23->DTR_f.DTR = pstcCfg->u8DeadTimeValue;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 重复周期设置(模式23)
|
||
**
|
||
**
|
||
** \param [in] u8ValidPeriod 重复周期值
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_SetValidPeriod(uint8_t u8ValidPeriod)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->RCR_f.RCR = u8ValidPeriod;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 OCREF清除功能(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_OCRefClr(stc_tim3_m23_OCREF_Clr_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.OCCS = pstcCfg->enOCRefClrSrcSel;
|
||
M0P_TIM3_MODE23->M23CR_f.OCCE = pstcCfg->bVCClrEn;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 使能DMA传输(模式23)
|
||
**
|
||
**
|
||
** \param [in] pstcCfg 初始化配置结构体指针
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_EnDMA(stc_tim3_m23_trig_dma_cfg_t* pstcCfg)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.UDE = pstcCfg->bUevTrigDMA;
|
||
M0P_TIM3_MODE23->M23CR_f.TDE = pstcCfg->bTITrigDMA;
|
||
M0P_TIM3_MODE23->CRCH0_f.CDEA = pstcCfg->bCmpA0TrigDMA;
|
||
M0P_TIM3_MODE23->CRCH0_f.CDEB = pstcCfg->bCmpB0TrigDMA;
|
||
M0P_TIM3_MODE23->CRCH1_f.CDEA = pstcCfg->bCmpA1TrigDMA;
|
||
M0P_TIM3_MODE23->CRCH1_f.CDEB = pstcCfg->bCmpB1TrigDMA;
|
||
M0P_TIM3_MODE23->CRCH2_f.CDEA = pstcCfg->bCmpA2TrigDMA;
|
||
M0P_TIM3_MODE23->CRCH2_f.CDEB = pstcCfg->bCmpB2TrigDMA;
|
||
M0P_TIM3_MODE23->MSCR_f.CCDS = pstcCfg->enCmpUevTrigDMA;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 捕获比较A软件触发(模式23)
|
||
**
|
||
**
|
||
** \param [in] enTim3Chx Timer3通道(Tim3CH0, Tim3CH1, Tim3CH2)
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_EnSwTrigCapCmpA(en_tim3_channel_t enTim3Chx)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
if(Tim3CH0 == enTim3Chx)
|
||
{
|
||
M0P_TIM3_MODE23->CRCH0_f.CCGA = TRUE;
|
||
}
|
||
else if(Tim3CH1 == enTim3Chx)
|
||
{
|
||
M0P_TIM3_MODE23->CRCH1_f.CCGA = TRUE;
|
||
}
|
||
else if(Tim3CH2 == enTim3Chx)
|
||
{
|
||
M0P_TIM3_MODE23->CRCH2_f.CCGA = TRUE;
|
||
}
|
||
else
|
||
{
|
||
enResult = Error;
|
||
}
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 捕获比较B软件触发(模式23)
|
||
**
|
||
**
|
||
** \param [in] enTim3Chx Timer3通道(Tim3CH0, Tim3CH1, Tim3CH2)
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_EnSwTrigCapCmpB(en_tim3_channel_t enTim3Chx)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
if(Tim3CH0 == enTim3Chx)
|
||
{
|
||
M0P_TIM3_MODE23->CRCH0_f.CCGB = TRUE;
|
||
}
|
||
else if(Tim3CH1 == enTim3Chx)
|
||
{
|
||
M0P_TIM3_MODE23->CRCH1_f.CCGB = TRUE;
|
||
}
|
||
else if(Tim3CH2 == enTim3Chx)
|
||
{
|
||
M0P_TIM3_MODE23->CRCH2_f.CCGB = TRUE;
|
||
}
|
||
else
|
||
{
|
||
enResult = Error;
|
||
}
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 软件更新使能(模式23)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_EnSwUev(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.UG = TRUE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 软件触发使能(模式23)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_EnSwTrig(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.TG = TRUE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
/**
|
||
*****************************************************************************
|
||
** \brief Timer3 软件刹车使能(模式23)
|
||
**
|
||
**
|
||
** \param [in] none
|
||
**
|
||
** \retval Ok or Error
|
||
*****************************************************************************/
|
||
en_result_t Tim3_M23_EnSwBk(void)
|
||
{
|
||
en_result_t enResult = Ok;
|
||
|
||
M0P_TIM3_MODE23->M23CR_f.BG = TRUE;
|
||
|
||
return enResult;
|
||
}
|
||
|
||
//@} // Tim3Group
|
||
|
||
/*******************************************************************************
|
||
* EOF (not truncated)
|
||
******************************************************************************/
|