微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > STM32学习手记(5):数据的保存与毁灭!(一)

STM32学习手记(5):数据的保存与毁灭!(一)

时间:01-18 来源:互联网 点击:

nnel_15, 1, ADC_SampleTime_55Cycles5);

  /* 这个函数一共有4个参数,第一个是指定转换器,根据所采用的器件的不同,可以是ADC1,ADC2,ADC3;第二个参数是指定通道号;第三个参数是指定该通道在转换序列中第几个开始转换,第四个参数是指定转换时间

  第一、二个参数不难理解,这里就不再多说了,看一看第三个参数。

  先看一看这个函数的内容,它在stm32f10x_adc.c中,这是STM库提供的一个函数:

  void ADC_RegularChannelConfig(ADC_TypeDef* ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime)

  { 。。.。。.前面的不写了

  /* For Rank 1 to 6 */

  if (Rank 《 7) //这个Rand就是第三个参数

  {

  /* Get the old register value */

  tmpreg1 = ADCx-》SQR3;

  /* Calculate the mask to clear */

  tmpreg2 = SQR3_SQ_Set 《《 (5 * (Rank - 1));

  SQR3的值如下:

  //#define SQR3_SQ_Set ((uint32_t)0x0000001F)

  之所以用5去乘,看下图中的表格:ADC_SQ3中SQ1~SQ6每个都是占5位。

  这下理解了:如果这个Rank是1,那么tmpreg2这个变量第[4:0]这5位将会是11111(即SQR3_SQ_Set的初始值:0x0000001f),如果Rank是2,那么tmpreg2这个变量的第[9:5]将会是11111,即tmpreg2将等于:0x00001f00,依此类推。

  /* Clear the old SQx bits for the selected rank */

  tmpreg1 = ~tmpreg2;

  /* tmpreg2取反再与,即清掉tmpreg1中相应的5位*/

  tmpreg2 = (uint32_t)ADC_Channel 《《 (5 * (Rank - 1));

  /*这次tmpreg2取的是通道值了,然后同相根据Rank的值左移5、10或更多位 */

  tmpreg1 |= tmpreg2;

  /* Store the new register value */

  ADCx-》SQR3 = tmpreg1;

  }

  */

  

  第四个参数是采样时间设定,代码如下:

  tmpreg2 = (uint32_t)ADC_SampleTime 《《 (3 * ADC_Channel);

  /* 设定新的采样时间,这里为什么用3,理由和上面的5一样,看下图。*/

  tmpreg1 |= tmpreg2;

  /* Store the new register value */

  ADCx-》SMPR2 = tmpreg1;

  

  /* Enable ADC1 DMA */

  ADC_DMACmd(ADC1, ENABLE);

  /* Enable ADC1 */

  ADC_Cmd(ADC1, ENABLE);

  至此一次ADC转换配置完毕。很麻烦。。.。。.也许功能强大的副产品就是麻烦吧,没有办法。

二、使用内置温度传感器测量温度

  学习使用ADC多通道转换方式,验证温度测量的准确性,为以后的工程实践打好基础。

  (1) ADC的单次与连续转换

  ADC转换可以在一次转换后停止,然后再次触发后进行下一次转换;也可以是持续不断地转换下去。这个是通过设定ADC_CR2的CONT位来确定。

  而在ST提供的库里面,是这样来设定的:

  ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;

  (2) ADC的扫描模式

  ADC的扫描模式是用来扫描一组选定的通道的,它们将会被依次转换。这个在上一份笔记中已说明过。

  那么连续转换和扫描转换之间又是什么关系呢?字面上理解,似乎它们都是持续不断地转换啊。

  答案是:连续转换的层次比扫描更高,它管着扫描呢。也就是说,对连续转换来说,它所谓的“一次转换”可并不是指的一个通道的转换结束,而是指的“一组”转换结束,当然,这个“一组”有可能只有一个通道而已。再说得明确一些:当ADC扫描一次结束以后,如果CONT位是“1”(设定为连续转换方式),那么将继续下一轮的转换。

  (3) EOC什么时候产生?

  我的理解应该是每个通道(Channel)转换结束时都会发生。但这里有些问题(见下图):

  

  上面的说明中:该位由硬件在(规则或注入)通道组换结束时设置…其中有个“组”字,字面的理解似乎应该是指一次转换组的所有通道都结束后才置1?但如果是这样,那么又如何进行数据的传递呢?要知道,对于ADC1来说,它的多个通道只有一个用于数据何存的寄存器:ADC1-》DR啊。

  而这个问题在其他两个地方也没有说得清楚(见下图):

  

  我们前面讨论了说连续转换是针对一组转换而言的,所以这里所谓的:每个转换后EOC标志被设置,究竟是一组转换结束后呢还是一个通道结束后呢?不明确。

  而在扫描模式是这么说的(见下图):

  

  这里仅说到:如果设置了DMA位,在每次EOC后…,而并没有说到什么时候会有EOC产生?是所有扫描结束还是每个通道转换结束?

  而关于SCAN位又有这样的说明(见下图):

  

  注意最后的注:如果分别设置了EOCIE或JEOCIE位,只在最后一个通道转换完毕才会产生EOC或者JEOC中断。

对这一行话的理解同样会有歧义:究竟是只在最后一个通道转换完毕才产生EOC或者JEOC呢,还是每个通道转换时都产生EOC或者JEOC,但是

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top