/***************************************************************************** * Copyright (c) 2019, Nations Technologies Inc. * * All rights reserved. * **************************************************************************** * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * - Redistributions of source code must retain the above copyright notice, * this list of conditions and the disclaimer below. * * Nations' name may not be used to endorse or promote products derived from * this software without specific prior written permission. * * DISCLAIMER: THIS SOFTWARE IS PROVIDED BY NATIONS "AS IS" AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE * DISCLAIMED. IN NO EVENT SHALL NATIONS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * ****************************************************************************/ /** * @file n32g45x_adc.h * @author Nations * @version v1.0.1 * * @copyright Copyright (c) 2019, Nations Technologies Inc. All rights reserved. */ #ifndef __N32G45X_ADC_H__ #define __N32G45X_ADC_H__ #ifdef __cplusplus extern "C" { #endif #include "n32g45x.h" #include /** @addtogroup N32G45X_StdPeriph_Driver * @{ */ #define VREF1P2_CTRL (*(uint32_t*)(0x40001800+0x20)) #define _EnVref1p2() do{VREF1P2_CTRL|=(1<<10);}while(0); #define _DisVref1p2() do{VREF1P2_CTRL&=~(1<<10);}while(0); /** @addtogroup ADC * @{ */ /** @addtogroup ADC_Exported_Types * @{ */ /** * @brief ADC Init structure definition */ typedef struct { uint32_t WorkMode; /*!< Configures the ADC to operate in independent or dual mode. This parameter can be a value of @ref ADC_mode */ FunctionalState MultiChEn; /*!< Specifies whether the conversion is performed in Scan (multichannels) or Single (one channel) mode. This parameter can be set to ENABLE or DISABLE */ FunctionalState ContinueConvEn; /*!< Specifies whether the conversion is performed in Continuous or Single mode. This parameter can be set to ENABLE or DISABLE. */ uint32_t ExtTrigSelect; /*!< Defines the external trigger used to start the analog to digital conversion of regular channels. This parameter can be a value of @ref ADC_external_trigger_sources_for_regular_channels_conversion */ uint32_t DatAlign; /*!< Specifies whether the ADC data alignment is left or right. This parameter can be a value of @ref ADC_data_align */ uint8_t ChsNumber; /*!< Specifies the number of ADC channels that will be converted using the sequencer for regular channel group. This parameter must range from 1 to 16. */ } ADC_InitType; /** * @} */ /** @addtogroup ADC_Exported_Constants * @{ */ #define IsAdcModule(PERIPH) (((PERIPH) == ADC1) || ((PERIPH) == ADC2) || ((PERIPH) == ADC3) || ((PERIPH) == ADC4)) #define IsAdcDmaModule(PERIPH) (((PERIPH) == ADC1) || ((PERIPH) == ADC3)) /** @addtogroup ADC_mode * @{ */ #define ADC_WORKMODE_INDEPENDENT ((uint32_t)0x00000000) #define ADC_WORKMODE_SEQ_INJECT_SIMULT ((uint32_t)0x00010000) #define ADC_WORKMODE_SEQ_SIMULT_ALTER_TRIG ((uint32_t)0x00020000) #define ADC_WORKMODE_INJ_SIMULT_FAST_INTERL ((uint32_t)0x00030000) #define ADC_WORKMODE_INT_SIMULT_SLOW_INTERL ((uint32_t)0x00040000) #define ADC_WORKMODE_INJ_SIMULT ((uint32_t)0x00050000) #define ADC_WORKMODE_REG_SIMULT ((uint32_t)0x00060000) #define ADC_WORKMODE_FAST_INTERL ((uint32_t)0x00070000) #define ADC_WORKMODE_SLOW_INTERL ((uint32_t)0x00080000) #define ADC_WORKMODE_ALTER_TRIG ((uint32_t)0x00090000) #define IsAdcWorkMode(MODE) \ (((MODE) == ADC_WORKMODE_INDEPENDENT) || ((MODE) == ADC_WORKMODE_SEQ_INJECT_SIMULT) \ || ((MODE) == ADC_WORKMODE_SEQ_SIMULT_ALTER_TRIG) || ((MODE) == ADC_WORKMODE_INJ_SIMULT_FAST_INTERL) \ || ((MODE) == ADC_WORKMODE_INT_SIMULT_SLOW_INTERL) || ((MODE) == ADC_WORKMODE_INJ_SIMULT) \ || ((MODE) == ADC_WORKMODE_REG_SIMULT) || ((MODE) == ADC_WORKMODE_FAST_INTERL) \ || ((MODE) == ADC_WORKMODE_SLOW_INTERL) || ((MODE) == ADC_WORKMODE_ALTER_TRIG)) /** * @} */ /** @addtogroup ADC_external_trigger_sources_for_regular_channels_conversion * @{ */ #define ADC_EXT_TRIGCONV_T1_CC1 ((uint32_t)0x00000000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIGCONV_T1_CC2 ((uint32_t)0x00020000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIGCONV_T2_CC2 ((uint32_t)0x00060000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIGCONV_T3_TRGO ((uint32_t)0x00080000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIGCONV_T4_CC4 ((uint32_t)0x000A0000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIGCONV_EXT_INT11_TIM8_TRGO ((uint32_t)0x000C0000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIGCONV_T1_CC3 ((uint32_t)0x00040000) /*!< For ADC1, ADC2 , ADC3 and ADC4 */ #define ADC_EXT_TRIGCONV_NONE ((uint32_t)0x000E0000) /*!< For ADC1, ADC2 , ADC3 and ADC4 */ #define ADC_EXT_TRIGCONV_T3_CC1 ((uint32_t)0x00000000) /*!< For ADC3 and ADC4 */ #define ADC_EXT_TRIGCONV_T2_CC3 ((uint32_t)0x00020000) /*!< For ADC3 and ADC4 */ #define ADC_EXT_TRIGCONV_T8_CC1 ((uint32_t)0x00060000) /*!< For ADC3 and ADC4 */ #define ADC_EXT_TRIGCONV_T8_TRGO ((uint32_t)0x00080000) /*!< For ADC3 and ADC4 */ #define ADC_EXT_TRIGCONV_T5_CC1 ((uint32_t)0x000A0000) /*!< For ADC3 and ADC4 */ #define ADC_EXT_TRIGCONV_EXT_INT10_T5_CC3 ((uint32_t)0x000C0000) /*!< For ADC3 and ADC4 */ #define IsAdcExtTrig(REGTRIG) \ (((REGTRIG) == ADC_EXT_TRIGCONV_T1_CC1) || ((REGTRIG) == ADC_EXT_TRIGCONV_T1_CC2) \ || ((REGTRIG) == ADC_EXT_TRIGCONV_T1_CC3) || ((REGTRIG) == ADC_EXT_TRIGCONV_T2_CC2) \ || ((REGTRIG) == ADC_EXT_TRIGCONV_T3_TRGO) || ((REGTRIG) == ADC_EXT_TRIGCONV_T4_CC4) \ || ((REGTRIG) == ADC_EXT_TRIGCONV_EXT_INT11_TIM8_TRGO) || ((REGTRIG) == ADC_EXT_TRIGCONV_NONE) \ || ((REGTRIG) == ADC_EXT_TRIGCONV_T3_CC1) || ((REGTRIG) == ADC_EXT_TRIGCONV_T2_CC3) \ || ((REGTRIG) == ADC_EXT_TRIGCONV_T8_CC1) || ((REGTRIG) == ADC_EXT_TRIGCONV_T8_TRGO) \ || ((REGTRIG) == ADC_EXT_TRIGCONV_T5_CC1) || ((REGTRIG) == ADC_EXT_TRIGCONV_EXT_INT10_T5_CC3)) /** * @} */ /** @addtogroup ADC_data_align * @{ */ #define ADC_DAT_ALIGN_R ((uint32_t)0x00000000) #define ADC_DAT_ALIGN_L ((uint32_t)0x00000800) #define IsAdcDatAlign(ALIGN) (((ALIGN) == ADC_DAT_ALIGN_R) || ((ALIGN) == ADC_DAT_ALIGN_L)) /** * @} */ /** @addtogroup ADC_channels * @{ */ #define ADC_CH_0 ((uint8_t)0x00) #define ADC_CH_1 ((uint8_t)0x01) #define ADC_CH_2 ((uint8_t)0x02) #define ADC_CH_3 ((uint8_t)0x03) #define ADC_CH_4 ((uint8_t)0x04) #define ADC_CH_5 ((uint8_t)0x05) #define ADC_CH_6 ((uint8_t)0x06) #define ADC_CH_7 ((uint8_t)0x07) #define ADC_CH_8 ((uint8_t)0x08) #define ADC_CH_9 ((uint8_t)0x09) #define ADC_CH_10 ((uint8_t)0x0A) #define ADC_CH_11 ((uint8_t)0x0B) #define ADC_CH_12 ((uint8_t)0x0C) #define ADC_CH_13 ((uint8_t)0x0D) #define ADC_CH_14 ((uint8_t)0x0E) #define ADC_CH_15 ((uint8_t)0x0F) #define ADC_CH_16 ((uint8_t)0x10) #define ADC_CH_17 ((uint8_t)0x11) #define ADC_CH_18 ((uint8_t)0x12) #define ADC_CH_TEMP_SENSOR ((uint8_t)ADC_CH_16) #define ADC_CH_INT_VREF ((uint8_t)ADC_CH_18) #define IsAdcChannel(CHANNEL) \ (((CHANNEL) == ADC_CH_0) || ((CHANNEL) == ADC_CH_1) || ((CHANNEL) == ADC_CH_2) || ((CHANNEL) == ADC_CH_3) \ || ((CHANNEL) == ADC_CH_4) || ((CHANNEL) == ADC_CH_5) || ((CHANNEL) == ADC_CH_6) || ((CHANNEL) == ADC_CH_7) \ || ((CHANNEL) == ADC_CH_8) || ((CHANNEL) == ADC_CH_9) || ((CHANNEL) == ADC_CH_10) || ((CHANNEL) == ADC_CH_11) \ || ((CHANNEL) == ADC_CH_12) || ((CHANNEL) == ADC_CH_13) || ((CHANNEL) == ADC_CH_14) || ((CHANNEL) == ADC_CH_15) \ || ((CHANNEL) == ADC_CH_16) || ((CHANNEL) == ADC_CH_17) || ((CHANNEL) == ADC_CH_18)) /** * @} */ /** @addtogroup ADC_sampling_time * @{ */ #define ADC_SAMP_TIME_1CYCLES5 ((uint8_t)0x00) #define ADC_SAMP_TIME_7CYCLES5 ((uint8_t)0x01) #define ADC_SAMP_TIME_13CYCLES5 ((uint8_t)0x02) #define ADC_SAMP_TIME_28CYCLES5 ((uint8_t)0x03) #define ADC_SAMP_TIME_41CYCLES5 ((uint8_t)0x04) #define ADC_SAMP_TIME_55CYCLES5 ((uint8_t)0x05) #define ADC_SAMP_TIME_71CYCLES5 ((uint8_t)0x06) #define ADC_SAMP_TIME_239CYCLES5 ((uint8_t)0x07) #define IsAdcSampleTime(TIME) \ (((TIME) == ADC_SAMP_TIME_1CYCLES5) || ((TIME) == ADC_SAMP_TIME_7CYCLES5) || ((TIME) == ADC_SAMP_TIME_13CYCLES5) \ || ((TIME) == ADC_SAMP_TIME_28CYCLES5) || ((TIME) == ADC_SAMP_TIME_41CYCLES5) \ || ((TIME) == ADC_SAMP_TIME_55CYCLES5) || ((TIME) == ADC_SAMP_TIME_71CYCLES5) \ || ((TIME) == ADC_SAMP_TIME_239CYCLES5)) /** * @} */ /** @addtogroup ADC_external_trigger_sources_for_injected_channels_conversion * @{ */ #define ADC_EXT_TRIG_INJ_CONV_T2_TRGO ((uint32_t)0x00002000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIG_INJ_CONV_T2_CC1 ((uint32_t)0x00003000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIG_INJ_CONV_T3_CC4 ((uint32_t)0x00004000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIG_INJ_CONV_T4_TRGO ((uint32_t)0x00005000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIG_INJ_CONV_EXT_INT15_TIM8_CC4 ((uint32_t)0x00006000) /*!< For ADC1 and ADC2 */ #define ADC_EXT_TRIG_INJ_CONV_T1_TRGO ((uint32_t)0x00000000) /*!< For ADC1, ADC2, ADC3 and ADC4 */ #define ADC_EXT_TRIG_INJ_CONV_T1_CC4 ((uint32_t)0x00001000) /*!< For ADC1, ADC2, ADC3 and ADC4 */ #define ADC_EXT_TRIG_INJ_CONV_NONE ((uint32_t)0x00007000) /*!< For ADC1, ADC2, ADC3 and ADC4 */ #define ADC_EXT_TRIG_INJ_CONV_T4_CC3 ((uint32_t)0x00002000) /*!< For ADC3 and ADC4 */ #define ADC_EXT_TRIG_INJ_CONV_T8_CC2 ((uint32_t)0x00003000) /*!< For ADC3 and ADC4 */ #define ADC_EXT_TRIG_INJ_CONV_T8_CC4 ((uint32_t)0x00004000) /*!< For ADC3 and ADC4 */ #define ADC_EXT_TRIG_INJ_CONV_T5_TRGO ((uint32_t)0x00005000) /*!< For ADC3 and ADC4 */ #define ADC_EXT_TRIG_INJ_CONV_EXT_INT14_T5_CC4 ((uint32_t)0x00006000) /*!< For ADC3 and ADC4 */ #define IsAdcExtInjTrig(INJTRIG) \ (((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T1_TRGO) || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T1_CC4) \ || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T2_TRGO) || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T2_CC1) \ || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T3_CC4) || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T4_TRGO) \ || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_EXT_INT15_TIM8_CC4) || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_NONE) \ || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T4_CC3) || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T8_CC2) \ || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T8_CC4) || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_T5_TRGO) \ || ((INJTRIG) == ADC_EXT_TRIG_INJ_CONV_EXT_INT14_T5_CC4)) /** * @} */ /** @addtogroup ADC_injected_channel_selection * @{ */ #define ADC_INJ_CH_1 ((uint8_t)0x14) #define ADC_INJ_CH_2 ((uint8_t)0x18) #define ADC_INJ_CH_3 ((uint8_t)0x1C) #define ADC_INJ_CH_4 ((uint8_t)0x20) #define IsAdcInjCh(CHANNEL) \ (((CHANNEL) == ADC_INJ_CH_1) || ((CHANNEL) == ADC_INJ_CH_2) || ((CHANNEL) == ADC_INJ_CH_3) \ || ((CHANNEL) == ADC_INJ_CH_4)) /** * @} */ /** @addtogroup ADC_analog_watchdog_selection * @{ */ #define ADC_ANALOG_WTDG_SINGLEREG_ENABLE ((uint32_t)0x00800200) #define ADC_ANALOG_WTDG_SINGLEINJEC_ENABLE ((uint32_t)0x00400200) #define ADC_ANALOG_WTDG_SINGLEREG_OR_INJEC_ENABLE ((uint32_t)0x00C00200) #define ADC_ANALOG_WTDG_ALLREG_ENABLE ((uint32_t)0x00800000) #define ADC_ANALOG_WTDG_ALLINJEC_ENABLE ((uint32_t)0x00400000) #define ADC_ANALOG_WTDG_ALLREG_ALLINJEC_ENABLE ((uint32_t)0x00C00000) #define ADC_ANALOG_WTDG_NONE ((uint32_t)0x00000000) #define IsAdcAnalogWatchdog(WATCHDOG) \ (((WATCHDOG) == ADC_ANALOG_WTDG_SINGLEREG_ENABLE) || ((WATCHDOG) == ADC_ANALOG_WTDG_SINGLEINJEC_ENABLE) \ || ((WATCHDOG) == ADC_ANALOG_WTDG_SINGLEREG_OR_INJEC_ENABLE) || ((WATCHDOG) == ADC_ANALOG_WTDG_ALLREG_ENABLE) \ || ((WATCHDOG) == ADC_ANALOG_WTDG_ALLINJEC_ENABLE) || ((WATCHDOG) == ADC_ANALOG_WTDG_ALLREG_ALLINJEC_ENABLE) \ || ((WATCHDOG) == ADC_ANALOG_WTDG_NONE)) /** * @} */ /** @addtogroup ADC_interrupts_definition * @{ */ #define ADC_INT_ENDC ((uint16_t)0x0220) #define ADC_INT_AWD ((uint16_t)0x0140) #define ADC_INT_JENDC ((uint16_t)0x0480) #define IsAdcInt(IT) ((((IT) & (uint16_t)0xF81F) == 0x00) && ((IT) != 0x00)) #define IsAdcGetInt(IT) (((IT) == ADC_INT_ENDC) || ((IT) == ADC_INT_AWD) || ((IT) == ADC_INT_JENDC)) /** * @} */ /** @addtogroup ADC_flags_definition * @{ */ #define ADC_FLAG_AWDG ((uint8_t)0x01) #define ADC_FLAG_ENDC ((uint8_t)0x02) #define ADC_FLAG_JENDC ((uint8_t)0x04) #define ADC_FLAG_JSTR ((uint8_t)0x08) #define ADC_FLAG_STR ((uint8_t)0x10) #define ADC_FLAG_EOC_ANY ((uint8_t)0x20) #define ADC_FLAG_JEOC_ANY ((uint8_t)0x40) #define IsAdcClrFlag(FLAG) ((((FLAG) & (uint8_t)0x80) == 0x00) && ((FLAG) != 0x00)) #define IsAdcGetFlag(FLAG) \ (((FLAG) == ADC_FLAG_AWDG) || ((FLAG) == ADC_FLAG_ENDC) || ((FLAG) == ADC_FLAG_JENDC) || ((FLAG) == ADC_FLAG_JSTR) \ || ((FLAG) == ADC_FLAG_STR) || ((FLAG) == ADC_FLAG_EOC_ANY) || ((FLAG) == ADC_FLAG_JEOC_ANY)) /** * @} */ /** @addtogroup ADC_thresholds * @{ */ #define IsAdcValid(THRESHOLD) ((THRESHOLD) <= 0xFFF) /** * @} */ /** @addtogroup ADC_injected_offset * @{ */ #define IsAdcOffsetValid(OFFSET) ((OFFSET) <= 0xFFF) /** * @} */ /** @addtogroup ADC_injected_length * @{ */ #define IsAdcInjLenValid(LENGTH) (((LENGTH) >= 0x1) && ((LENGTH) <= 0x4)) /** * @} */ /** @addtogroup ADC_injected_rank * @{ */ #define IsAdcInjRankValid(RANK) (((RANK) >= 0x1) && ((RANK) <= 0x4)) /** * @} */ /** @addtogroup ADC_regular_length * @{ */ #define IsAdcSeqLenValid(LENGTH) (((LENGTH) >= 0x1) && ((LENGTH) <= 0x10)) /** * @} */ /** @addtogroup ADC_regular_rank * @{ */ #define IsAdcReqRankValid(RANK) (((RANK) >= 0x1) && ((RANK) <= 0x10)) /** * @} */ /** @addtogroup ADC_regular_discontinuous_mode_number * @{ */ #define IsAdcSeqDiscNumberValid(NUMBER) (((NUMBER) >= 0x1) && ((NUMBER) <= 0x8)) /** * @} */ /************************** fllowing bit seg in ex register **********************/ /**@addtogroup ADC_channels_ex_style * @{ */ #define ADC1_Channel_01_PA0 ((uint8_t)0x01) #define ADC1_Channel_02_PA1 ((uint8_t)0x02) #define ADC1_Channel_03_PA6 ((uint8_t)0x03) #define ADC1_Channel_04_PA3 ((uint8_t)0x04) #define ADC1_Channel_05_PF4 ((uint8_t)0x05) #define ADC1_Channel_06_PC0 ((uint8_t)0x06) #define ADC1_Channel_07_PC1 ((uint8_t)0x07) #define ADC1_Channel_08_PC2 ((uint8_t)0x08) #define ADC1_Channel_09_PC3 ((uint8_t)0x09) #define ADC1_Channel_10_PF2 ((uint8_t)0x0A) #define ADC1_Channel_11_PA2 ((uint8_t)0x0B) #define ADC2_Channel_01_PA4 ((uint8_t)0x01) #define ADC2_Channel_02_PA5 ((uint8_t)0x02) #define ADC2_Channel_03_PB1 ((uint8_t)0x03) #define ADC2_Channel_04_PA7 ((uint8_t)0x04) #define ADC2_Channel_05_PC4 ((uint8_t)0x05) #define ADC2_Channel_06_PC0 ((uint8_t)0x06) #define ADC2_Channel_07_PC1 ((uint8_t)0x07) #define ADC2_Channel_08_PC2 ((uint8_t)0x08) #define ADC2_Channel_09_PC3 ((uint8_t)0x09) #define ADC2_Channel_10_PF2 ((uint8_t)0x0A) #define ADC2_Channel_11_PA2 ((uint8_t)0x0B) #define ADC2_Channel_12_PC5 ((uint8_t)0x0C) #define ADC2_Channel_13_PB2 ((uint8_t)0x0D) #define ADC3_Channel_01_PB11 ((uint8_t)0x01) #define ADC3_Channel_02_PE9 ((uint8_t)0x02) #define ADC3_Channel_03_PE13 ((uint8_t)0x03) #define ADC3_Channel_04_PE12 ((uint8_t)0x04) #define ADC3_Channel_05_PB13 ((uint8_t)0x05) #define ADC3_Channel_06_PE8 ((uint8_t)0x06) #define ADC3_Channel_07_PD10 ((uint8_t)0x07) #define ADC3_Channel_08_PD11 ((uint8_t)0x08) #define ADC3_Channel_09_PD12 ((uint8_t)0x09) #define ADC3_Channel_10_PD13 ((uint8_t)0x0A) #define ADC3_Channel_11_PD14 ((uint8_t)0x0B) #define ADC3_Channel_12_PB0 ((uint8_t)0x0C) #define ADC3_Channel_13_PE7 ((uint8_t)0x0D) #define ADC3_Channel_14_PE10 ((uint8_t)0x0E) #define ADC3_Channel_15_PE11 ((uint8_t)0x0F) #define ADC4_Channel_01_PE14 ((uint8_t)0x01) #define ADC4_Channel_02_PE15 ((uint8_t)0x02) #define ADC4_Channel_03_PB12 ((uint8_t)0x03) #define ADC4_Channel_04_PB14 ((uint8_t)0x04) #define ADC4_Channel_05_PB15 ((uint8_t)0x05) #define ADC4_Channel_06_PE8 ((uint8_t)0x06) #define ADC4_Channel_07_PD10 ((uint8_t)0x07) #define ADC4_Channel_08_PD11 ((uint8_t)0x08) #define ADC4_Channel_09_PD12 ((uint8_t)0x09) #define ADC4_Channel_10_PD13 ((uint8_t)0x0A) #define ADC4_Channel_11_PD14 ((uint8_t)0x0B) #define ADC4_Channel_12_PD8 ((uint8_t)0x0C) #define ADC4_Channel_13_PD9 ((uint8_t)0x0D) #define ADC_CH_0 ((uint8_t)0x00) #define ADC_CH_1 ((uint8_t)0x01) #define ADC_CH_2 ((uint8_t)0x02) #define ADC_CH_3 ((uint8_t)0x03) #define ADC_CH_4 ((uint8_t)0x04) #define ADC_CH_5 ((uint8_t)0x05) #define ADC_CH_6 ((uint8_t)0x06) #define ADC_CH_7 ((uint8_t)0x07) #define ADC_CH_8 ((uint8_t)0x08) #define ADC_CH_9 ((uint8_t)0x09) #define ADC_CH_10 ((uint8_t)0x0A) #define ADC_CH_11 ((uint8_t)0x0B) #define ADC_CH_12 ((uint8_t)0x0C) #define ADC_CH_13 ((uint8_t)0x0D) #define ADC_CH_14 ((uint8_t)0x0E) #define ADC_CH_15 ((uint8_t)0x0F) #define ADC_CH_16 ((uint8_t)0x10) #define ADC_CH_17 ((uint8_t)0x11) #define ADC_CH_18 ((uint8_t)0x12) /** * @} */ /**@addtogroup ADC_dif_sel_ch_definition * @{ */ #define ADC_DIFSEL_CHS_MASK ((uint32_t)0x0007FFFE) #define ADC_DIFSEL_CHS_1 ((uint32_t)0x00000002) #define ADC_DIFSEL_CHS_2 ((uint32_t)0x00000004) #define ADC_DIFSEL_CHS_3 ((uint32_t)0x00000008) #define ADC_DIFSEL_CHS_4 ((uint32_t)0x00000010) #define ADC_DIFSEL_CHS_5 ((uint32_t)0x00000020) #define ADC_DIFSEL_CHS_6 ((uint32_t)0x00000040) #define ADC_DIFSEL_CHS_7 ((uint32_t)0x00000080) #define ADC_DIFSEL_CHS_8 ((uint32_t)0x00000100) #define ADC_DIFSEL_CHS_9 ((uint32_t)0x00000200) #define ADC_DIFSEL_CHS_10 ((uint32_t)0x00000400) #define ADC_DIFSEL_CHS_11 ((uint32_t)0x00000800) #define ADC_DIFSEL_CHS_12 ((uint32_t)0x00001000) #define ADC_DIFSEL_CHS_13 ((uint32_t)0x00002000) #define ADC_DIFSEL_CHS_14 ((uint32_t)0x00004000) #define ADC_DIFSEL_CHS_15 ((uint32_t)0x00008000) #define ADC_DIFSEL_CHS_16 ((uint32_t)0x00010000) #define ADC_DIFSEL_CHS_17 ((uint32_t)0x00020000) #define ADC_DIFSEL_CHS_18 ((uint32_t)0x00040000) /** * @} */ /**@addtogroup ADC_calfact_definition * @{ */ #define ADC_CALFACT_CALFACTD_MSK ((uint32_t)0x3FL << 16) #define ADC_CALFACT_CALFACTS_MSK ((uint32_t)0x3FL << 0) /** * @} */ /**@addtogroup ADC_ctrl3_definition * @{ */ #define ADC_CTRL3_VABTMEN_MSK ((uint32_t)0x01L << 11) #define ADC_CTRL3_DPWMOD_MSK ((uint32_t)0x01L << 10) #define ADC_CTRL3_JENDCAIEN_MSK ((uint32_t)0x01L << 9) #define ADC_CTRL3_ENDCAIEN_MSK ((uint32_t)0x01L << 8) #define ADC_CTRL3_BPCAL_MSK ((uint32_t)0x01L << 7) #define ADC_CTRL3_PDRDY_MSK ((uint32_t)0x01L << 6) #define ADC_CTRL3_RDY_MSK ((uint32_t)0x01L << 5) #define ADC_CTRL3_CKMOD_MSK ((uint32_t)0x01L << 4) #define ADC_CTRL3_CALALD_MSK ((uint32_t)0x01L << 3) #define ADC_CTRL3_CALDIF_MSK ((uint32_t)0x01L << 2) #define ADC_CTRL3_RES_MSK ((uint32_t)0x03L << 0) /** * @} */ /**@addtogroup ADC_sampt3_definition * @{ */ #define ADC_SAMPT3_SAMPSEL_MSK ((uint32_t)0x01L << 3) /** * @} */ typedef enum { ADC_CTRL3_CKMOD_AHB = 0, ADC_CTRL3_CKMOD_PLL = 1, } ADC_CTRL3_CKMOD; typedef enum { ADC_CTRL3_RES_12BIT = 3, ADC_CTRL3_RES_10BIT = 2, ADC_CTRL3_RES_8BIT = 1, ADC_CTRL3_RES_6BIT = 0, } ADC_CTRL3_RES; typedef struct { FunctionalState VbatMinitEn; FunctionalState DeepPowerModEn; FunctionalState JendcIntEn; FunctionalState EndcIntEn; ADC_CTRL3_CKMOD ClkMode; FunctionalState CalAtuoLoadEn; bool DifModCal; ADC_CTRL3_RES ResBit; bool SampSecondStyle; } ADC_InitTypeEx; /** * @} */ /*ADC_SAMPT3 only have samp time and smp18[2:0],samp18 is refint ch, change to row function*/ /*ADC_IPTST reseverd register ,not to do it*/ /**@addtogroup ADC_bit_num_definition * @{ */ #define ADC_RST_BIT_12 ((uint32_t)0x03) #define ADC_RST_BIT_10 ((uint32_t)0x02) #define ADC_RST_BIT_8 ((uint32_t)0x01) #define ADC_RESULT_BIT_6 ((uint32_t)0x00) /** * @} */ /** @addtogroup ADC_flags_ex_definition * @{ */ #define ADC_FLAG_RDY ((uint8_t)0x20) #define ADC_FLAG_PD_RDY ((uint8_t)0x40) #define IS_ADC_GET_READY(FLAG) (((FLAG) == ADC_FLAG_RDY) || ((FLAG) == ADC_FLAG_PD_RDY) /** * @} */ /** * @} */ /** @addtogroup ADC_Exported_Functions * @{ */ void ADC_DeInit(ADC_Module* ADCx); void ADC_Init(ADC_Module* ADCx, ADC_InitType* ADC_InitStruct); void ADC_InitStruct(ADC_InitType* ADC_InitStruct); void ADC_Enable(ADC_Module* ADCx, FunctionalState Cmd); void ADC_EnableDMA(ADC_Module* ADCx, FunctionalState Cmd); void ADC_ConfigInt(ADC_Module* ADCx, uint16_t ADC_IT, FunctionalState Cmd); void ADC_StartCalibration(ADC_Module* ADCx); FlagStatus ADC_GetCalibrationStatus(ADC_Module* ADCx); void ADC_EnableSoftwareStartConv(ADC_Module* ADCx, FunctionalState Cmd); FlagStatus ADC_GetSoftwareStartConvStatus(ADC_Module* ADCx); void ADC_ConfigDiscModeChannelCount(ADC_Module* ADCx, uint8_t Number); void ADC_EnableDiscMode(ADC_Module* ADCx, FunctionalState Cmd); void ADC_ConfigRegularChannel(ADC_Module* ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime); void ADC_EnableExternalTrigConv(ADC_Module* ADCx, FunctionalState Cmd); uint16_t ADC_GetDat(ADC_Module* ADCx); uint32_t ADC_GetDualModeConversionDat(ADC_Module* ADCx); void ADC_EnableAutoInjectedConv(ADC_Module* ADCx, FunctionalState Cmd); void ADC_EnableInjectedDiscMode(ADC_Module* ADCx, FunctionalState Cmd); void ADC_ConfigExternalTrigInjectedConv(ADC_Module* ADCx, uint32_t ADC_ExternalTrigInjecConv); void ADC_EnableExternalTrigInjectedConv(ADC_Module* ADCx, FunctionalState Cmd); void ADC_EnableSoftwareStartInjectedConv(ADC_Module* ADCx, FunctionalState Cmd); FlagStatus ADC_GetSoftwareStartInjectedConvCmdStatus(ADC_Module* ADCx); void ADC_ConfigInjectedChannel(ADC_Module* ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime); void ADC_ConfigInjectedSequencerLength(ADC_Module* ADCx, uint8_t Length); void ADC_SetInjectedOffsetDat(ADC_Module* ADCx, uint8_t ADC_InjectedChannel, uint16_t Offset); uint16_t ADC_GetInjectedConversionDat(ADC_Module* ADCx, uint8_t ADC_InjectedChannel); void ADC_ConfigAnalogWatchdogWorkChannelType(ADC_Module* ADCx, uint32_t ADC_AnalogWatchdog); void ADC_ConfigAnalogWatchdogThresholds(ADC_Module* ADCx, uint16_t HighThreshold, uint16_t LowThreshold); void ADC_ConfigAnalogWatchdogSingleChannel(ADC_Module* ADCx, uint8_t ADC_Channel); void ADC_EnableTempSensorVrefint(FunctionalState Cmd); FlagStatus ADC_GetFlagStatus(ADC_Module* ADCx, uint8_t ADC_FLAG); void ADC_ClearFlag(ADC_Module* ADCx, uint8_t ADC_FLAG); INTStatus ADC_GetIntStatus(ADC_Module* ADCx, uint16_t ADC_IT); void ADC_ClearIntPendingBit(ADC_Module* ADCx, uint16_t ADC_IT); void ADC_InitEx(ADC_Module* ADCx, ADC_InitTypeEx* ADC_InitStructEx); void ADC_SetDifChs(ADC_Module* ADCx,uint32_t DifChs); FlagStatus ADC_GetFlagStatusNew(ADC_Module* ADCx, uint8_t ADC_FLAG_NEW); void ADC_SetBypassCalibration(ADC_Module* ADCx, FunctionalState en); void ADC_SetConvResultBitNum(ADC_Module* ADCx, uint32_t ResultBitNum); void ADC_ConfigClk(ADC_CTRL3_CKMOD ADC_ClkMode, uint32_t RCC_ADCHCLKPrescaler); /** * @} */ #ifdef __cplusplus } #endif #endif /*__N32G45X_ADC_H__ */ /** * @} */ /** * @} */