| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210 |
- /********************************** (C) COPYRIGHT *******************************
- * File Name : ch32v20x_adc.c
- * Author : WCH
- * Version : V1.0.0
- * Date : 2021/06/06
- * Description : This file provides all the ADC firmware functions.
- *********************************************************************************
- * Copyright (c) 2021 Nanjing Qinheng Microelectronics Co., Ltd.
- * Attention: This software (modified or not) and binary are used for
- * microcontroller manufactured by Nanjing Qinheng Microelectronics.
- *******************************************************************************/
- #include "ch32v20x_adc.h"
- #include "ch32v20x_rcc.h"
- /* ADC DISCNUM mask */
- #define CTLR1_DISCNUM_Reset ((uint32_t)0xFFFF1FFF)
- /* ADC DISCEN mask */
- #define CTLR1_DISCEN_Set ((uint32_t)0x00000800)
- #define CTLR1_DISCEN_Reset ((uint32_t)0xFFFFF7FF)
- /* ADC JAUTO mask */
- #define CTLR1_JAUTO_Set ((uint32_t)0x00000400)
- #define CTLR1_JAUTO_Reset ((uint32_t)0xFFFFFBFF)
- /* ADC JDISCEN mask */
- #define CTLR1_JDISCEN_Set ((uint32_t)0x00001000)
- #define CTLR1_JDISCEN_Reset ((uint32_t)0xFFFFEFFF)
- /* ADC AWDCH mask */
- #define CTLR1_AWDCH_Reset ((uint32_t)0xFFFFFFE0)
- /* ADC Analog watchdog enable mode mask */
- #define CTLR1_AWDMode_Reset ((uint32_t)0xFF3FFDFF)
- /* CTLR1 register Mask */
- #define CTLR1_CLEAR_Mask ((uint32_t)0xE0F0FEFF)
- /* ADC ADON mask */
- #define CTLR2_ADON_Set ((uint32_t)0x00000001)
- #define CTLR2_ADON_Reset ((uint32_t)0xFFFFFFFE)
- /* ADC DMA mask */
- #define CTLR2_DMA_Set ((uint32_t)0x00000100)
- #define CTLR2_DMA_Reset ((uint32_t)0xFFFFFEFF)
- /* ADC RSTCAL mask */
- #define CTLR2_RSTCAL_Set ((uint32_t)0x00000008)
- /* ADC CAL mask */
- #define CTLR2_CAL_Set ((uint32_t)0x00000004)
- /* ADC SWSTART mask */
- #define CTLR2_SWSTART_Set ((uint32_t)0x00400000)
- /* ADC EXTTRIG mask */
- #define CTLR2_EXTTRIG_Set ((uint32_t)0x00100000)
- #define CTLR2_EXTTRIG_Reset ((uint32_t)0xFFEFFFFF)
- /* ADC Software start mask */
- #define CTLR2_EXTTRIG_SWSTART_Set ((uint32_t)0x00500000)
- #define CTLR2_EXTTRIG_SWSTART_Reset ((uint32_t)0xFFAFFFFF)
- /* ADC JEXTSEL mask */
- #define CTLR2_JEXTSEL_Reset ((uint32_t)0xFFFF8FFF)
- /* ADC JEXTTRIG mask */
- #define CTLR2_JEXTTRIG_Set ((uint32_t)0x00008000)
- #define CTLR2_JEXTTRIG_Reset ((uint32_t)0xFFFF7FFF)
- /* ADC JSWSTART mask */
- #define CTLR2_JSWSTART_Set ((uint32_t)0x00200000)
- /* ADC injected software start mask */
- #define CTLR2_JEXTTRIG_JSWSTART_Set ((uint32_t)0x00208000)
- #define CTLR2_JEXTTRIG_JSWSTART_Reset ((uint32_t)0xFFDF7FFF)
- /* ADC TSPD mask */
- #define CTLR2_TSVREFE_Set ((uint32_t)0x00800000)
- #define CTLR2_TSVREFE_Reset ((uint32_t)0xFF7FFFFF)
- /* CTLR2 register Mask */
- #define CTLR2_CLEAR_Mask ((uint32_t)0xFFF1F7FD)
- /* ADC SQx mask */
- #define RSQR3_SQ_Set ((uint32_t)0x0000001F)
- #define RSQR2_SQ_Set ((uint32_t)0x0000001F)
- #define RSQR1_SQ_Set ((uint32_t)0x0000001F)
- /* RSQR1 register Mask */
- #define RSQR1_CLEAR_Mask ((uint32_t)0xFF0FFFFF)
- /* ADC JSQx mask */
- #define ISQR_JSQ_Set ((uint32_t)0x0000001F)
- /* ADC JL mask */
- #define ISQR_JL_Set ((uint32_t)0x00300000)
- #define ISQR_JL_Reset ((uint32_t)0xFFCFFFFF)
- /* ADC SMPx mask */
- #define SAMPTR1_SMP_Set ((uint32_t)0x00000007)
- #define SAMPTR2_SMP_Set ((uint32_t)0x00000007)
- /* ADC IDATARx registers offset */
- #define IDATAR_Offset ((uint8_t)0x28)
- /* ADC1 RDATAR register base address */
- #define RDATAR_ADDRESS ((uint32_t)0x4001244C)
- /*********************************************************************
- * @fn ADC_DeInit
- *
- * @brief Deinitializes the ADCx peripheral registers to their default
- * reset values.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- *
- * @return none
- */
- void ADC_DeInit(ADC_TypeDef *ADCx)
- {
- if(ADCx == ADC1)
- {
- RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1, ENABLE);
- RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1, DISABLE);
- }
- else if(ADCx == ADC2)
- {
- RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC2, ENABLE);
- RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC2, DISABLE);
- }
- }
- /*********************************************************************
- * @fn ADC_Init
- *
- * @brief Initializes the ADCx peripheral according to the specified
- * parameters in the ADC_InitStruct.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_InitStruct - pointer to an ADC_InitTypeDef structure that
- * contains the configuration information for the specified ADC
- * peripheral.
- *
- * @return none
- */
- void ADC_Init(ADC_TypeDef *ADCx, ADC_InitTypeDef *ADC_InitStruct)
- {
- uint32_t tmpreg1 = 0;
- uint8_t tmpreg2 = 0;
- tmpreg1 = ADCx->CTLR1;
- tmpreg1 &= CTLR1_CLEAR_Mask;
- tmpreg1 |= (uint32_t)(ADC_InitStruct->ADC_Mode | (uint32_t)ADC_InitStruct->ADC_OutputBuffer |
- (uint32_t)ADC_InitStruct->ADC_Pga | ((uint32_t)ADC_InitStruct->ADC_ScanConvMode << 8));
- ADCx->CTLR1 = tmpreg1;
- tmpreg1 = ADCx->CTLR2;
- tmpreg1 &= CTLR2_CLEAR_Mask;
- tmpreg1 |= (uint32_t)(ADC_InitStruct->ADC_DataAlign | ADC_InitStruct->ADC_ExternalTrigConv |
- ((uint32_t)ADC_InitStruct->ADC_ContinuousConvMode << 1));
- ADCx->CTLR2 = tmpreg1;
- tmpreg1 = ADCx->RSQR1;
- tmpreg1 &= RSQR1_CLEAR_Mask;
- tmpreg2 |= (uint8_t)(ADC_InitStruct->ADC_NbrOfChannel - (uint8_t)1);
- tmpreg1 |= (uint32_t)tmpreg2 << 20;
- ADCx->RSQR1 = tmpreg1;
- }
- /*********************************************************************
- * @fn ADC_StructInit
- *
- * @brief Fills each ADC_InitStruct member with its default value.
- *
- * @param ADC_InitStruct - pointer to an ADC_InitTypeDef structure that
- * contains the configuration information for the specified ADC
- * peripheral.
- *
- * @return none
- */
- void ADC_StructInit(ADC_InitTypeDef *ADC_InitStruct)
- {
- ADC_InitStruct->ADC_Mode = ADC_Mode_Independent;
- ADC_InitStruct->ADC_ScanConvMode = DISABLE;
- ADC_InitStruct->ADC_ContinuousConvMode = DISABLE;
- ADC_InitStruct->ADC_ExternalTrigConv = ADC_ExternalTrigConv_T1_CC1;
- ADC_InitStruct->ADC_DataAlign = ADC_DataAlign_Right;
- ADC_InitStruct->ADC_NbrOfChannel = 1;
- }
- /*********************************************************************
- * @fn ADC_Cmd
- *
- * @brief Enables or disables the specified ADC peripheral.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return none
- */
- void ADC_Cmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR2 |= CTLR2_ADON_Set;
- }
- else
- {
- ADCx->CTLR2 &= CTLR2_ADON_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_DMACmd
- *
- * @brief Enables or disables the specified ADC DMA request.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return none
- */
- void ADC_DMACmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR2 |= CTLR2_DMA_Set;
- }
- else
- {
- ADCx->CTLR2 &= CTLR2_DMA_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_ITConfig
- *
- * @brief Enables or disables the specified ADC interrupts.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_IT - specifies the ADC interrupt sources to be enabled or disabled.
- * ADC_IT_EOC - End of conversion interrupt mask.
- * ADC_IT_AWD - Analog watchdog interrupt mask.
- * ADC_IT_JEOC - End of injected conversion interrupt mask.
- * NewState - ENABLE or DISABLE.
- *
- * @return none
- */
- void ADC_ITConfig(ADC_TypeDef *ADCx, uint16_t ADC_IT, FunctionalState NewState)
- {
- uint8_t itmask = 0;
- itmask = (uint8_t)ADC_IT;
- if(NewState != DISABLE)
- {
- ADCx->CTLR1 |= itmask;
- }
- else
- {
- ADCx->CTLR1 &= (~(uint32_t)itmask);
- }
- }
- /*********************************************************************
- * @fn ADC_ResetCalibration
- *
- * @brief Resets the selected ADC calibration registers.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- *
- * @return none
- */
- void ADC_ResetCalibration(ADC_TypeDef *ADCx)
- {
- ADCx->CTLR2 |= CTLR2_RSTCAL_Set;
- }
- /*********************************************************************
- * @fn ADC_GetResetCalibrationStatus
- *
- * @brief Gets the selected ADC reset calibration registers status.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- *
- * @return FlagStatus: SET or RESET.
- */
- FlagStatus ADC_GetResetCalibrationStatus(ADC_TypeDef *ADCx)
- {
- FlagStatus bitstatus = RESET;
- if((ADCx->CTLR2 & CTLR2_RSTCAL_Set) != (uint32_t)RESET)
- {
- bitstatus = SET;
- }
- else
- {
- bitstatus = RESET;
- }
- return bitstatus;
- }
- /*********************************************************************
- * @fn ADC_StartCalibration
- *
- * @brief Starts the selected ADC calibration process.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- *
- * @return None
- */
- void ADC_StartCalibration(ADC_TypeDef *ADCx)
- {
- ADCx->CTLR2 |= CTLR2_CAL_Set;
- }
- /*********************************************************************
- * @fn ADC_GetCalibrationStatus
- *
- * @brief Gets the selected ADC calibration status.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- *
- * @return FlagStatus: SET or RESET.
- */
- FlagStatus ADC_GetCalibrationStatus(ADC_TypeDef *ADCx)
- {
- FlagStatus bitstatus = RESET;
- if((ADCx->CTLR2 & CTLR2_CAL_Set) != (uint32_t)RESET)
- {
- bitstatus = SET;
- }
- else
- {
- bitstatus = RESET;
- }
- return bitstatus;
- }
- /*********************************************************************
- * @fn ADC_SoftwareStartConvCmd
- *
- * @brief Enables or disables the selected ADC software start conversion.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return None
- */
- void ADC_SoftwareStartConvCmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR2 |= CTLR2_EXTTRIG_SWSTART_Set;
- }
- else
- {
- ADCx->CTLR2 &= CTLR2_EXTTRIG_SWSTART_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_GetSoftwareStartConvStatus
- *
- * @brief Gets the selected ADC Software start conversion Status.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- *
- * @return FlagStatus - SET or RESET.
- */
- FlagStatus ADC_GetSoftwareStartConvStatus(ADC_TypeDef *ADCx)
- {
- FlagStatus bitstatus = RESET;
- if((ADCx->CTLR2 & CTLR2_SWSTART_Set) != (uint32_t)RESET)
- {
- bitstatus = SET;
- }
- else
- {
- bitstatus = RESET;
- }
- return bitstatus;
- }
- /*********************************************************************
- * @fn ADC_DiscModeChannelCountConfig
- *
- * @brief Configures the discontinuous mode for the selected ADC regular
- * group channel.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * Number - specifies the discontinuous mode regular channel
- * count value(1-8).
- *
- * @return None
- */
- void ADC_DiscModeChannelCountConfig(ADC_TypeDef *ADCx, uint8_t Number)
- {
- uint32_t tmpreg1 = 0;
- uint32_t tmpreg2 = 0;
- tmpreg1 = ADCx->CTLR1;
- tmpreg1 &= CTLR1_DISCNUM_Reset;
- tmpreg2 = Number - 1;
- tmpreg1 |= tmpreg2 << 13;
- ADCx->CTLR1 = tmpreg1;
- }
- /*********************************************************************
- * @fn ADC_DiscModeCmd
- *
- * @brief Enables or disables the discontinuous mode on regular group
- * channel for the specified ADC.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return None
- */
- void ADC_DiscModeCmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR1 |= CTLR1_DISCEN_Set;
- }
- else
- {
- ADCx->CTLR1 &= CTLR1_DISCEN_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_RegularChannelConfig
- *
- * @brief Configures for the selected ADC regular channel its corresponding
- * rank in the sequencer and its sample time.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_Channel - the ADC channel to configure.
- * ADC_Channel_0 - ADC Channel0 selected.
- * ADC_Channel_1 - ADC Channel1 selected.
- * ADC_Channel_2 - ADC Channel2 selected.
- * ADC_Channel_3 - ADC Channel3 selected.
- * ADC_Channel_4 - ADC Channel4 selected.
- * ADC_Channel_5 - ADC Channel5 selected.
- * ADC_Channel_6 - ADC Channel6 selected.
- * ADC_Channel_7 - ADC Channel7 selected.
- * ADC_Channel_8 - ADC Channel8 selected.
- * ADC_Channel_9 - ADC Channel9 selected.
- * ADC_Channel_10 - ADC Channel10 selected.
- * ADC_Channel_11 - ADC Channel11 selected.
- * ADC_Channel_12 - ADC Channel12 selected.
- * ADC_Channel_13 - ADC Channel13 selected.
- * ADC_Channel_14 - ADC Channel14 selected.
- * ADC_Channel_15 - ADC Channel15 selected.
- * ADC_Channel_16 - ADC Channel16 selected.
- * ADC_Channel_17 - ADC Channel17 selected.
- * Rank - The rank in the regular group sequencer.
- * This parameter must be between 1 to 16.
- * ADC_SampleTime - The sample time value to be set for the selected channel.
- * ADC_SampleTime_1Cycles5 - Sample time equal to 1.5 cycles.
- * ADC_SampleTime_7Cycles5 - Sample time equal to 7.5 cycles.
- * ADC_SampleTime_13Cycles5 - Sample time equal to 13.5 cycles.
- * ADC_SampleTime_28Cycles5 - Sample time equal to 28.5 cycles.
- * ADC_SampleTime_41Cycles5 - Sample time equal to 41.5 cycles.
- * ADC_SampleTime_55Cycles5 - Sample time equal to 55.5 cycles.
- * ADC_SampleTime_71Cycles5 - Sample time equal to 71.5 cycles.
- * ADC_SampleTime_239Cycles5 - Sample time equal to 239.5 cycles.
- *
- * @return None
- */
- void ADC_RegularChannelConfig(ADC_TypeDef *ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime)
- {
- uint32_t tmpreg1 = 0, tmpreg2 = 0;
- if(ADC_Channel > ADC_Channel_9)
- {
- tmpreg1 = ADCx->SAMPTR1;
- tmpreg2 = SAMPTR1_SMP_Set << (3 * (ADC_Channel - 10));
- tmpreg1 &= ~tmpreg2;
- tmpreg2 = (uint32_t)ADC_SampleTime << (3 * (ADC_Channel - 10));
- tmpreg1 |= tmpreg2;
- ADCx->SAMPTR1 = tmpreg1;
- }
- else
- {
- tmpreg1 = ADCx->SAMPTR2;
- tmpreg2 = SAMPTR2_SMP_Set << (3 * ADC_Channel);
- tmpreg1 &= ~tmpreg2;
- tmpreg2 = (uint32_t)ADC_SampleTime << (3 * ADC_Channel);
- tmpreg1 |= tmpreg2;
- ADCx->SAMPTR2 = tmpreg1;
- }
- if(Rank < 7)
- {
- tmpreg1 = ADCx->RSQR3;
- tmpreg2 = RSQR3_SQ_Set << (5 * (Rank - 1));
- tmpreg1 &= ~tmpreg2;
- tmpreg2 = (uint32_t)ADC_Channel << (5 * (Rank - 1));
- tmpreg1 |= tmpreg2;
- ADCx->RSQR3 = tmpreg1;
- }
- else if(Rank < 13)
- {
- tmpreg1 = ADCx->RSQR2;
- tmpreg2 = RSQR2_SQ_Set << (5 * (Rank - 7));
- tmpreg1 &= ~tmpreg2;
- tmpreg2 = (uint32_t)ADC_Channel << (5 * (Rank - 7));
- tmpreg1 |= tmpreg2;
- ADCx->RSQR2 = tmpreg1;
- }
- else
- {
- tmpreg1 = ADCx->RSQR1;
- tmpreg2 = RSQR1_SQ_Set << (5 * (Rank - 13));
- tmpreg1 &= ~tmpreg2;
- tmpreg2 = (uint32_t)ADC_Channel << (5 * (Rank - 13));
- tmpreg1 |= tmpreg2;
- ADCx->RSQR1 = tmpreg1;
- }
- }
- /*********************************************************************
- * @fn ADC_ExternalTrigConvCmd
- *
- * @brief Enables or disables the ADCx conversion through external trigger.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return None
- */
- void ADC_ExternalTrigConvCmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR2 |= CTLR2_EXTTRIG_Set;
- }
- else
- {
- ADCx->CTLR2 &= CTLR2_EXTTRIG_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_GetConversionValue
- *
- * @brief Returns the last ADCx conversion result data for regular channel.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- *
- * @return ADCx->RDATAR - The Data conversion value.
- */
- uint16_t ADC_GetConversionValue(ADC_TypeDef *ADCx)
- {
- return (uint16_t)ADCx->RDATAR;
- }
- /*********************************************************************
- * @fn ADC_GetDualModeConversionValue
- *
- * @brief Returns the last ADC1 and ADC2 conversion result data in dual mode.
- *
- * @return RDATAR_ADDRESS - The Data conversion value.
- */
- uint32_t ADC_GetDualModeConversionValue(void)
- {
- return (*(__IO uint32_t *)RDATAR_ADDRESS);
- }
- /*********************************************************************
- * @fn ADC_AutoInjectedConvCmd
- *
- * @brief Enables or disables the selected ADC automatic injected group
- * conversion after regular one.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return None
- */
- void ADC_AutoInjectedConvCmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR1 |= CTLR1_JAUTO_Set;
- }
- else
- {
- ADCx->CTLR1 &= CTLR1_JAUTO_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_InjectedDiscModeCmd
- *
- * @brief Enables or disables the discontinuous mode for injected group
- * channel for the specified ADC.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return None
- */
- void ADC_InjectedDiscModeCmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR1 |= CTLR1_JDISCEN_Set;
- }
- else
- {
- ADCx->CTLR1 &= CTLR1_JDISCEN_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_ExternalTrigInjectedConvConfig
- *
- * @brief Configures the ADCx external trigger for injected channels conversion.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_ExternalTrigInjecConv - specifies the ADC trigger to start
- * injected conversion.
- * ADC_ExternalTrigInjecConv_T1_TRGO - Timer1 TRGO event selected.
- * ADC_ExternalTrigInjecConv_T1_CC4 - Timer1 capture compare4 selected.
- * ADC_ExternalTrigInjecConv_T2_TRGO - Timer2 TRGO event selected.
- * ADC_ExternalTrigInjecConv_T2_CC1 - Timer2 capture compare1 selected.
- * ADC_ExternalTrigInjecConv_T3_CC4 - Timer3 capture compare4 selected.
- * ADC_ExternalTrigInjecConv_T4_TRGO - Timer4 TRGO event selected.
- * ADC_ExternalTrigInjecConv_Ext_IT15_TIM8_CC4 - External interrupt
- * line 15 event selected.
- * ADC_ExternalTrigInjecConv_None: Injected conversion started
- * by software and not by external trigger.
- *
- * @return None
- */
- void ADC_ExternalTrigInjectedConvConfig(ADC_TypeDef *ADCx, uint32_t ADC_ExternalTrigInjecConv)
- {
- uint32_t tmpreg = 0;
- tmpreg = ADCx->CTLR2;
- tmpreg &= CTLR2_JEXTSEL_Reset;
- tmpreg |= ADC_ExternalTrigInjecConv;
- ADCx->CTLR2 = tmpreg;
- }
- /*********************************************************************
- * @fn ADC_ExternalTrigInjectedConvCmd
- *
- * @brief Enables or disables the ADCx injected channels conversion through
- * external trigger.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return None
- */
- void ADC_ExternalTrigInjectedConvCmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR2 |= CTLR2_JEXTTRIG_Set;
- }
- else
- {
- ADCx->CTLR2 &= CTLR2_JEXTTRIG_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_SoftwareStartInjectedConvCmd
- *
- * @brief Enables or disables the selected ADC start of the injected
- * channels conversion.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return None
- */
- void ADC_SoftwareStartInjectedConvCmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR2 |= CTLR2_JEXTTRIG_JSWSTART_Set;
- }
- else
- {
- ADCx->CTLR2 &= CTLR2_JEXTTRIG_JSWSTART_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_GetSoftwareStartInjectedConvCmdStatus
- *
- * @brief Gets the selected ADC Software start injected conversion Status.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- *
- * @return FlagStatus: SET or RESET.
- */
- FlagStatus ADC_GetSoftwareStartInjectedConvCmdStatus(ADC_TypeDef *ADCx)
- {
- FlagStatus bitstatus = RESET;
- if((ADCx->CTLR2 & CTLR2_JSWSTART_Set) != (uint32_t)RESET)
- {
- bitstatus = SET;
- }
- else
- {
- bitstatus = RESET;
- }
- return bitstatus;
- }
- /*********************************************************************
- * @fn ADC_InjectedChannelConfig
- *
- * @brief Configures for the selected ADC injected channel its corresponding
- * rank in the sequencer and its sample time.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_Channel - the ADC channel to configure.
- * ADC_Channel_0 - ADC Channel0 selected.
- * ADC_Channel_1 - ADC Channel1 selected.
- * ADC_Channel_2 - ADC Channel2 selected.
- * ADC_Channel_3 - ADC Channel3 selected.
- * ADC_Channel_4 - ADC Channel4 selected.
- * ADC_Channel_5 - ADC Channel5 selected.
- * ADC_Channel_6 - ADC Channel6 selected.
- * ADC_Channel_7 - ADC Channel7 selected.
- * ADC_Channel_8 - ADC Channel8 selected.
- * ADC_Channel_9 - ADC Channel9 selected.
- * ADC_Channel_10 - ADC Channel10 selected.
- * ADC_Channel_11 - ADC Channel11 selected.
- * ADC_Channel_12 - ADC Channel12 selected.
- * ADC_Channel_13 - ADC Channel13 selected.
- * ADC_Channel_14 - ADC Channel14 selected.
- * ADC_Channel_15 - ADC Channel15 selected.
- * ADC_Channel_16 - ADC Channel16 selected.
- * ADC_Channel_17 - ADC Channel17 selected.
- * Rank - The rank in the regular group sequencer.
- * This parameter must be between 1 to 4.
- * ADC_SampleTime - The sample time value to be set for the selected channel.
- * ADC_SampleTime_1Cycles5 - Sample time equal to 1.5 cycles.
- * ADC_SampleTime_7Cycles5 - Sample time equal to 7.5 cycles.
- * ADC_SampleTime_13Cycles5 - Sample time equal to 13.5 cycles.
- * ADC_SampleTime_28Cycles5 - Sample time equal to 28.5 cycles.
- * ADC_SampleTime_41Cycles5 - Sample time equal to 41.5 cycles.
- * ADC_SampleTime_55Cycles5 - Sample time equal to 55.5 cycles.
- * ADC_SampleTime_71Cycles5 - Sample time equal to 71.5 cycles.
- * ADC_SampleTime_239Cycles5 - Sample time equal to 239.5 cycles.
- *
- * @return None
- */
- void ADC_InjectedChannelConfig(ADC_TypeDef *ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime)
- {
- uint32_t tmpreg1 = 0, tmpreg2 = 0, tmpreg3 = 0;
- if(ADC_Channel > ADC_Channel_9)
- {
- tmpreg1 = ADCx->SAMPTR1;
- tmpreg2 = SAMPTR1_SMP_Set << (3 * (ADC_Channel - 10));
- tmpreg1 &= ~tmpreg2;
- tmpreg2 = (uint32_t)ADC_SampleTime << (3 * (ADC_Channel - 10));
- tmpreg1 |= tmpreg2;
- ADCx->SAMPTR1 = tmpreg1;
- }
- else
- {
- tmpreg1 = ADCx->SAMPTR2;
- tmpreg2 = SAMPTR2_SMP_Set << (3 * ADC_Channel);
- tmpreg1 &= ~tmpreg2;
- tmpreg2 = (uint32_t)ADC_SampleTime << (3 * ADC_Channel);
- tmpreg1 |= tmpreg2;
- ADCx->SAMPTR2 = tmpreg1;
- }
- tmpreg1 = ADCx->ISQR;
- tmpreg3 = (tmpreg1 & ISQR_JL_Set) >> 20;
- tmpreg2 = ISQR_JSQ_Set << (5 * (uint8_t)((Rank + 3) - (tmpreg3 + 1)));
- tmpreg1 &= ~tmpreg2;
- tmpreg2 = (uint32_t)ADC_Channel << (5 * (uint8_t)((Rank + 3) - (tmpreg3 + 1)));
- tmpreg1 |= tmpreg2;
- ADCx->ISQR = tmpreg1;
- }
- /*********************************************************************
- * @fn ADC_InjectedSequencerLengthConfig
- *
- * @brief Configures the sequencer length for injected channels.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * Length - The sequencer length.
- * This parameter must be a number between 1 to 4.
- *
- * @return None
- */
- void ADC_InjectedSequencerLengthConfig(ADC_TypeDef *ADCx, uint8_t Length)
- {
- uint32_t tmpreg1 = 0;
- uint32_t tmpreg2 = 0;
- tmpreg1 = ADCx->ISQR;
- tmpreg1 &= ISQR_JL_Reset;
- tmpreg2 = Length - 1;
- tmpreg1 |= tmpreg2 << 20;
- ADCx->ISQR = tmpreg1;
- }
- /*********************************************************************
- * @fn ADC_SetInjectedOffset
- *
- * @brief Set the injected channels conversion value offset.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_InjectedChannel: the ADC injected channel to set its offset.
- * ADC_InjectedChannel_1 - Injected Channel1 selected.
- * ADC_InjectedChannel_2 - Injected Channel2 selected.
- * ADC_InjectedChannel_3 - Injected Channel3 selected.
- * ADC_InjectedChannel_4 - Injected Channel4 selected.
- * Offset - the offset value for the selected ADC injected channel.
- * This parameter must be a 12bit value.
- *
- * @return None
- */
- void ADC_SetInjectedOffset(ADC_TypeDef *ADCx, uint8_t ADC_InjectedChannel, uint16_t Offset)
- {
- __IO uint32_t tmp = 0;
- tmp = (uint32_t)ADCx;
- tmp += ADC_InjectedChannel;
- *(__IO uint32_t *)tmp = (uint32_t)Offset;
- }
- /*********************************************************************
- * @fn ADC_GetInjectedConversionValue
- *
- * @brief Returns the ADC injected channel conversion result.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_InjectedChannel - the ADC injected channel to set its offset.
- * ADC_InjectedChannel_1 - Injected Channel1 selected.
- * ADC_InjectedChannel_2 - Injected Channel2 selected.
- * ADC_InjectedChannel_3 - Injected Channel3 selected.
- * ADC_InjectedChannel_4 - Injected Channel4 selected.
- *
- * @return tmp - The Data conversion value.
- */
- uint16_t ADC_GetInjectedConversionValue(ADC_TypeDef *ADCx, uint8_t ADC_InjectedChannel)
- {
- __IO uint32_t tmp = 0;
- tmp = (uint32_t)ADCx;
- tmp += ADC_InjectedChannel + IDATAR_Offset;
- return (uint16_t)(*(__IO uint32_t *)tmp);
- }
- /*********************************************************************
- * @fn ADC_AnalogWatchdogCmd
- *
- * @brief Enables or disables the analog watchdog on single/all regular
- * or injected channels.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_AnalogWatchdog - the ADC analog watchdog configuration.
- * ADC_AnalogWatchdog_SingleRegEnable - Analog watchdog on a
- * single regular channel.
- * ADC_AnalogWatchdog_SingleInjecEnable - Analog watchdog on a
- * single injected channel.
- * ADC_AnalogWatchdog_SingleRegOrInjecEnable - Analog watchdog
- * on a single regular or injected channel.
- * ADC_AnalogWatchdog_AllRegEnable - Analog watchdog on all
- * regular channel.
- * ADC_AnalogWatchdog_AllInjecEnable - Analog watchdog on all
- * injected channel.
- * ADC_AnalogWatchdog_AllRegAllInjecEnable - Analog watchdog on
- * all regular and injected channels.
- * ADC_AnalogWatchdog_None - No channel guarded by the analog
- * watchdog.
- *
- * @return none
- */
- void ADC_AnalogWatchdogCmd(ADC_TypeDef *ADCx, uint32_t ADC_AnalogWatchdog)
- {
- uint32_t tmpreg = 0;
- tmpreg = ADCx->CTLR1;
- tmpreg &= CTLR1_AWDMode_Reset;
- tmpreg |= ADC_AnalogWatchdog;
- ADCx->CTLR1 = tmpreg;
- }
- /*********************************************************************
- * @fn ADC_AnalogWatchdogThresholdsConfig
- *
- * @brief Configures the high and low thresholds of the analog watchdog.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * HighThreshold - the ADC analog watchdog High threshold value.
- * This parameter must be a 12bit value.
- * LowThreshold - the ADC analog watchdog Low threshold value.
- * This parameter must be a 12bit value.
- *
- * @return none
- */
- void ADC_AnalogWatchdogThresholdsConfig(ADC_TypeDef *ADCx, uint16_t HighThreshold,
- uint16_t LowThreshold)
- {
- ADCx->WDHTR = HighThreshold;
- ADCx->WDLTR = LowThreshold;
- }
- /*********************************************************************
- * @fn ADC_AnalogWatchdogSingleChannelConfig
- *
- * @brief Configures the analog watchdog guarded single channel.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_Channel - the ADC channel to configure.
- * ADC_Channel_0 - ADC Channel0 selected.
- * ADC_Channel_1 - ADC Channel1 selected.
- * ADC_Channel_2 - ADC Channel2 selected.
- * ADC_Channel_3 - ADC Channel3 selected.
- * ADC_Channel_4 - ADC Channel4 selected.
- * ADC_Channel_5 - ADC Channel5 selected.
- * ADC_Channel_6 - ADC Channel6 selected.
- * ADC_Channel_7 - ADC Channel7 selected.
- * ADC_Channel_8 - ADC Channel8 selected.
- * ADC_Channel_9 - ADC Channel9 selected.
- * ADC_Channel_10 - ADC Channel10 selected.
- * ADC_Channel_11 - ADC Channel11 selected.
- * ADC_Channel_12 - ADC Channel12 selected.
- * ADC_Channel_13 - ADC Channel13 selected.
- * ADC_Channel_14 - ADC Channel14 selected.
- * ADC_Channel_15 - ADC Channel15 selected.
- * ADC_Channel_16 - ADC Channel16 selected.
- * ADC_Channel_17 - ADC Channel17 selected.
- *
- * @return None
- */
- void ADC_AnalogWatchdogSingleChannelConfig(ADC_TypeDef *ADCx, uint8_t ADC_Channel)
- {
- uint32_t tmpreg = 0;
- tmpreg = ADCx->CTLR1;
- tmpreg &= CTLR1_AWDCH_Reset;
- tmpreg |= ADC_Channel;
- ADCx->CTLR1 = tmpreg;
- }
- /*********************************************************************
- * @fn ADC_TempSensorVrefintCmd
- *
- * @brief Enables or disables the temperature sensor and Vrefint channel.
- *
- * @param NewState - ENABLE or DISABLE.
- *
- * @return none
- */
- void ADC_TempSensorVrefintCmd(FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADC1->CTLR2 |= CTLR2_TSVREFE_Set;
- }
- else
- {
- ADC1->CTLR2 &= CTLR2_TSVREFE_Reset;
- }
- }
- /*********************************************************************
- * @fn ADC_GetFlagStatus
- *
- * @brief Checks whether the specified ADC flag is set or not.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_FLAG - specifies the flag to check.
- * ADC_FLAG_AWD - Analog watchdog flag.
- * ADC_FLAG_EOC - End of conversion flag.
- * ADC_FLAG_JEOC - End of injected group conversion flag.
- * ADC_FLAG_JSTRT - Start of injected group conversion flag.
- * ADC_FLAG_STRT - Start of regular group conversion flag.
- *
- * @return FlagStatus: SET or RESET.
- */
- FlagStatus ADC_GetFlagStatus(ADC_TypeDef *ADCx, uint8_t ADC_FLAG)
- {
- FlagStatus bitstatus = RESET;
- if((ADCx->STATR & ADC_FLAG) != (uint8_t)RESET)
- {
- bitstatus = SET;
- }
- else
- {
- bitstatus = RESET;
- }
- return bitstatus;
- }
- /*********************************************************************
- * @fn ADC_ClearFlag
- *
- * @brief Clears the ADCx's pending flags.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_FLAG - specifies the flag to clear.
- * ADC_FLAG_AWD - Analog watchdog flag.
- * ADC_FLAG_EOC - End of conversion flag.
- * ADC_FLAG_JEOC - End of injected group conversion flag.
- * ADC_FLAG_JSTRT - Start of injected group conversion flag.
- * ADC_FLAG_STRT - Start of regular group conversion flag.
- *
- * @return none
- */
- void ADC_ClearFlag(ADC_TypeDef *ADCx, uint8_t ADC_FLAG)
- {
- ADCx->STATR = ~(uint32_t)ADC_FLAG;
- }
- /*********************************************************************
- * @fn ADC_GetITStatus
- *
- * @brief Checks whether the specified ADC interrupt has occurred or not.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_IT - specifies the ADC interrupt source to check.
- * ADC_IT_EOC - End of conversion interrupt mask.
- * ADC_IT_AWD - Analog watchdog interrupt mask.
- * ADC_IT_JEOC - End of injected conversion interrupt mask.
- *
- * @return FlagStatus: SET or RESET.
- */
- ITStatus ADC_GetITStatus(ADC_TypeDef *ADCx, uint16_t ADC_IT)
- {
- ITStatus bitstatus = RESET;
- uint32_t itmask = 0, enablestatus = 0;
- itmask = ADC_IT >> 8;
- enablestatus = (ADCx->CTLR1 & (uint8_t)ADC_IT);
- if(((ADCx->STATR & itmask) != (uint32_t)RESET) && enablestatus)
- {
- bitstatus = SET;
- }
- else
- {
- bitstatus = RESET;
- }
- return bitstatus;
- }
- /*********************************************************************
- * @fn ADC_ClearITPendingBit
- *
- * @brief Clears the ADCx's interrupt pending bits.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * ADC_IT - specifies the ADC interrupt pending bit to clear.
- * ADC_IT_EOC - End of conversion interrupt mask.
- * ADC_IT_AWD - Analog watchdog interrupt mask.
- * ADC_IT_JEOC - End of injected conversion interrupt mask.
- *
- * @return none
- */
- void ADC_ClearITPendingBit(ADC_TypeDef *ADCx, uint16_t ADC_IT)
- {
- uint8_t itmask = 0;
- itmask = (uint8_t)(ADC_IT >> 8);
- ADCx->STATR = ~(uint32_t)itmask;
- }
- /*********************************************************************
- * @fn TempSensor_Volt_To_Temper
- *
- * @brief Internal Temperature Sensor Voltage to temperature.
- *
- * @param Value - Voltage Value(mv).
- *
- * @return Temper - Temperature Value.
- */
- s32 TempSensor_Volt_To_Temper(s32 Value)
- {
- s32 Temper, Refer_Volt, Refer_Temper;
- s32 k = 43;
- Refer_Volt = (s32)((*(u32 *)0x1FFFF720) & 0x0000FFFF);
- Refer_Temper = (s32)(((*(u32 *)0x1FFFF720) >> 16) & 0x0000FFFF);
- Temper = Refer_Temper - ((Value - Refer_Volt) * 10 + (k >> 1)) / k;
- return Temper;
- }
- /*********************************************************************
- * @fn ADC_BufferCmd
- *
- * @brief Enables or disables the ADCx buffer.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- * NewState - ENABLE or DISABLE.
- *
- * @return none
- */
- void ADC_BufferCmd(ADC_TypeDef *ADCx, FunctionalState NewState)
- {
- if(NewState != DISABLE)
- {
- ADCx->CTLR1 |= (1 << 26);
- }
- else
- {
- ADCx->CTLR1 &= ~(1 << 26);
- }
- }
- /*********************************************************************
- * @fn Get_CalibrationValue
- *
- * @brief Get ADCx Calibration Value.
- *
- * @param ADCx - where x can be 1 or 2 to select the ADC peripheral.
- *
- * @return CalibrationValue
- */
- int16_t Get_CalibrationValue(ADC_TypeDef *ADCx)
- {
- __IO uint8_t i, j;
- uint16_t buf[10];
- __IO uint16_t t;
- #if defined (CH32V20x_D6)
- __IO uint16_t p;
- #endif
- for(i = 0; i < 10; i++){
- ADC_ResetCalibration(ADCx);
- while(ADC_GetResetCalibrationStatus(ADCx));
- ADC_StartCalibration(ADCx);
- while(ADC_GetCalibrationStatus(ADCx));
- buf[i] = ADCx->RDATAR;
- }
- for(i = 0; i < 10; i++){
- for(j = 0; j < 9; j++){
- if(buf[j] > buf[j + 1])
- {
- t = buf[j];
- buf[j] = buf[j + 1];
- buf[j + 1] = t;
- }
- }
- }
- #if defined (CH32V20x_D8) || defined (CH32V20x_D8W)
- t = 0;
- for( i = 0; i < 6; i++ ) {
- t += buf[i + 2];
- }
- t = ( t / 6 ) + ( ( t % 6 ) / 3 );
- return ( int16_t )( 2048 - ( int16_t )t );
- #else
- t = 0;
- p = 0;
- /* 1024 */
- for(i = 0; i < 6; i++ ){
- if(buf[i+2] > 1536) break;
- t += buf[i+2];
- }
- if(i > 0){
- t = ( t / i ) + ( (( t % i )*2) / i );
- }
- else t = 1024;
- /* 2048 */
- j = 6-i;
- if(j > 0){
- for(; i < 6; i++ ){
- p += buf[i+2];
- }
- p = ( p / j ) + ( (( p % j )*2) / j );
- }
- else p = 2048;
- return ( int16_t )(((( int16_t )( 1024 - ( int16_t )t ) + ( int16_t )( 2048 - ( int16_t )p ))/2) + ((( int16_t )( 1024 - ( int16_t )t ) + ( int16_t )( 2048 - ( int16_t )p ))%2));
- #endif
- }
|