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文档
版权声明:本文博客原创文章。博客,未经同意,不得转载。