首页 > 代码库 > 1.13裸机ADC部分

1.13裸机ADC部分

1.13.1、ADC的引入

1.13.1.1、什么是ADC

  • (1)ADC:analog digital converter ,AD转换,模数转换(也就是模拟转数字)
  • (2)CPU本身是数数字的,而外部世界变量(如电压、温度、高度、压力)都是模拟的,所以需要用CPU来处理这些外部的模拟量的时候就需要做AD转换

1.13.1.2、为什么需要ADC

  • (1)为了用数字技术来处理外部的模拟量

1.13.1.3、关于模拟量和数字量

  • (1)模拟的就是连续的,显示生活中的时间、电压、高度等都是模拟的(连续分布的,划分的话可以无限划分)。模拟量反应在数学里面就是无限多个小数位从0到1之间有无数个数。
  • (2)数字的就是离散的,离散的就是不连续的。这种离散处理实际上是数学上对现实中的模拟量的一种精度的描述,数字化就是离散化,就是把连续分布的模拟量按照一定精度采样变成多个不连续分布的数字值,就叫数字量
  • (3)数字化的意义就在于可以用(离散)数字来简化模拟量,这东西是计算机的基础
  • (4)计算机处理参量的时候都是数字化的,计算机也需要数字化的值来参与运算,如果系统输入的模拟量就需要外加一个AD转换器,将这个模拟量转成数字量,再给CPU

1.13.1.4、有AD自然就有DA

  • (1)AD是analog to digital   而DA是digital to analog 
  • (2)纯粹用CPU 不可能实现数字转模拟,因为CPU本身就是数字的。使用一些(具有积分和微分效果的)物理器件,就可以实现数字转模拟。
  • (3)数字转模拟的作用。譬如用来做波形发生器

1.13.2、ADC的主要相关概念

1.13.2.1量程(模拟量的输入范围)

  • (1)AD转换器是一个电子器件,所以只能输入电压信号,其他种类的模拟信号必须经过传感器(sensor)的转换器转换成模拟的电压信号,然后才能给AD
  • (2)AD输入端的模拟电压要求有一个范围,一般是0~3.3V或0~5V或者是0~12V等等。模拟电压的范围是AD芯片本身的一个参数,实际工作时AD的电压信号不能超过这个电压范围

1.13.2.3、精度(分辨率resolution)

  • (1)AD转换输出的数字值是有一定的位数的(譬如说十位,就是说输出的数字值的位数是用十位二进制表示的,这种就叫10位AD)。这个位数就表示了转换精度
  • (2)10位AD就相当于把整个范围分成了1024个格子,每个格子的间隔就是电压的精度,譬如说,加入AD芯片的量程是0~3.3V,则每一个格子的代表的电压值是3.3V,则每个格子代表的电压值是3.3V/1024=0.0032265,如果此时AD转换后得到的数字是447,则这个数字代表的模拟量是447*0.0032265 = 1.44V
  • (3)AD位数越多,则每个格子表示的电压值越小,将来的算出来的值就越小,就越精确。
  • (4)AD的模拟来那个城一样的情况下,AD精度位数越多精度越高,测出来的值越准。但是如果AD的量程不一样。譬如2个AD,A的量程是0~50V,B是0~0.5V,A是12位的,B是10位的,实际上B的精度比A的还要高。(A的精度50/1024 = 0.04883,0.5/4096 =  0.000122)

1.13.2.3、转换速率(MSPS与convert clock不同)

  • (1)首先要明白:AD芯片进行AD转换是耗费时间的。这个时间需要多久,不同的芯片是不一样的,同一颗芯片在配置不一样的(譬如说精度为10位时时间比精度配置为12位时小,譬如说有些AD可以分配转换时钟,时钟频率高则转换时间短)时转换时间也不一样。
  • (2)详细的需要时间可以参考数据手册。一般数据手册中描述转换速率用的单位是MSPS(第一个M是兆,第二个S是sample,,就是采样,后面的PS是每秒,每秒钟转出来多少M个数字值)
  • (3)AD工作都需要一个时钟,这个时钟有一个范围,我们实际给他配置时不要超过这个范围就可以了。AD转换是在这个时钟下进行的,时钟的频率控制着AD转换的速率。注意:时钟频率和MSPS不是一回事,只是成正比不是完全相等。譬如S5PV210中的AD转换器,MSPS = 时钟频率/5

1.13.2.4、通道数

  • (1)AD有多少路analog input通道代表了将来可以同时进行多少路模拟信号的输入

1.13.3、S5PV210的ADC控制器

1.13.3.1、ADC和(电阻式)触摸屏的关系

  • (1)ADC在210的数据手册的section10.7
  • (2)电阻式触摸屏工作时依赖AD转换,所以在210SOC中电阻触摸屏接口本身和ADC接口是合二为一的。或者说电阻触摸屏接口使用了(复用了ADC的接口)

1.13.3.2、ADC的工作时钟框图

  • ADCCLK是ADC控制器工作的时钟,也就是1.13.2.3节中讲到的convertor clock。从时钟框图可以看出,他是PCLK(当然是PCLK_PSYS)经过了一次分频后得到的,所以将来初始化ADC控制器时一定有一个步骤是初始化这里的分频器

1.13.3.3、210的10个ADC通道(注意ADC引脚和GPIO的区别)

  • (1)210一共支持10个ADC通道,分别叫AIN[0]~AIN[9]。理论上可以同时做10路AD转换
  • (2)SoC的引脚至少分2中:digit数字引脚和analog模拟引脚。我们以前接触的GPIO都属于数字引脚,ADCchannel通道引脚属于模拟引脚。数字引脚和模拟引脚一般不复用

1.13.2.4、ADC控制器的主要寄存器

  • TSADCCON0
  • TSDATX0  TSDATY0  转出来的AD值存在这里,我们读也是在这里读
  • CLRINTADC0     清中断
  • ADCMUX            选择当前正在操作的AD通道

(1)等待触摸屏转换完毕的方法有2种:一种是检查标志位,第二种是中断。第一种方式下我们先开启一次转换后循环不同检查标志位直到标志位为1为1表明已经转化好了。可以去读了,第二种方式下就是设置好中断,写好中断isr来读取AD转换数据,然后开启中断后CPU就不用管了,等AD转换完就会生成一个中断给CPU,就会进入中断处理流程,第一种方法是同步的,第二种方式是异步的。

(2)AD转换都是需要反复进行的,那么转完一次一般立即开启下一次转换,所以需要一种机制能够在一次转完时自动开启下一次,这个机制就叫做start by read。这个机制的原理是:当我们读取本次AD转换的AD值后,硬件自动开启下一次转换。

1.13.4转换的变成实战1

 

1.13裸机ADC部分