• 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文档







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

  • 相关阅读:
    ubuntu中KDE与GNOME安装切换
    前向算法的数学意义上的实现
    题目1023:EXCEL排序
    题目1022:游船出租
    php notice提示
    Php显示中文时乱码
    题目1021:统计字符
    题目1020:最小长方形
    题目1013:开门人和关门人
    题目1032:ZOJ
  • 原文地址:https://www.cnblogs.com/lcchuguo/p/4713950.html
Copyright © 2020-2023  润新知