不好意思,上次发的贴不知道怎么回事不能回复,又从发贴,请原谅:我知道相关上次贴的原理图,但是问题是当我设置寄存器CACTL1 的CAON为1时,这是中断标志位就产生了。或者我先设置CARSEL CAEX 位,也产生中断标志位,我这时没有设置CAON位但是在我单步运行时看到中断标志位几经置1了,当我打开相应中断和总中断的时候,就会进入中断,我设置是ca1进入比较器的+端,内部比较电压进入—端。
我现在的做法是,当我设置好寄存器然后就清楚中断标志位,但是当上电时如果ca1>参考电压,不产生中断。
我是想用内部比较器检测电压,当电压超过参考电压,就中断告诉我,我就切断外部电源这个功能。求指点。!!!!!!!!!
Triton Zhang:
其实你已经很清楚地描述了初始化一个外设的正确步骤。总结一下就是先配置外设,在使能外设中断之前先清除中断标志,防止在配置未完成器件产生的非正常中断标志。
另外不清楚你求指点是需要什么方面的帮助.
如果外部电源的关闭时间要求不是太严格的话,建议使用ADC的方式来做,这样可以很好的防止电源的波动造成误操作。
Xiaowei Bai1:
楼主请确认ca1是不是在上电是就已经大于参考电压,如果是的话,你在开初始化时如果开启CAON位,这是内部的电容还在充电(电容充电的时间是非常快的)的过程中所以这个大于的时间会发生所以就会出现中断,但是如果你一开始清除了,那么你就已经清楚了这个事件,并且以后的时间ca1就一直大于了才考电压,所以就不会进中断了。
楼主可以做这样的实验看看,你在初始化之与CAON置为之间增加不同的延时,就应该可以测到这个时间。
Hanson He:
楼主可以参考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
}