本帖最后由 哈利 于 2013-11-4 21:39 编辑
程序代码如下:
#include <msp430.h>
void main(void)
{ unsigned int i;
WDTCTL = WDTPW + WDTHOLD;
if(CALBC1_1MHZ==0XFF || CALDCO_1MHZ==0XFF)
{
while(1);
}
do
{
IFG1 &= ~OFIFG;
for(i=0xff;i>0;i--);
}
while((IFG1&OFIFG));
P1DIR |= BIT0;
P1OUT =0;
ADC10CTL0 |= ADC10ON + ADC10IE + SREF_1 + ADC10SHT_3 + REF2_5V + REFON;
ADC10CTL1 |= INCH_10 + ADC10SSEL_2 + SHS_1 + CONSEQ_2;
__enable_interrupt();
TA0CCR0 = 30;
TA0CCTL0 |= CCIE;
TA0CTL = TASSEL_2 | MC_1;
LPM0;
}
#pragma vector=TIMER0_A0_VECTOR
__interrupt void timer0_isr(void)
{
TA0CTL = 0;
TA0CCR0 =32767;
TA0CCR1 = 2500;
TA0CCTL0 &=~CCIE;
TA0CCTL1 = OUTMOD_3;
TA0CTL = TASSEL_2 + MC_1;
ADC10CTL0 |= ENC;
}
#pragma vector=ADC10_VECTOR
__interrupt void ADC10_isr(void)
{
P1OUT ^= BIT0;
}
是这样一回事:当我让程序全速进行时,发现CPU进入低功耗不响应ADC10的中断,但是只要这时候,我按一下BREAK按钮,也就是那个红 {MOD}的小手,接着通过查看寄存器得知ADC10中断标志已经置位。不可思议的是:紧接着,我按一下单步执行,发现响应了中断。再全速运行,仍然是同样的问题。每次都是这样。。。这是为什么?仿真过程有问题??
如果我把主程序最后一句“LPM0;”换成“while(1)”,仿真过程不会出现问题。求解?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
抱歉,编这个程序本来就是打算看一下ADC10的SHI信号是边沿触发还是电平触发。ADC10的触发源来自TA1,TA1的输出高电平时间足够ADC采样几百次,但是运行起来发现,LED是闪烁的,说明SHI是边沿触发。因为就是一个小实验,所以没有注释。问题上午刚刚解决:当CPU进入LPM0时,MAIN CLOCK 是关闭的,而我的ADC10时钟选的是它,所以进入低功耗之后,肯定不会有中断响应的。至于BREAK一下,再执行为什么能够响应,还不知道。将ADC10的时钟源改为子系统时钟就可以。谢啦!
;P就是一个小实验,思路我回复给楼上了。
奥,原来是一个人啊:lol:lol,不好意思。
解决了就好。:handshake
看到一堆代码就头疼:funk:
一周热门 更多>