fuzidage
专注嵌入式、linux驱动 、arm裸机研究

导航

 

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;
}

测试结果如下:

posted on 2020-07-29 14:37  fuzidage  阅读(341)  评论(0编辑  收藏  举报