1043 lines
41 KiB
C
1043 lines
41 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_cmp.c
|
|
**
|
|
** A detailed description is available at
|
|
** @link CmpGroup CMP @endlink
|
|
**
|
|
** - 2018-10-22 CDT First version for Device Driver Library of CMP.
|
|
**
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Include files
|
|
******************************************************************************/
|
|
#include "hc32f460_cmp.h"
|
|
#include "hc32f460_utility.h"
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \addtogroup CmpGroup
|
|
******************************************************************************/
|
|
//@{
|
|
|
|
/*******************************************************************************
|
|
* Local type definitions ('typedef')
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Local pre-processor symbols/macros ('#define')
|
|
******************************************************************************/
|
|
|
|
/*!< Parameter valid check for CMP Instances. */
|
|
#define IS_VALID_CMP(__CMPx__) \
|
|
( (M4_CMP1 == (__CMPx__)) || \
|
|
(M4_CMP2 == (__CMPx__)) || \
|
|
(M4_CMP3 == (__CMPx__)))
|
|
|
|
/*!< Parameter valid check for CMP function */
|
|
#define IS_VALID_CMP_FUNCTION(x) \
|
|
( (CmpOutput == (x)) || \
|
|
(CmpOutpuInv == (x)) || \
|
|
(CmpVcoutOutput == (x)))
|
|
|
|
/*! Parameter validity check for edge sel. */
|
|
#define IS_VALID_EDGESEL(x) \
|
|
( (CmpNoneEdge == (x)) || \
|
|
(CmpBothEdge == (x)) || \
|
|
(CmpRisingEdge == (x)) || \
|
|
(CmpFaillingEdge == (x)))
|
|
|
|
/*!< Parameter CMP FLT validity check for clock division. */
|
|
#define IS_VALID_FLTCLK_DIVISION(x) \
|
|
( (CmpNoneFlt == (x)) || \
|
|
(CmpFltPclk3Div1 == (x)) || \
|
|
(CmpFltPclk3Div2 == (x)) || \
|
|
(CmpFltPclk3Div4 == (x)) || \
|
|
(CmpFltPclk3Div8 == (x)) || \
|
|
(CmpFltPclk3Div16 == (x)) || \
|
|
(CmpFltPclk3Div32 == (x)) || \
|
|
(CmpFltPclk3Div64 == (x)))
|
|
|
|
/*!< Parameter validity check for INP4 SEL. */
|
|
#define IS_VALID_INP4SEL(x) \
|
|
( (CmpInp4None == (x)) || \
|
|
(CmpInp4PGAO == (x)) || \
|
|
(CmpInp4PGAO_BP == (x)) || \
|
|
(CmpInp4CMP1_INP4 == (x)))
|
|
|
|
/*!< Parameter validity check for INP INPUT SEL. */
|
|
#define IS_VALID_INPSEL(x) \
|
|
( (CmpInpNone == (x)) || \
|
|
(CmpInp1 == (x)) || \
|
|
(CmpInp2 == (x)) || \
|
|
(CmpInp3 == (x)) || \
|
|
(CmpInp4 == (x)) || \
|
|
(CmpInp1_Inp2 == (x)) || \
|
|
(CmpInp1_Inp3 == (x)) || \
|
|
(CmpInp2_Inp3 == (x)) || \
|
|
(CmpInp1_Inp4 == (x)) || \
|
|
(CmpInp2_Inp4 == (x)) || \
|
|
(CmpInp3_Inp4 == (x)) || \
|
|
(CmpInp1_Inp2_Inp3 == (x)) || \
|
|
(CmpInp1_Inp2_Inp4 == (x)) || \
|
|
(CmpInp1_Inp3_Inp4 == (x)) || \
|
|
(CmpInp2_Inp3_Inp4 == (x)) || \
|
|
(CmpInp1_Inp2_Inp3_Inp4 == (x)))
|
|
|
|
/*!< Parameter validity check for INM INPUT SEL. */
|
|
#define IS_VALID_INMSEL(x) \
|
|
( (CmpInm1 == (x)) || \
|
|
(CmpInm2 == (x)) || \
|
|
(CmpInm3 == (x)) || \
|
|
(CmpInm4 == (x)) || \
|
|
(CmpInmNone == (x)))
|
|
|
|
/*!< Parameter validity check for CMP_CR channel. */
|
|
#define IS_VALID_CMP_CR_CH(x) \
|
|
( (CmpDac1 == (x)) || \
|
|
(CmpDac2 == (x)))
|
|
|
|
/*!< Parameter validity check for ADC internal reference voltage path. */
|
|
#define IS_VALID_ADC_REF_VOLT_PATH(x) \
|
|
( (CmpAdcRefVoltPathDac1 == (x)) || \
|
|
(CmpAdcRefVoltPathDac2 == (x)) || \
|
|
(CmpAdcRefVoltPathVref == (x)))
|
|
|
|
/*!< RVADC Write Protection Key. */
|
|
#define RVADC_WRITE_PROT_KEY (0x5500u)
|
|
|
|
/*!< Timer4x ECER register address. */
|
|
#define CMP_CR_DADRx(__DACx__) \
|
|
( (CmpDac1 == (__DACx__)) ? &M4_CMP_CR->DADR1 : &M4_CMP_CR->DADR2)
|
|
|
|
/*******************************************************************************
|
|
* 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 Initializes the specified CMP.
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] pstcInitCfg Pointer to CMP configure structure
|
|
** \arg This parameter detail refer @ref stc_cmp_init_t
|
|
**
|
|
** \retval Ok CMP is initialized normally
|
|
** \retval ErrorInvalidParameter If one of following cases matches:
|
|
** - CMPx is invalid
|
|
** - pstcInitCfg == NULL
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_Init(M4_CMP_TypeDef *CMPx, const stc_cmp_init_t *pstcInitCfg)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx && pstcInitCfg pointer */
|
|
if ((IS_VALID_CMP(CMPx)) && (NULL != pstcInitCfg))
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_EDGESEL(pstcInitCfg->enEdgeSel));
|
|
DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcInitCfg->enCmpIntEN));
|
|
DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcInitCfg->enCmpInvEn));
|
|
DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcInitCfg->enCmpOutputEn));
|
|
DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcInitCfg->enCmpVcoutOutputEn));
|
|
DDL_ASSERT(IS_VALID_FLTCLK_DIVISION(pstcInitCfg->enFltClkDiv));
|
|
|
|
/* De-Initialize CMP */
|
|
CMPx->CTRL = (uint16_t)0x0000u;
|
|
CMPx->VLTSEL = (uint16_t)0x0000u;
|
|
CMPx->CVSSTB = (uint16_t)0x0005u;
|
|
CMPx->CVSPRD = (uint16_t)0x000Fu;
|
|
|
|
CMPx->CTRL_f.IEN = (uint16_t)pstcInitCfg->enCmpIntEN;
|
|
CMPx->CTRL_f.INV = (uint16_t)pstcInitCfg->enCmpInvEn;
|
|
CMPx->CTRL_f.EDGSL = (uint16_t)pstcInitCfg->enEdgeSel;
|
|
CMPx->CTRL_f.FLTSL = (uint16_t)pstcInitCfg->enFltClkDiv;
|
|
CMPx->CTRL_f.CMPOE = (uint16_t)pstcInitCfg->enCmpOutputEn;
|
|
CMPx->CTRL_f.OUTEN = (uint16_t)pstcInitCfg->enCmpVcoutOutputEn;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief De-Initialize CMP
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_DeInit(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
CMPx->CTRL = (uint16_t)0x0000u;
|
|
CMPx->VLTSEL = (uint16_t)0x0000u;
|
|
CMPx->CVSSTB = (uint16_t)0x0005u;
|
|
CMPx->CVSPRD = (uint16_t)0x000Fu;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Enable or disable CMP working
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] enCmd The CMP function state
|
|
** \arg Disable Disable CMP working
|
|
** \arg Enable Enable CMP working
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_Cmd(M4_CMP_TypeDef *CMPx, en_functional_state_t enCmd)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_FUNCTIONAL_STATE(enCmd));
|
|
|
|
CMPx->CTRL_f.CMPON = (uint16_t)(enCmd);
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Enable or disable CMP interrupt request
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] enCmd The CMP interrupt function state
|
|
** \arg Disable Disable interrupt request
|
|
** \arg Enable Enable interrupt request
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid.
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_IrqCmd(M4_CMP_TypeDef *CMPx, en_functional_state_t enCmd)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
CMPx->CTRL_f.IEN = (uint16_t)(enCmd);
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set scan time(scan stable&&period)
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] u8ScanStable CMP scan stable value
|
|
** \arg u8ScanStable < 16
|
|
** \param [in] u8ScanPeriod CMP scan period value
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
** \note u8ScanStable && u8ScanPeriod value must meet following condition:
|
|
** u8ScanPeriod > u8ScanStable + FLTSL_DIV*4 + 5
|
|
** FLTSL_DIV is filter sample period division(refer CMPx->CTRL_f.FLTSL)
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_SetScanTime(M4_CMP_TypeDef *CMPx,
|
|
uint8_t u8ScanStable,
|
|
uint8_t u8ScanPeriod)
|
|
{
|
|
uint16_t u16Flts;
|
|
uint16_t u16FltslDiv;
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if ((!IS_VALID_CMP(CMPx)) || (u8ScanStable & 0xF0u))
|
|
{
|
|
enRet = ErrorInvalidParameter;
|
|
}
|
|
else
|
|
{
|
|
u16Flts = CMPx->CTRL_f.FLTSL;
|
|
u16FltslDiv = ((uint16_t)1u << (u16Flts - 1u));
|
|
|
|
if ((0u != u16Flts) &&
|
|
(u8ScanPeriod <= (u8ScanStable + u16FltslDiv * 4u + 5u)))
|
|
{
|
|
enRet = ErrorInvalidParameter;
|
|
}
|
|
else
|
|
{
|
|
CMPx->CVSSTB_f.STB = u8ScanStable;
|
|
CMPx->CVSPRD_f.PRD = u8ScanPeriod;
|
|
}
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Enable or disable the specified CMP function.
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] enFunc CMP function selection
|
|
** \arg CmpVcoutOutput CMP Vcout output enable function
|
|
** \arg CmpOutpuInv CMP output invert enable function
|
|
** \arg CmpOutput CMP output enable function
|
|
** \param [in] enCmd CMP functional state
|
|
** \arg Enable Enable the specified CMP function
|
|
** \arg Disable Disable the specified CMP function
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_FuncCmd(M4_CMP_TypeDef *CMPx,
|
|
en_cmp_func_t enFunc,
|
|
en_functional_state_t enCmd)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_FUNCTIONAL_STATE(enCmd));
|
|
DDL_ASSERT(IS_VALID_CMP_FUNCTION(enFunc));
|
|
|
|
if (Enable == enCmd)
|
|
{
|
|
CMPx->CTRL |= (uint16_t)enFunc;
|
|
}
|
|
else
|
|
{
|
|
CMPx->CTRL &= (uint16_t)(~((uint16_t)enFunc));
|
|
}
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Start CMP scan
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval Ok Start successfully
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_StartScan(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
CMPx->CTRL_f.CVSEN = (uint16_t)1u;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Stop CMP scan
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval Ok Stop successfully
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_StopScan(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
CMPx->CTRL_f.CVSEN = (uint16_t)0u;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set CMP filter sample clock division.
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] enFltClkDiv The CMP filter sample clock division selection
|
|
** \arg CmpNoneFlt Unuse filter
|
|
** \arg CmpFltPclk3Div1 PCLK3/1
|
|
** \arg CmpFltPclk3Div2 PCLK3/2
|
|
** \arg CmpFltPclk3Div4 PCLK3/4
|
|
** \arg CmpFltPclk3Div8 PCLK3/8
|
|
** \arg CmpFltPclk3Div16 PCLK3/16
|
|
** \arg CmpFltPclk3Div32 PCLK3/32
|
|
** \arg CmpFltPclk3Div64 PCLK3/64
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_SetFilterClkDiv(M4_CMP_TypeDef *CMPx,
|
|
en_cmp_fltclk_div_t enFltClkDiv)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_FLTCLK_DIVISION(enFltClkDiv));
|
|
CMPx->CTRL_f.FLTSL = (uint16_t)enFltClkDiv;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Get CMP filter sample clock division.
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval CmpNoneFlt Unuse filter
|
|
** \retval CmpFltPclk3Div1 PCLK3/1
|
|
** \retval CmpFltPclk3Div2 PCLK3/2
|
|
** \retval CmpFltPclk3Div4 PCLK3/4
|
|
** \retval CmpFltPclk3Div8 PCLK3/8
|
|
** \retval CmpFltPclk3Div16 PCLK3/16
|
|
** \retval CmpFltPclk3Div32 PCLK3/32
|
|
** \retval CmpFltPclk3Div64 PCLK3/64
|
|
**
|
|
******************************************************************************/
|
|
en_cmp_fltclk_div_t CMP_GetFilterClkDiv(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_CMP(CMPx));
|
|
|
|
return (en_cmp_fltclk_div_t)CMPx->CTRL_f.FLTSL;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set CMP detection edge selection.
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] enEdgeSel The CMP detection edge selection
|
|
** \arg CmpNoneEdge None edge detection
|
|
** \arg CmpRisingEdge Rising edge detection
|
|
** \arg CmpFaillingEdge Falling edge detection
|
|
** \arg CmpBothEdge Falling or Rising edge detection
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_SetEdgeSel(M4_CMP_TypeDef *CMPx,
|
|
en_cmp_edge_sel_t enEdgeSel)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_EDGESEL(enEdgeSel));
|
|
CMPx->CTRL_f.EDGSL = (uint16_t)enEdgeSel;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Get CMP detection edge selection.
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval CmpNoneEdge None edge detection
|
|
** \retval CmpRisingEdge Rising edge detection
|
|
** \retval CmpFaillingEdge Falling edge detection
|
|
** \retval CmpBothEdge Falling or Rising edge detection
|
|
**
|
|
******************************************************************************/
|
|
en_cmp_edge_sel_t CMP_GetEdgeSel(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_CMP(CMPx));
|
|
|
|
return (en_cmp_edge_sel_t)CMPx->CTRL_f.EDGSL;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set CMP input sel
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] pstcInputSel The CMP input selection structure
|
|
** \arg This parameter detail refer @ref stc_cmp_input_sel_t
|
|
**
|
|
** \retval Ok Set successfully
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_InputSel(M4_CMP_TypeDef *CMPx,
|
|
const stc_cmp_input_sel_t *pstcInputSel)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx && pstcInputSel pointer */
|
|
if ((IS_VALID_CMP(CMPx)) && (NULL != pstcInputSel))
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_INMSEL(pstcInputSel->enInmSel));
|
|
DDL_ASSERT(IS_VALID_INPSEL(pstcInputSel->enInpSel));
|
|
DDL_ASSERT(IS_VALID_INP4SEL(pstcInputSel->enInp4Sel));
|
|
|
|
if ((CmpInp4PGAO == pstcInputSel->enInp4Sel) ||
|
|
(CmpInp4PGAO_BP == pstcInputSel->enInp4Sel))
|
|
{
|
|
if (M4_CMP3 != CMPx)
|
|
{
|
|
enRet = Ok;
|
|
}
|
|
}
|
|
else if (CmpInp4CMP1_INP4 == pstcInputSel->enInp4Sel)
|
|
{
|
|
if (M4_CMP1 == CMPx)
|
|
{
|
|
enRet = Ok;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
enRet = Ok;
|
|
}
|
|
|
|
if (enRet == Ok)
|
|
{
|
|
CMPx->VLTSEL_f.CVSL = (uint16_t)pstcInputSel->enInpSel;
|
|
CMPx->VLTSEL_f.RVSL = (uint16_t)pstcInputSel->enInmSel;
|
|
CMPx->VLTSEL_f.C4SL = (uint16_t)pstcInputSel->enInp4Sel;
|
|
}
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set CMP INP input selection
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] enInputSel The INP input selection
|
|
** \arg CmpInpNone None input
|
|
** \arg CmpInp1 INP1 input
|
|
** \arg CmpInp2 INP2 input
|
|
** \arg CmpInp1_Inp2 INP1 INP2 input
|
|
** \arg CmpInp3 INP3 input
|
|
** \arg CmpInp1_Inp3 INP1 INP3 input
|
|
** \arg CmpInp2_Inp3 INP2 INP3 input
|
|
** \arg CmpInp1_Inp2_Inp3 INP1 INP2 INP3 input
|
|
** \arg CmpInp4 INP4 input
|
|
** \arg CmpInp1_Inp4 INP1 INP4 input
|
|
** \arg CmpInp2_Inp4 INP2 INP4 input
|
|
** \arg CmpInp1_Inp2_Inp4 INP1 INP2 INP4 input
|
|
** \arg CmpInp3_Inp4 INP3 INP4 input
|
|
** \arg CmpInp1_Inp3_Inp4 INP1 INP3 INP4 input
|
|
** \arg CmpInp2_Inp3_Inp4 INP2 INP3 INP4 input
|
|
** \arg CmpInp1_Inp2_Inp3_Inp4 INP1 INP2 INP3 INP4 input
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_SetInp(M4_CMP_TypeDef *CMPx, en_cmp_inp_sel_t enInputSel)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_INPSEL(enInputSel));
|
|
CMPx->VLTSEL_f.CVSL = (uint16_t)enInputSel;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set CMP INP input selection
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval CmpInpNone None input
|
|
** \retval CmpInp1 INP1 input
|
|
** \retval CmpInp2 INP2 input
|
|
** \retval CmpInp1_Inp2 INP1 INP2 input
|
|
** \retval CmpInp3 INP3 input
|
|
** \retval CmpInp1_Inp3 INP1 INP3 input
|
|
** \retval CmpInp2_Inp3 INP2 INP3 input
|
|
** \retval CmpInp1_Inp2_Inp3 INP1 INP2 INP3 input
|
|
** \retval CmpInp4 INP4 input
|
|
** \retval CmpInp1_Inp4 INP1 INP4 input
|
|
** \retval CmpInp2_Inp4 INP2 INP4 input
|
|
** \retval CmpInp1_Inp2_Inp4 INP1 INP2 INP4 input
|
|
** \retval CmpInp3_Inp4 INP3 INP4 input
|
|
** \retval CmpInp1_Inp3_Inp4 INP1 INP3 INP4 input
|
|
** \retval CmpInp2_Inp3_Inp4 INP2 INP3 INP4 input
|
|
** \retval CmpInp1_Inp2_Inp3_Inp4 INP1 INP2 INP3 INP4 input
|
|
**
|
|
******************************************************************************/
|
|
en_cmp_inp_sel_t CMP_GetInp(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_CMP(CMPx));
|
|
|
|
return (en_cmp_inp_sel_t)CMPx->VLTSEL_f.CVSL;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set CMP INM input selection
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] enInputSel The INP input selection
|
|
** \arg CmpInmNone None input
|
|
** \arg CmpInm1 INM1 input
|
|
** \arg CmpInm2 INM2 input
|
|
** \arg CmpInm3 INM3 input
|
|
** \arg CmpInm4 INM4 input
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid.
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_SetInm(M4_CMP_TypeDef *CMPx, en_cmp_inm_sel_t enInputSel)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_INMSEL(enInputSel));
|
|
CMPx->VLTSEL_f.RVSL = (uint16_t)enInputSel;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Get CMP INM input selection
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval CmpInmNone None input
|
|
** \retval CmpInm1 INM1 input
|
|
** \retval CmpInm2 INM2 input
|
|
** \retval CmpInm3 INM3 input
|
|
** \retval CmpInm4 INM4 input
|
|
**
|
|
******************************************************************************/
|
|
en_cmp_inm_sel_t CMP_GetInm(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_CMP(CMPx));
|
|
|
|
return (en_cmp_inm_sel_t)CMPx->VLTSEL_f.RVSL;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set CMP INP4 input selection
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
** \param [in] enInputSel The INP input selection
|
|
** \arg CmpInp4None None input
|
|
** \arg CmpInp4PGAO PGAO output
|
|
** \arg CmpInp4PGAO_BP PGAO_BP output
|
|
** \arg CmpInp4CMP1_INP4 CMP1_INP4
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter CMPx is invalid.
|
|
**
|
|
** \note Inp4 Selection is valid only for M4_CMP1
|
|
** and M4_CMP2.
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_SetInp4(M4_CMP_TypeDef *CMPx,en_cmp_inp4_sel_t enInputSel)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check parameter */
|
|
DDL_ASSERT(M4_CMP3 != CMPx);
|
|
DDL_ASSERT(IS_VALID_INP4SEL(enInputSel));
|
|
|
|
/* Check CMPx pointer */
|
|
if (IS_VALID_CMP(CMPx))
|
|
{
|
|
CMPx->VLTSEL_f.C4SL = (uint16_t)enInputSel;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Get CMP INP4 input selection
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval CmpInp4None None input
|
|
** \retval CmpInp4PGAO PGAO output
|
|
** \retval CmpInp4PGAO_BP PGAO_BP output
|
|
** \retval CmpInp4CMP1_INP4 CMP1_INP4
|
|
**
|
|
** \note Inp4 Selection is valid only for M4_CMP1
|
|
** and M4_CMP2.
|
|
**
|
|
******************************************************************************/
|
|
en_cmp_inp4_sel_t CMP_GetInp4(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_CMP(CMPx));
|
|
|
|
return (en_cmp_inp4_sel_t)CMPx->VLTSEL_f.C4SL;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Get CMP output state
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval CmpOutputLow Compare output Low "0"
|
|
** \retval CmpOutputHigh Compare output High "1"
|
|
**
|
|
******************************************************************************/
|
|
en_cmp_output_state_t CMP_GetOutputState(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_CMP(CMPx));
|
|
|
|
return (en_cmp_output_state_t)(CMPx->OUTMON_f.OMON);
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Get CMP INP state
|
|
**
|
|
** \param [in] CMPx Pointer to CMP instance register base
|
|
** \arg M4_CMP1 CMP unit 1 instance register base
|
|
** \arg M4_CMP2 CMP unit 2 instance register base
|
|
** \arg M4_CMP3 CMP unit 3 instance register base
|
|
**
|
|
** \retval CmpOutputLow Compare output Low "0"
|
|
** \retval CmpOutputHigh Compare output High "1"
|
|
**
|
|
******************************************************************************/
|
|
en_cmp_inp_state_t CMP_GetInpState(M4_CMP_TypeDef *CMPx)
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_CMP(CMPx));
|
|
|
|
return (en_cmp_inp_state_t)(CMPx->OUTMON_f.CVST);
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Initialize CMP DAC
|
|
**
|
|
** \param [in] enCh CMP DAC channel
|
|
** \arg CmpDac1 CMP CR DAC channel: DAC1
|
|
** \arg CmpDac2 CMP CR DAC channel: DAC2
|
|
** \param [in] pstcInitCfg Pointer to CMP DAC configure structure
|
|
** \arg This parameter detail refer @ref stc_cmp_dac_init_t
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter enCh is invalid.
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_DAC_Init(en_cmp_dac_ch_t enCh,
|
|
const stc_cmp_dac_init_t *pstcInitCfg)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
if ((IS_VALID_CMP_CR_CH(enCh)) && (pstcInitCfg != NULL))
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_FUNCTIONAL_STATE(pstcInitCfg->enCmpDacEN));
|
|
|
|
M4_CMP_CR->DACR &= (uint16_t)(~(1ul << enCh)); /* Disable DAC */
|
|
|
|
*(__IO uint8_t *)CMP_CR_DADRx(enCh) = pstcInitCfg->u8DacData; /* Set DAC data */
|
|
|
|
if (Enable == pstcInitCfg->enCmpDacEN)
|
|
{
|
|
M4_CMP_CR->DACR |= (uint16_t)(1ul << enCh); /* Enable DAC */
|
|
}
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief De-Initialize CMP DAC
|
|
**
|
|
** \param [in] enCh CMP DAC channel
|
|
** \arg CmpDac1 CMP CR DAC channel: DAC1
|
|
** \arg CmpDac2 CMP CR DAC channel: DAC2
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter enCh is invalid.
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_DAC_DeInit(en_cmp_dac_ch_t enCh)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check parameter */
|
|
if (IS_VALID_CMP_CR_CH(enCh))
|
|
{
|
|
M4_CMP_CR->DACR &= (uint16_t)(~(1ul << enCh));
|
|
*(__IO uint8_t *)CMP_CR_DADRx(enCh) = 0u;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Enable or disable CMP DAC working
|
|
**
|
|
** \param [in] enCh CMP DAC channel
|
|
** \arg CmpDac1 CMP DAC channel: DAC1
|
|
** \arg CmpDac2 CMP DAC channel: DAC2
|
|
** \param [in] enCmd The CMP DAC function state
|
|
** \arg Disable Disable CMP DAC working
|
|
** \arg Enable Enable CMP DAC working
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter enCh is invalid.
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_DAC_Cmd(en_cmp_dac_ch_t enCh, en_functional_state_t enCmd)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check parameter */
|
|
if (IS_VALID_CMP_CR_CH(enCh))
|
|
{
|
|
if(Enable == enCmd)
|
|
{
|
|
M4_CMP_CR->DACR |= (uint16_t)(1ul << enCh);
|
|
}
|
|
else
|
|
{
|
|
M4_CMP_CR->DACR &= (uint16_t)(~(1ul << enCh));
|
|
}
|
|
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set DAC data register value
|
|
**
|
|
** \param [in] enCh CMP DAC channel
|
|
** \arg CmpDac1 CMP CR DAC channel: DAC1
|
|
** \arg CmpDac2 CMP CR DAC channel: DAC2
|
|
** \param [in] u8DacData DAC data register value
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter enCh is invalid.
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_DAC_SetData(en_cmp_dac_ch_t enCh, uint8_t u8DacData)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check parameter */
|
|
if (IS_VALID_CMP_CR_CH(enCh))
|
|
{
|
|
*(__IO uint8_t *)CMP_CR_DADRx(enCh) = u8DacData;
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Get DAC data register value
|
|
**
|
|
** \param [in] enCh CMP DAC channel
|
|
** \arg CmpDac1 CMP CR DAC channel: DAC1
|
|
** \arg CmpDac2 CMP CR DAC channel: DAC2
|
|
**
|
|
** \retval DAC data register value
|
|
**
|
|
******************************************************************************/
|
|
uint8_t CMP_DAC_GetData(en_cmp_dac_ch_t enCh)
|
|
{
|
|
/* Check parameter */
|
|
DDL_ASSERT(IS_VALID_CMP_CR_CH(enCh));
|
|
|
|
return *(__IO uint8_t *)CMP_CR_DADRx(enCh);
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Set ADC internal reference voltage path
|
|
**
|
|
** \param [in] enRefVoltPath ADC internal reference voltage path
|
|
** \arg CmpAdcRefVoltPathDac1 ADC internal reference voltage path: DAC1
|
|
** \arg CmpAdcRefVoltPathDac2 ADC internal reference voltage path: DAC2
|
|
** \arg CmpAdcRefVoltPathVref ADC internal reference voltage path: VREF
|
|
**
|
|
** \retval Ok Set successfully.
|
|
** \retval ErrorInvalidParameter enRefVoltPath is invalid.
|
|
**
|
|
******************************************************************************/
|
|
en_result_t CMP_ADC_SetRefVoltPath(en_cmp_adc_int_ref_volt_path_t enRefVoltPath)
|
|
{
|
|
en_result_t enRet = ErrorInvalidParameter;
|
|
|
|
/* Check parameter */
|
|
if (IS_VALID_ADC_REF_VOLT_PATH(enRefVoltPath))
|
|
{
|
|
M4_CMP_CR->RVADC = RVADC_WRITE_PROT_KEY; /* Release write protection */
|
|
M4_CMP_CR->RVADC = enRefVoltPath; /* Set reference voltage path */
|
|
enRet = Ok;
|
|
}
|
|
|
|
return enRet;
|
|
}
|
|
|
|
//@} // CmpGroup
|
|
|
|
/*******************************************************************************
|
|
* EOF (not truncated)
|
|
******************************************************************************/
|