OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4478|回复: 3

关于定时器中断触发ADC的采样频率

[复制链接]

85

主题

249

帖子

0

精华

高级会员

Rank: 4

积分
674
金钱
674
注册时间
2020-12-5
在线时间
202 小时
发表于 2021-4-5 21:57:31 | 显示全部楼层 |阅读模式
1金钱
仿照论坛上的代码,自己改写了一个定时器中断触发的ADC采样,想要请教一下大家这样写有没有问题?
1.下图是ADC的配置
ADC111.png

2.下图是dma以及dma中断的配置,以及dma中断中配置一旦缓存采集完毕以后就关闭ADC采样
dma111115151231354.png

3.下面是定时器以及定时器中断的配置,在定时器中断函数中执行ADC使能函数。
TIM2111.png TIM2 2222.png
4.这是主函数中设置定时器计数频率的函数。
MAIN111.png
我的问题是:1.我这样配置的话是不是整个过程就是:首先定时器计数到重装载值的时候执行定时器中断函数中的使能ADC采样函数,从而开始ADC采样,由于DMA配置缓存区容量为1,ADC采集到的一个数据从外设传给内存,然后执行DMA中断关闭ADC采样,等到下一个定时器中断函数的执行再次打开ADC进行采样。这样就可以通过配置定时器的频率从而来控制AD采样的频率?这样的话ADC采样频率的理论最大值可以达到多少,为啥我1M就是极限了,TIM2_PWM_Init(8,0)的时候就采集不到数据了?

DMA111.png

最佳答案

查看完整内容[请看2#楼]

一般采样率1M就是极限 看你的型号,手册上找找看有没有ADC的转换时间的说明。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

12

主题

3389

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8646
金钱
8646
注册时间
2020-5-11
在线时间
4103 小时
发表于 2021-4-5 21:57:32 | 显示全部楼层
本帖最后由 LcwSwust 于 2021-4-6 10:47 编辑

一般采样率1M就是极限
看你的型号,手册上找找看有没有ADC的转换时间的说明。
傲游截图20210406104331.jpg
专治疑难杂症
回复

使用道具 举报

11

主题

2147

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4894
金钱
4894
注册时间
2015-1-10
在线时间
612 小时
发表于 2021-4-6 13:33:12 | 显示全部楼层
定时器触发ADC的话直接硬件触发就行了,不需要在定时器中断里面再软件触发ADC,你看看datasheet ADC那一章里面的外部触发源
回复

使用道具 举报

85

主题

249

帖子

0

精华

高级会员

Rank: 4

积分
674
金钱
674
注册时间
2020-12-5
在线时间
202 小时
 楼主| 发表于 2021-4-7 20:26:53 | 显示全部楼层
阿侑kevin 发表于 2021-4-6 13:33
定时器触发ADC的话直接硬件触发就行了,不需要在定时器中断里面再软件触发ADC,你看看datasheet ADC那一章 ...

本来定时器触发的话可以实现,但是DAC就没有办法输出我设定的固定电压了,很奇怪,然后修改了一下dac的设置最后调试成功了。多谢您的回复
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-26 00:27

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表