搜索
bottom↓
回复: 2

请教各位大侠,msp430f149 ad转换完成后,怎样完全关闭adc模块

[复制链接]

出0入0汤圆

发表于 2012-4-28 09:20:48 | 显示全部楼层 |阅读模式
我在程序里把  ADC12ON  REFON  ENC    置0,还是有几百uA的电流   

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2012-4-28 09:25:21 | 显示全部楼层
贴一段代码给你看下,变成149是需要把名字改一下的,TI和BT,430多系列的寄存器名字是不太一样的,但是功能却是一下的。
// *************************************************************************************************
// Extern section

// *************************************************************************************************
// @fn          adc12_single_conversion
// @brief       Init ADC12.      Do single conversion. Turn off ADC12.
// @param       u16 ref                  Select reference
//                              u16 sht          Sample-and-hold time
//                              u16 channel      Channel of the conversion
// @return      u16 adc12_result Return ADC result
// *************************************************************************************************
u16 adc12_single_conversion(u16 ref, u16 sht, u16 channel)
{
    // Initialize the shared reference module
    REFCTL0 |= REFMSTR + ref + REFON;   // Enable internal reference (1.5V or 2.5V)

    // Initialize ADC12_A
    ADC12CTL0 = sht + ADC12ON;          // Set sample time
    ADC12CTL1 = ADC12SHP;               // Enable sample timer
    ADC12MCTL0 = ADC12SREF_1 + channel; // ADC input channel
    ADC12IE = 0x001;                    // ADC_IFG upon conv result-ADCMEMO

    // Wait 2 ticks (66us) to allow internal reference to settle
    Timer0_A4_Delay(2);

    // Start ADC12
    ADC12CTL0 |= ADC12ENC;

    // Clear data ready flag
    adc12_data_ready = 0;

    // Sampling and conversion start
    ADC12CTL0 |= ADC12SC;

    // Delay to get next ADC value
    Timer0_A4_Delay(5);
    while (!adc12_data_ready) ;

    // Shut down ADC12
    ADC12CTL0 &= ~(ADC12ENC | ADC12SC | sht);
    ADC12CTL0 &= ~ADC12ON;

    // Shut down reference voltage
    REFCTL0 &= ~(REFMSTR + ref + REFON);

    ADC12IE = 0;

    // Return ADC result
    return (adc12_result);
}

// *************************************************************************************************
// @fn          ADC12ISR
// @brief       Store ADC12 conversion result. Set flag to indicate data ready.
// @param       none
// @return      none
// *************************************************************************************************
#pragma vector=ADC12_VECTOR
__interrupt void ADC12ISR(void)
{
    switch (__even_in_range(ADC12IV, 34))
    {
        case 0:
            break;                    // Vector  0:  No interrupt
        case 2:
            break;                    // Vector  2:  ADC overflow
        case 4:
            break;                    // Vector  4:  ADC timing overflow
        case 6:                       // Vector  6:  ADC12IFG0
            adc12_result = ADC12MEM0; // Move results, IFG is cleared
            adc12_data_ready = 1;
            _BIC_SR_IRQ(LPM3_bits);   // Exit active CPU
            break;
        case 8:
            break;                    // Vector  8:  ADC12IFG1
        case 10:
            break;                    // Vector 10:  ADC12IFG2
        case 12:
            break;                    // Vector 12:  ADC12IFG3
        case 14:
            break;                    // Vector 14:  ADC12IFG4
        case 16:
            break;                    // Vector 16:  ADC12IFG5
        case 18:
            break;                    // Vector 18:  ADC12IFG6
        case 20:
            break;                    // Vector 20:  ADC12IFG7
        case 22:
            break;                    // Vector 22:  ADC12IFG8
        case 24:
            break;                    // Vector 24:  ADC12IFG9
        case 26:
            break;                    // Vector 26:  ADC12IFG10
        case 28:
            break;                    // Vector 28:  ADC12IFG11
        case 30:
            break;                    // Vector 30:  ADC12IFG12
        case 32:
            break;                    // Vector 32:  ADC12IFG13
        case 34:
            break;                    // Vector 34:  ADC12IFG14
        default:
            break;
    }
}

出0入0汤圆

发表于 2012-4-28 09:26:08 | 显示全部楼层
本帖最后由 USACH 于 2012-4-30 00:33 编辑

延时你自己修改一下就行。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-6 10:22

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表