1 ADC硬件原理#
模数转换器即A/D转换器,或简称ADC,通常是指一个将模拟信号转变为数字信号的电子元件。
如图,把可变电阻上的电压值变换的模拟信号通过ADC转换,输出数字信号。以s3c2440为例:
1.1 ADC属性#
对于数字信号我们需要得到它的2个属性:
转换精度:
用多少位来存储这个数据(假如是10 bit)。那么最大值0b111111111对应3.3v, 0b0对应0v。采样/转换速度:
可以看出s3c2440的转换精度可达10 bit, 转换速率可达 500ksps.
1.2 ADC框图#
下图是s3c2440芯片的ADC转换框图:
可以看出AD converter前有一个MUX选择器,用来选择模拟输入源,这里选择A[3:0]作为输入源。
下面是编写程序要做的步骤:
1.确定是哪一路信号:设置8:1MUX
2.设置工作时钟
3.启动ADC
4.读状态,判断ADC转换是否成功。
5.读数据
2 ADC寄存器#
2.1 控制寄存器(ADCCON)#
bit[15]:只读,用来表示转换是否完成
bit[14:6]:用来设置adc频率(如果是auto TSC则不用设置该位)
bit[5:3]:用来选择模拟输入源
bit[2]:用来设置是否待机
bit[0]:用来启动adc
2.2 启动延时寄存器(ADCDLY)#
2.3 数据寄存器(ADCDAT0)#
bit[9:0]表示转换后的数据
3 编程测试#
1 | void adc_init(void) { |