关于单通道ADC10测量

关于单通道ADC10测量,第1张

volaTIle unsigned int ad_value[10];

int main( void )

{

WDTCTL=WDTPW+WDTHOLD; //关看门狗

BCSCTL1 =CALBC1_1MHz; //设定DCO 为1MHZ

DCOCTL =CALBC1_1MHZ;

//时钟源选AD 内部时钟并4 分频,选通道10,AD 启动信号来源选TA.OUT1,选单通道连续采样

ADC10CTL1=ADC10DIV_3+INCH_10+SHS_1+CONSEQ_2;

//选1.5V 为正向参考,地为负参考,AD 中断使能,打开参考,启动AD 模块(不是启动AD 转换)

ADC10CTL0=SREF_1+ADC10SHT_3+ADC10IE+REFON+ADC10ON;

TACCR0=30; //延时等待参考稳定

TACCTL0 |=CCIE; //CCR0 中断使能

TACTL=TACLR+MC_1+TASSEL_2; //TA 增计数,时钟源为smclk

_BIS_SR(LPM0_bits+GIE); //进入低功耗0,使能总中断,等待参考稳定

TACCTL0 &=~CCIE; //CCR0 中断禁止

_BIC_SR(GIE); //关总中断

ADC10CTL0 |=ENC; //AD 转换使能

TACCTL1=OUTMOD_4; //CCR1 选输出模式4,当TAR=0 时,输出高电平

TACTL =TASSEL_2+MC_2; //TA 改为连续计数,smclk 时钟源

_BIS_SR(LPM0_bits+GIE); //进入低功耗0,使能总中断,等待10AD 完成

_NOP();

return 0;

}

#pragma vector = TIMERA0_VECTOR //TA0 中断服务,用来参考稳定

__interrupt void ta0_isr(void)

{

TACTL=0; //关TA

_BIC_SR_IRQ(LPM0_bits); //退出低功耗

}

#pragma vector = ADC10_VECTOR //ADC10 中断服务

__interrupt void adc_isr(void)

{

staTIc char i=0;

ad_value[i]=ADC10MEM; //保存AD 结果

i++;

if(i==10) //作10 次AD

_BIC_SR_IRQ(LPM0_bits+GIE); //退出低功耗

}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/dianzi/2640667.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-08-12
下一篇 2022-08-12

发表评论

登录后才能评论

评论列表(0条)

保存