gd32f303 ADC注入

时间: 2023-07-18 10:52:23 浏览: 37
gd32f303是一款基于ARM Cortex-M4内核的微控制器,其ADC模块支持多通道的ADC注入模式。使用ADC注入模式可以在不干扰常规转换的情况下进行一些特殊的测量,比如频率、周期等。以下是基本的ADC注入模式配置步骤: 1. 配置ADC时钟和时钟分频系数 2. 配置ADC外设并使能ADC时钟 3. 配置ADC通道和采样时间 4. 配置ADC注入序列 5. 配置注入触发源 6. 使能ADC注入模式 7. 启动一次注入转换 需要注意的是,在注入转换完成后需要手动清除转换标志位,并且在下一次注入转换之前必须等待转换完成。具体配置方法可以参考GD32F30x固件库中的ADC_InjectedChannelConfig函数。
相关问题

GD32F303 ADC代码

以下是使用GD32F303芯片的ADC代码示例: ```c #include "gd32f30x.h" void ADC_Configuration(void) { /* 使能 ADC0 时钟 */ rcu_periph_clock_enable(RCU_ADC0); /* 配置 ADC0 工作模式为单次转换模式 */ adc_mode_config(ADC_MODE_FREE); /* 配置 ADC0 外部触发源为软件触发 */ adc_external_trigger_source_config(ADC_INSERTED_CHANNEL, ADC_EXTTRIG_INSERTED_NONE); /* 配置 ADC0 触发通道为 ADC_CHANNEL_0 */ adc_channel_length_config(ADC_INSERTED_CHANNEL, 1); adc_inserted_channel_config(0, ADC_CHANNEL_0, ADC_SAMPLETIME_239POINT5); /* 配置 ADC0 转换个数为1 */ adc_special_function_config(ADC_INSERTED_CHANNEL, ADC_SCAN_MODE, DISABLE); adc_special_function_config(ADC_INSERTED_CHANNEL, ADC_CONTINUOUS_MODE, DISABLE); adc_special_function_config(ADC_INSERTED_CHANNEL, ADC_INSERTED_SCAN, DISABLE); /* 使能 ADC0 */ adc_enable(ADC_INSERTED_CHANNEL); /* ADC0 开始转换 */ adc_calibration_enable(ADC_INSERTED_CHANNEL); } int main(void) { /* ADC 配置 */ ADC_Configuration(); while (1) { /* ADC0 开始转换 */ adc_software_trigger_enable(ADC_INSERTED_CHANNEL); /* 等待 ADC0 转换完成 */ while (RESET == adc_flag_get(ADC_INSERTED_CHANNEL, ADC_FLAG_EOC)); /* 读取 ADC0 转换结果 */ uint16_t adc_value = adc_injected_data_read(ADC_INSERTED_CHANNEL, 0); /* 处理 ADC0 转换结果 */ // TODO } } ``` 此代码使用单次转换模式进行 ADC0 转换,触发通道为 ADC_CHANNEL_0,转换结果存储在插入通道的第一个转换结果中。ADC0 的转换结果可以通过调用 `adc_injected_data_read` 函数来读取。

GD32F303 ADC例程

