123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278 |
- /**
- ******************************************************************************
- * @brief ADC header file of the firmware library.
- ******************************************************************************
- */
- /* Define to prevent recursive inclusion -------------------------------------*/
- #ifndef __GD32F10X_ADC_H
- #define __GD32F10X_ADC_H
- #ifdef __cplusplus
- extern "C" {
- #endif
- typedef enum { FALSE = 0, TRUE } BOOL;
- /* Includes ------------------------------------------------------------------*/
- #include "gd32f10x.h"
- /** @addtogroup GD32F10x_Firmware
- * @{
- */
- /** @addtogroup ADC
- * @{
- */
- /** @defgroup ADC_Exported_Types
- * @{
- */
- /**
- * @brief ADC Init structure definition
- */
- typedef struct {
- uint32_t ADC_Trig_External; /*!< AD conversion of regular channels trigger. */
- uint8_t ADC_Channel_Number; /*!< The number of converted ADC channels .
- This parameter must range from 1 to 16. */
- uint32_t ADC_Data_Align; /*!< ADC data alignment,left or right. */
- TypeState ADC_Mode_Scan; /*!< AD conversion mode,multichannels mode or Single channel mode.
- This parameter can be ENABLE or DISABLE */
- uint32_t ADC_Mode; /*!< AD operation mode,independent mode or dual mode.
- This parameter can be a value of @ref ADC_mode */
- TypeState ADC_Mode_Continuous; /*!< AD perform mode,continuous mode or single mode.
- This parameter can be ENABLE or DISABLE. */
- } ADC_InitPara;
- /**
- * @}
- */
- /** @defgroup ADC_Exported_Constants
- * @{
- */
- /** @defgroup ADC_external_trigger
- * @{
- */
- #define ADC_EXTERNAL_TRIGGER_MODE_T1_CC1 ((uint32_t)0x00000000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T1_CC2 ((uint32_t)0x00020000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T2_CC2 ((uint32_t)0x00060000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T3_TRGO ((uint32_t)0x00080000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T4_CC4 ((uint32_t)0x000A0000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIGGER_MODE_EXT_IT11_T8_TRGO ((uint32_t)0x000C0000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T1_CC3 ((uint32_t)0x00040000) /*!< Used in ADC1,ADC2 and ADC3 */
- #define ADC_EXTERNAL_TRIGGER_MODE_NONE ((uint32_t)0x000E0000) /*!< Used in ADC1,ADC2 and ADC3 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T3_CC1 ((uint32_t)0x00000000) /*!< Only used in ADC3 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T2_CC3 ((uint32_t)0x00020000) /*!< Only used in ADC3 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T8_CC1 ((uint32_t)0x00060000) /*!< Only used in ADC3 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T8_TRGO ((uint32_t)0x00080000) /*!< Only used in ADC3 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T5_CC1 ((uint32_t)0x000A0000) /*!< Only used in ADC3 */
- #define ADC_EXTERNAL_TRIGGER_MODE_T5_CC3 ((uint32_t)0x000C0000) /*!< Only used in ADC3 */
- /**
- * @}
- */
- /** @defgroup ADC_channels
- * @{
- */
- #define ADC_CHANNEL_0 ((uint8_t)0x00)
- #define ADC_CHANNEL_1 ((uint8_t)0x01)
- #define ADC_CHANNEL_2 ((uint8_t)0x02)
- #define ADC_CHANNEL_3 ((uint8_t)0x03)
- #define ADC_CHANNEL_4 ((uint8_t)0x04)
- #define ADC_CHANNEL_5 ((uint8_t)0x05)
- #define ADC_CHANNEL_6 ((uint8_t)0x06)
- #define ADC_CHANNEL_7 ((uint8_t)0x07)
- #define ADC_CHANNEL_8 ((uint8_t)0x08)
- #define ADC_CHANNEL_9 ((uint8_t)0x09)
- #define ADC_CHANNEL_10 ((uint8_t)0x0A)
- #define ADC_CHANNEL_11 ((uint8_t)0x0B)
- #define ADC_CHANNEL_12 ((uint8_t)0x0C)
- #define ADC_CHANNEL_13 ((uint8_t)0x0D)
- #define ADC_CHANNEL_14 ((uint8_t)0x0E)
- #define ADC_CHANNEL_15 ((uint8_t)0x0F)
- #define ADC_CHANNEL_16 ((uint8_t)0x10)
- #define ADC_CHANNEL_17 ((uint8_t)0x11)
- #define ADC_CHANNEL_TEMPSENSOR ((uint8_t)ADC_CHANNEL_16)
- #define ADC_CHANNEL_VREFINT ((uint8_t)ADC_CHANNEL_17)
- /**
- * @}
- */
- /** @defgroup ADC_data_align
- * @{
- */
- #define ADC_DATAALIGN_RIGHT ((uint32_t)0x00000000)
- #define ADC_DATAALIGN_LEFT ((uint32_t)0x00000800)
- /**
- * @}
- */
- /** @defgroup ADC_mode
- * @{
- */
- #define ADC_MODE_INDEPENDENT ((uint32_t)0x00000000)
- #define ADC_MODE_REGINSERTSIMULT ((uint32_t)0x00010000)
- #define ADC_MODE_REGSIMULT_ALTERTRIG ((uint32_t)0x00020000)
- #define ADC_MODE_INSERTSIMULT_FASTINTERL ((uint32_t)0x00030000)
- #define ADC_MODE_INSERTSIMULT_SLOWINTERL ((uint32_t)0x00040000)
- #define ADC_MODE_INSERTSIMULT ((uint32_t)0x00050000)
- #define ADC_MODE_REGSIMULT ((uint32_t)0x00060000)
- #define ADC_MODE_FASTINTERL ((uint32_t)0x00070000)
- #define ADC_MODE_SLOWINTERL ((uint32_t)0x00080000)
- #define ADC_MODE_ALTERTRIG ((uint32_t)0x00090000)
- /**
- * @}
- */
- /** @defgroup ADC_sampling_time
- * @{
- */
- #define ADC_SAMPLETIME_1POINT5 ((uint8_t)0x00)
- #define ADC_SAMPLETIME_7POINT5 ((uint8_t)0x01)
- #define ADC_SAMPLETIME_13POINT5 ((uint8_t)0x02)
- #define ADC_SAMPLETIME_28POINT5 ((uint8_t)0x03)
- #define ADC_SAMPLETIME_41POINT5 ((uint8_t)0x04)
- #define ADC_SAMPLETIME_55POINT5 ((uint8_t)0x05)
- #define ADC_SAMPLETIME_71POINT5 ((uint8_t)0x06)
- #define ADC_SAMPLETIME_239POINT5 ((uint8_t)0x07)
- /**
- * @}
- */
- /** @defgroup ADC_external_trigger_sources_for_inserted_channels_conversion
- * @{
- */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T2_TRGO ((uint32_t)0x00002000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T2_CC1 ((uint32_t)0x00003000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T3_CC4 ((uint32_t)0x00004000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T4_TRGO ((uint32_t)0x00005000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_EXT_IT15_T8_CC4 ((uint32_t)0x00006000) /*!< Only used in ADC1 and ADC2 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T1_TRIG ((uint32_t)0x00000000) /*!< Used in ADC1,ADC2 and ADC3 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T1_CC4 ((uint32_t)0x00001000) /*!< Used in ADC1,ADC2 and ADC3 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_NONE ((uint32_t)0x00007000) /*!< Used in ADC1,ADC2 and ADC3 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T4_CC3 ((uint32_t)0x00002000) /*!< Only used in ADC3 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T8_CC2 ((uint32_t)0x00003000) /*!< Only used in ADC3 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T8_CC4 ((uint32_t)0x00004000) /*!< Only used in ADC3 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T5_TRGO ((uint32_t)0x00005000) /*!< Only used in ADC3 */
- #define ADC_EXTERNAL_TRIG_INSERTCONV_T5_CC4 ((uint32_t)0x00006000) /*!< Only used in ADC3 */
- /**
- * @}
- */
- /** @defgroup ADC_inserted_channel_selection
- * @{
- */
- #define ADC_INSERTEDCHANNEL_1 ((uint8_t)0x14)
- #define ADC_INSERTEDCHANNEL_2 ((uint8_t)0x18)
- #define ADC_INSERTEDCHANNEL_3 ((uint8_t)0x1C)
- #define ADC_INSERTEDCHANNEL_4 ((uint8_t)0x20)
- /**
- * @}
- */
- /** @defgroup ADC_analog_watchdog_selection
- * @{
- */
- #define ADC_ANALOGWATCHDOG_SINGLEREGENABLE ((uint32_t)0x00800200)
- #define ADC_ANALOGWATCHDOG_SINGLEINSERTENABLE ((uint32_t)0x00400200)
- #define ADC_ANALOGWATCHDOG_SINGLEREGORINSERTENABLE ((uint32_t)0x00C00200)
- #define ADC_ANALOGWATCHDOG_ALLREGENABLE ((uint32_t)0x00800000)
- #define ADC_ANALOGWATCHDOG_ALLINSERTENABLE ((uint32_t)0x00400000)
- #define ADC_ANALOGWATCHDOG_ALLREGALLINSERTENABLE ((uint32_t)0x00C00000)
- #define ADC_ANALOGWATCHDOG_NONE ((uint32_t)0x00000000)
- /**
- * @}
- */
- /** @defgroup ADC_interrupts_definition
- * @{
- */
- #define ADC_INT_EOC ((uint16_t)0x0220)
- #define ADC_INT_AWE ((uint16_t)0x0140)
- #define ADC_INT_EOIC ((uint16_t)0x0480)
- /**
- * @}
- */
- /** @defgroup ADC_flags_definition
- * @{
- */
- #define ADC_FLAG_AWE ((uint8_t)0x01)
- #define ADC_FLAG_EOC ((uint8_t)0x02)
- #define ADC_FLAG_EOIC ((uint8_t)0x04)
- #define ADC_FLAG_STIC ((uint8_t)0x08)
- #define ADC_FLAG_STRC ((uint8_t)0x10)
- /**
- * @}
- */
- /**
- * @}
- */
- /** @defgroup ADC_Exported_Functions
- * @{
- */
- void ADC_DeInit(ADC_TypeDef *ADCx, ADC_InitPara *ADC_InitParaStruct);
- void ADC_Init(ADC_TypeDef *ADCx, ADC_InitPara *ADC_InitParaStruct);
- void ADC_Enable(ADC_TypeDef *ADCx, TypeState NewValue);
- void ADC_DMA_Enable(ADC_TypeDef *ADCx, TypeState NewValue);
- void ADC_INTConfig(ADC_TypeDef *ADCx, uint16_t ADC_INT, TypeState NewValue);
- void ADC_Calibration(ADC_TypeDef *ADCx);
- void ADC_SoftwareStartConv_Enable(ADC_TypeDef *ADCx, TypeState NewValue);
- TypeState ADC_GetSoftwareStartConvBitState(ADC_TypeDef *ADCx);
- void ADC_DiscModeChannelCount_Config(ADC_TypeDef *ADCx, uint8_t Number);
- void ADC_DiscMode_Enable(ADC_TypeDef *ADCx, TypeState NewValue);
- void ADC_RegularChannel_Config(ADC_TypeDef *ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime);
- void ADC_ExternalTrigConv_Enable(ADC_TypeDef *ADCx, TypeState NewValue);
- uint16_t ADC_GetConversionValue(ADC_TypeDef *ADCx);
- uint32_t ADC_GetDualModeConversionValue(void);
- void ADC_AutoInsertedConv_Enable(ADC_TypeDef *ADCx, TypeState NewValue);
- void ADC_InsertedDiscMode_Enable(ADC_TypeDef *ADCx, TypeState NewValue);
- void ADC_ExternalTrigInsertedConv_Config(ADC_TypeDef *ADCx, uint32_t ADC_ExternalTrigInsertConv);
- void ADC_ExternalTrigInsertedConv_Enable(ADC_TypeDef *ADCx, TypeState NewValue);
- void ADC_SoftwareStartInsertedConv_Enable(ADC_TypeDef *ADCx, TypeState NewValue);
- TypeState ADC_GetSoftwareStartInsertedConvCmdBitState(ADC_TypeDef *ADCx);
- void ADC_InsertedChannel_Config(ADC_TypeDef *ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime);
- void ADC_InsertedSequencerLength_Config(ADC_TypeDef *ADCx, uint8_t Length);
- void ADC_SetInsertedOffset(ADC_TypeDef *ADCx, uint8_t ADC_InsertedChannel, uint16_t Offset);
- uint16_t ADC_GetInsertedConversionValue(ADC_TypeDef *ADCx, uint8_t ADC_InsertedChannel);
- void ADC_AnalogWatchdog_Enable(ADC_TypeDef *ADCx, uint32_t ADC_AnalogWatchdog);
- void ADC_AnalogWatchdogThresholds_Config(ADC_TypeDef *ADCx, uint16_t HighThreshold, uint16_t LowThreshold);
- void ADC_AnalogWatchdogSingleChannel_Config(ADC_TypeDef *ADCx, uint8_t ADC_Channel);
- void ADC_TempSensorVrefint_Enable(TypeState NewValue);
- TypeState ADC_GetBitState(ADC_TypeDef *ADCx, uint8_t ADC_FLAG);
- void ADC_ClearBitState(ADC_TypeDef *ADCx, uint8_t ADC_FLAG);
- TypeState ADC_GetIntState(ADC_TypeDef *ADCx, uint16_t ADC_INT);
- void ADC_ClearIntBitState(ADC_TypeDef *ADCx, uint16_t ADC_INT);
- /**
- * @}
- */
- /**
- * @}
- */
- /**
- * @}
- */
- #ifdef __cplusplus
- }
- #endif
- #endif /*__GD32F10X_ADC_H */
|