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