以下是基于GD32F303芯片的ADC例程,你可以参考: ```c #include "gd32f30x.h" #include <stdio.h> #define ADC_GPIO_PORT GPIOA #define ADC_GPIO_PIN GPIO_PIN_0 #define ADC_GPIO_CLK RCU_GPIOA #define ADC_DMA_CHANNEL DMA_CH0 #define ADC_DMA_CLK RCU_DMA0 #define ADC_DMA_IRQ DMA0_Channel0_IRQn #define ADC_DMA_IRQHANDLER DMA0_Channel0_IRQHandler uint16_t adc_value[16]; void adc_gpio_config(void); void adc_config(void); void dma_config(void); int main(void) { // 使能GPIOA时钟 rcu_periph_clock_enable(ADC_GPIO_CLK); // 配置GPIOA.0为模拟输入 adc_gpio_config(); // 配置ADC adc_config(); // 配置DMA dma_config(); // 启动DMA传输 dma_channel_enable(DMA0, ADC_DMA_CHANNEL); while (1) { // 等待DMA传输完成 while(!dma_flag_get(DMA0, ADC_DMA_CHANNEL, DMA_FLAG_FTF)); // 输出ADC值 for(int i = 0; i < 16; i++) { printf("ADC%d value: %d\n", i, adc_value[i]); } // 清除DMA传输完成标志位 dma_flag_clear(DMA0, ADC_DMA_CHANNEL, DMA_FLAG_FTF); } } void adc_gpio_config(void) { gpio_init(ADC_GPIO_PORT, GPIO_MODE_AIN, GPIO_OSPEED_50MHZ, ADC_GPIO_PIN); } void adc_config(void) { // 使能ADC时钟 rcu_periph_clock_enable(RCU_ADC0); // ADC时钟分频 adc_clock_config(ADC_ADCCK_PCLK2_DIV8); // ADC模式配置 adc_mode_config(ADC_MODE_FREE); // ADC通道配置 adc_channel_length_config(ADC_REGULAR_CHANNEL, 16); adc_regular_channel_config(0, ADC_CHANNEL_0, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(1, ADC_CHANNEL_1, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(2, ADC_CHANNEL_2, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(3, ADC_CHANNEL_3, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(4, ADC_CHANNEL_4, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(5, ADC_CHANNEL_5, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(6, ADC_CHANNEL_6, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(7, ADC_CHANNEL_7, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(8, ADC_CHANNEL_8, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(9, ADC_CHANNEL_9, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(10, ADC_CHANNEL_10, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(11, ADC_CHANNEL_11, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(12, ADC_CHANNEL_12, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(13, ADC_CHANNEL_13, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(14, ADC_CHANNEL_14, ADC_SAMPLETIME_55POINT5); adc_regular_channel_config(15, ADC_CHANNEL_15, ADC_SAMPLETIME_55POINT5); // ADC DMA配置 adc_dma_mode_enable(); adc_dma_request_after_last_enable(); // ADC使能 adc_enable(); delay_1ms(1); adc_calibration_enable(); delay_1ms(1); adc_software_trigger_enable(ADC_REGULAR_CHANNEL); } void dma_config(void) { // 使能DMA时钟 rcu_periph_clock_enable(ADC_DMA_CLK); // DMA通道配置 dma_deinit(DMA0, ADC_DMA_CHANNEL); dma_init_struct.direction = DMA_PERIPHERAL_TO_MEMORY; dma_init_struct.memory_addr = (uint32_t)adc_value; dma_init_struct.memory_inc = DMA_MEMORY_INC_ENABLE; dma_init_struct.memory_width = DMA_MEMORY_WIDTH_16BIT; dma_init_struct.number = 16; dma_init_struct.periph_addr = (uint32_t)&ADC_RDATA(ADC0); dma_init_struct.periph_inc = DMA_PERIPH_INC_DISABLE; dma_init_struct.periph_width = DMA_PERIPHERAL_WIDTH_16BIT; dma_init_struct.priority = DMA_PRIORITY_ULTRA_HIGH; dma_init(DMA0, ADC_DMA_CHANNEL, &dma_init_struct); // DMA中断配置 nvic_irq_enable(ADC_DMA_IRQ, 0, 0); dma_interrupt_enable(DMA0, ADC_DMA_CHANNEL, DMA_INT_FTF); } void ADC_DMA_IRQHANDLER(void) { dma_interrupt_flag_clear(DMA0, ADC_DMA_CHANNEL, DMA_INT_FTF); } ``` 需要注意的是,这个例程使用了DMA传输来获取ADC采样值,因此在使用之前需要先配置DMA。同时,在输出ADC值之前需要等待DMA传输完成。

相关推荐

最新推荐

recommend-type

ADC的规则通道和注入通道混合使用

之前完成了规则通道DMA的数据传输了,不过平时在使用ADC的时候可能就会遇到很多情况,不可能就这样简单的按规则通道来采样,DMA存储,使用数据的;可能有时候会需要立刻采样,那样我们就需要利用到注入通道了。
recommend-type

GD32F207xx_Datasheet_Rev2.0.pdf

GD32F2采用2.6V-3.6V电源,I/O口可承受5V电平。支持高级电源管理并具备三种省电模式。在外部电池供电情况下,内置的高精度可校准实时时钟(RTC)运行时的待机电流低于1uA。支持三相PWM互补输出和霍尔采集接口的2个16位...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

可见光定位LED及其供电硬件具体型号,广角镜头和探测器,实验设计具体流程步骤,

1. 可见光定位LED型号:一般可使用5mm或3mm的普通白色LED,也可以选择专门用于定位的LED,例如OSRAM公司的SFH 4715AS或Vishay公司的VLMU3500-385-120。 2. 供电硬件型号:可以使用常见的直流电源供电,也可以选择专门的LED驱动器,例如Meanwell公司的ELG-75-C或ELG-150-C系列。 3. 广角镜头和探测器型号:一般可采用广角透镜和CMOS摄像头或光电二极管探测器,例如Omron公司的B5W-LA或Murata公司的IRS-B210ST01。 4. 实验设计流程步骤: 1)确定实验目的和研究对象,例如车辆或机器人的定位和导航。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这
recommend-type

解释这行代码 c = ((double)rand() / RAND_MAX) * (a + b - fabs(a - b)) + fabs(a - b);

这行代码的作用是随机生成一个浮点数,范围在 a 和 b 之间(包括 a 和 b)。 其中,`rand()` 函数是 C 语言标准库中的一个函数,用于生成一个伪随机整数。`RAND_MAX` 是一个常量,它表示 `rand()` 函数生成的随机数的最大值。 因此,`(double)rand() / RAND_MAX` 表示生成的随机数在 [0, 1] 之间的浮点数。 然后,将这个随机数乘上 `(a - b) - fabs(a - b)`,再加上 `fabs(a - b)`。 `fabs(a - b)` 是 C 语言标准库中的一个函数,用于计算一个数的绝对值。因此,`fabs(a - b)