- 1、本文档共6页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
中断函数写法
三?????????????
主程序语句如下:
void main(void)
{
WDTCTL = WDTPW + WDTHOLD; // 关闭看门狗
P5DIR |= 0x0F; // 设置 P5.0-P5.3 为输出方向
P1DIR = 0x0F; // 设置P1.4 -P1.7 为输入方向
P1IE = 0xf0; // 设置P1.4 -P1.7 可以中断
P1IES = 0xf0; // 设置P1.4 -P1.7 为下降沿中断
_BIS_SR(LPM3_bits + GIE); // 进入最低功耗睡眠,打开总总断开关
for (;;)
{
}
}
语句“#pragma vector=PORT1_VECTOR”指明中断函数是为什么中断服务的,即中断向量。本程序将为端口P1 服务,所以使用PORT1_VECTOR 中断向量,该PORT1_VECTOR 的含义在头文件中有明显表述,请仔细查阅。
语句“__interrupt void p1int(void)”为中断函数的函数声明。
需要注意的是:P1 的中断标志不能自动清除,需要人为清除,所以程序最后需要清除端口P1 的中断标志,否则会引起中断嵌套,引起死循环。
?
#pragma vector=PORT1_VECTOR
__interrupt void p1int(void)
{
if((P1INBIT5) == BIT5)
P5OUT = ~BIT1 ;
else
P5OUT |= BIT1;
if((P1INBIT6) == BIT6)
P5OUT = ~BIT2;
else
P5OUT |= BIT2;
if((P1INBIT7) == BIT7)
P5OUT = ~BIT3;
else
P5OUT |= BIT3;
P1IFG = 0 ;
}
?
四?????????????
?
综合起来,一般的键盘程序有如下三个步骤:
A 消除按键抖动(如果使用硬件,则可略);
B 判断是哪个按键按下,识别键码;
C 等待按键松开。
?
?
????????? 主程序:(提供端口设置,使之能进入中断)
unsigned char keybuf; // 全局变量,键值缓存
……
WDTCTL = WDTPW + WDTHOLD; // 关闭看门狗
P1DIR = 0x0F; // 设置P1.4 -P1.7 为输入方向
P1IE = 0xf0; // 设置P1.4 -P1.7 可以中断
P1IES = 0xf0; // 设置P1.4 -P1.7 为下降沿中断
_BIS_SR(LPM3_bits + GIE); // 进入最低功耗睡眠,打开总总断开关
……
?
????????? 判键子程序
unsigned char p1keyj(void) // 判键子程序
{
unsigned char x;
x=(P1IN0Xf0); // P14--P17 接有按键
return(x); // 有按键返回非全 1
}
?
????????? 中断服务程序:
#pragma vector=PORT1_VECTOR
__interrupt void p1int(void)
{
//端口1 的中断服务程序
while(p1keyj()!=0xf0) //没有按键按下,返回全1――0xf0
{
delay(500); //延时消除抖动
while(p1keyj()!=0xf0)
{
keybuf = keycode();//确信有按键按下,找按键得键值,送到全局变量keybuf
while(p1keyj()= =0) //等待按键松开
; //做对应键盘的事务
}
}
}
//为了保证代码可以在IAR编译器的任何版本中都能正确得到编译,所以作以下的条件编译。#ifdef __IAR_SYSTEMS_ICC__ //如果编译器是IAR, 那么以下将被编译。 #if __VER__ = 200#pragma vector=USART0RX_VECTOR //在IAR2.0以上中断函数声明。__interrupt void SPI0_rx (void) #else //在IAR2.0以下中断函数声明。interrupt[USART0RX_VECTOR] void SPI0_rx (void)#endif //IAR中断函数声明结束。{ }
在上述中USART0RX_VECTOR 是定义中断地址宏,其实就是一个中断矢量值,例如,地址0xffe0 这个中断矢量有芯片型号决定,一旦信号确定,那么所有的终端矢量也就确定了。 SPI0_rx 是中断函数名称,使用者可以根据自己的喜好来编写这个函数名。实际例程//********
文档评论(0)