用G2553做IO口中断,P1.0控制LED,另外选一个IO口做中断处理。发现,寄存器P1IES的值对于是高电平还是低电平触发完全没有影响。
分别试了P1.1~P1.7口,发现它们的触发方式都是确定了的:
低电平触发:P1.1 P1.2 P1.3 P1.5
高电平触发:P1.4 P1.6 P1.7
不论P1IES怎么设置,以上结论都成立,每个IO都试过了,那这样的话,P1IES还有什么意义?
代码如下(用P1.7中断):
#include <msp430g2553.h>
#define KEY BIT7
void button_init()
{
P1DIR |= BIT0; // set P1.0 to output direction
P1IE |= KEY; // P1.3 interrupt enabled
P1IES = 0x00;
P1IFG &= ~KEY; // P1.3 IFG cleared
P1REN |= KEY;
}
void main()
{
button_init();
_EINT(); //换成_BIS_SR(LPM4 + GIE)就会自动跳出while(1)...????
while(1)
_NOP();
}
#pragma vector=PORT1_VECTOR
__interrupt void Port_1(void)
{
if (P1IFG & KEY)
{
P1OUT ^= BIT0; // P1.0 = toggle
P1IFG &= ~KEY; // P1.3 IFG cleared
}
}
另外还有个问题:main函数中的_EINT(); 换成_BIS_SR(LPM4 + GIE); 后就老是跳出while循环,不知道为什么?这两句有什么区别?
谢谢各位!
此帖出自
小平头技术问答
那个_EINT(); 和_BIS_SR(LPM4 + GIE); 是有很明显的区别的
前者只是打开总中断 而后者是打开总中断还要进入低功耗模式 进入低功耗模式后 由于你在P1口的中断中没有退出低功耗模式 所以单片机处理完中断后东西后会继续进入低功耗模式 直到下一次中断的来临
#include "msp430g2553.h"
#define KEY BIT3
void button_init()
{
P1DIR |= BIT0; // set P1.0 to output direction
P1IE |= KEY; // P1.3 interrupt enabled
P1IES = KEY;
P1IFG &= ~KEY; // P1.3 IFG cleared
}
void main()
{
button_init();
while(1)
{
__bis_SR_register(LPM4_bits + GIE);
}
}
#pragma vector=PORT1_VECTOR
__interrupt void Port_1(void)
{
if (P1IFG & KEY)
{
P1OUT ^= BIT0; // P1.0 = toggle
P1IFG &= ~KEY; // P1.3 IFG cleared
}
__bis_SR_register_on_exit(LPM4_bits + GIE);
}
一周热门 更多>