单片机学习小组
直播中

吴湛

9年用户 883经验值
擅长:电源/新能源
私信 关注

关于stm32f1中的ADC和DMA理解

怎样去校准STM32f1中的ADC呢?
怎样去理解stm32f1中的ADC和DMA呢?



回帖(1)

周睫蒙

2022-2-21 14:58:00
        本文主要讲解stm32f1ADC和DMA的理解,不讲最基础的配置,需要对ADC和DMA有一定了解。另外在学习中参考了多篇文章,感谢前辈的付出。
        在使用ADC过程中,我先是对ADC的校准过程产生了疑问
        如上图最后两行可知,校准前ADC既要上电又要关电。。。我甚是不解,重看资料才理解

         校准应该满足ADON第一次置1,且在置1之前置0时间超过两个ADC周期,并且在读这段话时,我又重新对ADC的转换启动方式有了新的认识。

         在看这个CR2寄存器ADON位之前,我一直以为ADC转换触发方式只有外部触发转换 和 软件设置CR2第22位SWSTART。但现在多了连续置ADON位为1这种方式,经过试验发现这种方式确实可行,于是我想在不开启连续转换模式下ADON在两次置1后会清0吗?

         如上图所示,打开逻辑分析仪,读取CR2的ADON位可知,在ADON置1后不对其进行置0操作则一直保持1,即第一次读取完后对ADON置一下1,ADC就可以转换一次,
        在了解完ADC的转换开启后,我又开始使用ADC的DMA请求

         上图简单的一段话其暗藏了十分多的内容,我们逐一来看,第一句话直接表明了一个必须使用DMA的场景——在ADC开启多通道转换时,想要得到每个通道ADC转换的值,就必须开启对应的DMA通道,也就是说,当开启CR1SCAN位时,我们所配置的ADC规则通道组将会按照我们所安排的顺序去开启转换,然后将值放入DR寄存器中,但是,问题就在这里。

        如上图所示,ADC的数据位被存放在了DR寄存器的前16位,但这只有16位,多通道读取时,一次扫描将会有多个数据被存放,那当然会把之前的数据给顶替掉,所以DMA在这个时候起了大作用
        如上图,DMA在得到ADC某个通道转换结束的信号时,就会将DR中的数据发送给外设寄存器或存储器(如SRAM),所以,我们可以设置一个数组,将多个数据存储下来。
        但我那时产生了一个很傻的想法,那就是当第一个ADC通道转换完之后,DMA开始传输数据,那么第二个通道的转换是在DMA传输完成后开始还是边传输边转换

         如上图所示,红线为SR的规则通道开始转换位,绿线为规则通道转换结束位,蓝色为DMA_ISR的传输完成中断位,由上图分析可知,红线拉高(ADC开始转换),绿线拉高(ADC转换完成),蓝线拉高(DMA传输完成),绿线拉低(ADC转换完成中断被清0),可见只有DMA传输完,ADC中断才被清零 (跟下图对应) ,进行下一个通道的转换。

        那三句话是什么意思呢?

        再读双ADC的快速交叉模式,配合着DR寄存器对高16位的讲解,一下就了然了。
        第一次写博客,写的都不是啥重点,有错误的地方请各位指出,我看到会及时修改。
举报

更多回帖

发帖
×
20
完善资料,
赚取积分