This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

msp430f2132内部比较器的应用



不好意思,上次发的贴不知道怎么回事不能回复,又从发贴,请原谅:我知道相关上次贴的原理图,但是问题是当我设置寄存器CACTL1 的CAON为1时,这是中断标志位就产生了。或者我先设置CARSEL   CAEX 位,也产生中断标志位,我这时没有设置CAON位但是在我单步运行时看到中断标志位几经置1了,当我打开相应中断和总中断的时候,就会进入中断,我设置是ca1进入比较器的+端,内部比较电压进入—端。

   我现在的做法是,当我设置好寄存器然后就清楚中断标志位,但是当上电时如果ca1>参考电压,不产生中断。

  我是想用内部比较器检测电压,当电压超过参考电压,就中断告诉我,我就切断外部电源这个功能。求指点。!!!!!!!!!

  • 其实你已经很清楚地描述了初始化一个外设的正确步骤。总结一下就是先配置外设,在使能外设中断之前先清除中断标志,防止在配置未完成器件产生的非正常中断标志。

    另外不清楚你求指点是需要什么方面的帮助.

     如果外部电源的关闭时间要求不是太严格的话,建议使用ADC的方式来做,这样可以很好的防止电源的波动造成误操作。

  • 楼主请确认ca1是不是在上电是就已经大于参考电压,如果是的话,你在开初始化时如果开启CAON位,这是内部的电容还在充电(电容充电的时间是非常快的)的过程中所以这个大于的时间会发生所以就会出现中断,但是如果你一开始清除了,那么你就已经清楚了这个事件,并且以后的时间ca1就一直大于了才考电压,所以就不会进中断了。

    楼主可以做这样的实验看看,你在初始化之与CAON置为之间增加不同的延时,就应该可以测到这个时间。

  • 楼主可以参考TI CCS中的比较器中断例程如下:

    //******************************************************************************

    //   MSP430x21x2 Demo - Comparator A, Poll input CA0, interrupt triggered

    //

    //   Description:  Normal operation is in LPM3.  When Vcompare crosses the ref

    //   voltage, an interrupt is generated, and the ISR toggles the LED.

    //

    //

    //                 MSP430x21x2

    //             -----------------

    //         /|\|                 |

    //          | |                 |

    //          --|RST           CA0|<--Vcompare

    //            |                 |

    //         <--|CAOUT/P2.6       |

    //            |             P1.0|-->LED

    //

    //  P. Thanigai / K.Venkat

    //  Texas Instruments Inc.

    //  November 2007

    //  Built with CCE Version: 3.2.0 and IAR Embedded Workbench Version: 3.42A

    //******************************************************************************

    #include  <msp430x21x2.h>

    void main(void)

    {

     WDTCTL = WDTPW+WDTHOLD;                   // Stop WDT

     CACTL1 = CAON+CAREF_2+CARSEL;             // Enable comp, ref = 0.5*Vcc

     CACTL2 = P2CA0;                           // Pin to CA0

     CAPD |= CAPD6;                            // Port pin buffer disable

     P1DIR |= BIT0;                            // P1.0 = output direction

     P2SEL |= BIT6;                            // P2.6 = CAOUT

     CACTL1 |= CAIE;                           // Setup interrupt for Comparator

     _BIS_SR(LPM3_bits + GIE);                 // Enter LPM3, interrupts enabled

    }

    // Comp_A interrupt service routine -- toggles LED

    #pragma vector=COMPARATORA_VECTOR

    __interrupt void Comp_A_ISR (void)

    {

     CACTL1 ^= CAIES;                          // Toggles interrupt edge

     P1OUT ^= 0x01;                            // Toggle P1.0

    }