如上图最后两行可知,校准前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通道,也就是说,当开启CR1的SCAN位时,我们所配置的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位的讲解,一下就了然了。 、来自https://blog.csdn.net/qq_53652152/article/details/119219284
|