s3c2440的A/D转换应用

   10 地点 CMOS ADC(模/数字转换器)是 8 通道模拟输入型设备回收。该模拟输入信号转换 10 位二进制数字编码,A/D变化。也被称为模数转换。该模拟信号被转换成美元

算机可以处理的数字信号。

       对于s3c2440来说。实现A/D转换比較简单,主要做的事情就是 ADC 控制寄存器 ADCCON 和 ADC 转换数据寄存器 ADCDAT0。寄存器ADCDAT0的低10位用于存储A/D转换

后的数据。寄存器ADCCON的第15位用于标识A/D转换是否结束。

第14位用于使能是否进行预分频。而第6位到第13位则存储的是预分频数值,由于A/D转换的速度不能太快,

所以要通过预分频处理才干够得到正确的A/D转换速度。

  

 

  如我们想要得到A/D转换频率为1MHz,则预分频的值应为49。第3位到第5位表示的是A/D转换的通道选择。

第2位能够实现A/D转换的待机模式。第1位用于是否通过读

取操作来使能A/D转换的開始。

第0位则是在第1位被清零的情况下用于开启A/D转换。

 

    

    单独的adc操作 非常easy,就配置下轮询寄存器的某个位变化了就说明採样完成了:

int readADC(INT8U channel)
{
	channel	&= 7;
	rADCCON = (1<<14)|(49<<6)|(channel<<3);              //设置预分频器和A/D通道

	rADCCON|=0x1;                                      //启动A/D转换

	while(rADCCON & 0x1)
		OSTimeDly(1);                                                //确认A/D转换是否開始

	while(!(rADCCON & 0x8000))
		OSTimeDly(1);                                                //等待A/D转换的结束

	return ( (int)rADCDAT0 & 0x3ff );      //读取A/D转换的数据
}

在多任务环境下while循环后面能够增加一个比較短的 OSTimeDly 。


没有什么模拟传感器,能够用螺丝刀转动PR2可见採集数据随着转动改变。  在这里就不把採集的数据显示在lcd上了,只通过串口打印出来吧。



详细代码能够从我github上clone。



參考:

blog.csdn.net/zhaocj/article/details/5495730

s3c2440文档







版权声明:本文博客原创文章。博客,未经同意,不得转载。

原文地址:https://www.cnblogs.com/lcchuguo/p/4713950.html