s3c2440裸机编程-ADC

1 ADC硬件原理#

模数转换器即A/D转换器,或简称ADC,通常是指一个将模拟信号转变为数字信号的电子元件。

如图,把可变电阻上的电压值变换的模拟信号通过ADC转换,输出数字信号。以s3c2440为例:

1.1 ADC属性#

对于数字信号我们需要得到它的2个属性:

  1. 转换精度:
    用多少位来存储这个数据(假如是10 bit)。那么最大值0b111111111对应3.3v, 0b0对应0v。

  2. 采样/转换速度:


可以看出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
2
3
4
5
6
7
8
9
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;
}