共2条
1/1 1 跳转至页
,VXWORKS,NUCLEUS,keil,for,arm,01a,ccd,13581980230, 咨询一个ADC的问题
问
我用周立功的LPC2119,采用AIN0进行模拟信号的采集,很奇怪,每次读ADDR中模拟量的值都和我用示波器测的不一样,我把程序贴出来,大家帮我看看吧,谢谢了。
/****************************************************************************
* 头文件
****************************************************************************/
#include "LPC2294.h"
#define LED1CON 0x00040000 /* LED控制,低电平点亮,用于指示 */
#define FPCLK 2768400L
/****************************************************************************
* 名称:DelayNS()
* 功能:长软件延时
* 入口参数:dly 延时参数,值越大,延时越久
* 出口参数:无
****************************************************************************/
void DelayNS(uint32 dly)//dly=1是6.8ms,20是136ms
{ uint32 i;
for(; dly>0; dly--)
for(i=0; i<50000; i++);
}
//短延时
void delay(int dly)//dly=1是1us,100000是31.6ms,500000是156ms
{
int i;
for(;dly>0;dly--)
{
for(i=0;i<2;i++);
}
}
//检测电池电压
void battery_test()
{
uint32 ADC_Data;
PINSEL1 = 0x00400000; // 设置P0.27连接到AIN0
IO0DIR=0x00020000;
/* 进行ADC模块设置,其中x<<n表示第n位设置为x(若x超过一位,则向高位顺延) */
ADCR = (1 << 0) | // SEL = 1 ,选择通道0
((FPCLK / 1000000 - 1) << 8) | // CLKDIV = Fpclk / 1000000 - 1 ,即转换时钟为1MHz
(0 << 16) | // BURST = 0 ,软件控制转换操作
(0 << 17) | // CLKS = 0 ,使用11clock转换
(1 << 21) | // PDN = 1 , 正常工作模式(非掉电转换模式)
(0 << 22) | // TEST1:0 = 00 ,正常工作模式(非测试模式)
(1 << 24) | // START = 1 ,直接启动ADC转换
(0 << 27); // EDGE = 0 (CAP/MAT引脚下降沿触发ADC转换)
DelayNS(10);
ADC_Data = ADDR; // 读取ADC结果,并清除DONE标志位
while(1)
{ ADCR = (ADCR&0xFFFFFF00)|0x01|(1 << 24); // 切换通道并进行第一次转换
while( (ADDR&0x80000000)==0 ); // 等待转换结束
ADCR = ADCR | (1 << 24); // 再次启运转换
while( (ADDR&0x80000000)==0 );
ADC_Data = ADDR; // 读取ADC结果
ADC_Data = (ADC_Data>>6) & 0x3FF;
ADC_Data = ADC_Data * 3300;
ADC_Data = ADC_Data / 1024;
if (ADC_Data<=3000)//2.25*2=4.5V,2250--4.3,2500--4.4
{
IO0CLR=0x00020000;
//DelayNS(30);
//清零P0.17,使蜂鸣器响
}
if (ADC_Data>3000)//2.25*2=4.5V
{
IO0SET=0x00020000;
//清零P0.17,使蜂鸣器响
}
DelayNS(30);
}
}
//主函数
int main(void)
{
PINSEL1=0x00400000;//P0.27:AD,P0.17:IO
PINSEL2=0x00000004; //gpio功能设定,P1.25:16作为GPIO,P1.26-P1.31,P1.18:LED----------------------------------------
IO0DIR=0x00020000;
IO0SET=0x00020000;
IO1DIR=LED1CON;
IO1SET=LED1CON;
delay(500000);
IO1CLR=LED1CON;
delay(500000);
IO1SET=LED1CON;
delay(500000);
IO1CLR=LED1CON;
delay(500000);
battery_test();
while (1);
return(0);//使得main返回一个值给调用程序的外壳,表明程序已经成功运行。
}
/****************************************************************************
* 头文件
****************************************************************************/
#include "LPC2294.h"
#define LED1CON 0x00040000 /* LED控制,低电平点亮,用于指示 */
#define FPCLK 2768400L
/****************************************************************************
* 名称:DelayNS()
* 功能:长软件延时
* 入口参数:dly 延时参数,值越大,延时越久
* 出口参数:无
****************************************************************************/
void DelayNS(uint32 dly)//dly=1是6.8ms,20是136ms
{ uint32 i;
for(; dly>0; dly--)
for(i=0; i<50000; i++);
}
//短延时
void delay(int dly)//dly=1是1us,100000是31.6ms,500000是156ms
{
int i;
for(;dly>0;dly--)
{
for(i=0;i<2;i++);
}
}
//检测电池电压
void battery_test()
{
uint32 ADC_Data;
PINSEL1 = 0x00400000; // 设置P0.27连接到AIN0
IO0DIR=0x00020000;
/* 进行ADC模块设置,其中x<<n表示第n位设置为x(若x超过一位,则向高位顺延) */
ADCR = (1 << 0) | // SEL = 1 ,选择通道0
((FPCLK / 1000000 - 1) << 8) | // CLKDIV = Fpclk / 1000000 - 1 ,即转换时钟为1MHz
(0 << 16) | // BURST = 0 ,软件控制转换操作
(0 << 17) | // CLKS = 0 ,使用11clock转换
(1 << 21) | // PDN = 1 , 正常工作模式(非掉电转换模式)
(0 << 22) | // TEST1:0 = 00 ,正常工作模式(非测试模式)
(1 << 24) | // START = 1 ,直接启动ADC转换
(0 << 27); // EDGE = 0 (CAP/MAT引脚下降沿触发ADC转换)
DelayNS(10);
ADC_Data = ADDR; // 读取ADC结果,并清除DONE标志位
while(1)
{ ADCR = (ADCR&0xFFFFFF00)|0x01|(1 << 24); // 切换通道并进行第一次转换
while( (ADDR&0x80000000)==0 ); // 等待转换结束
ADCR = ADCR | (1 << 24); // 再次启运转换
while( (ADDR&0x80000000)==0 );
ADC_Data = ADDR; // 读取ADC结果
ADC_Data = (ADC_Data>>6) & 0x3FF;
ADC_Data = ADC_Data * 3300;
ADC_Data = ADC_Data / 1024;
if (ADC_Data<=3000)//2.25*2=4.5V,2250--4.3,2500--4.4
{
IO0CLR=0x00020000;
//DelayNS(30);
//清零P0.17,使蜂鸣器响
}
if (ADC_Data>3000)//2.25*2=4.5V
{
IO0SET=0x00020000;
//清零P0.17,使蜂鸣器响
}
DelayNS(30);
}
}
//主函数
int main(void)
{
PINSEL1=0x00400000;//P0.27:AD,P0.17:IO
PINSEL2=0x00000004; //gpio功能设定,P1.25:16作为GPIO,P1.26-P1.31,P1.18:LED----------------------------------------
IO0DIR=0x00020000;
IO0SET=0x00020000;
IO1DIR=LED1CON;
IO1SET=LED1CON;
delay(500000);
IO1CLR=LED1CON;
delay(500000);
IO1SET=LED1CON;
delay(500000);
IO1CLR=LED1CON;
delay(500000);
battery_test();
while (1);
return(0);//使得main返回一个值给调用程序的外壳,表明程序已经成功运行。
}
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图四被打赏50分 | |
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 |