一、实验内容
通过外部中断方式依次按下按键S1控制LED1的亮灭
二、实验过程
1、电路原理图同上
2、中断的概念
比如说我们在执行main函数时,突然来了个指令。优先级比现在执行的main还高,那我们便选择跳过去执行优先级高的,完了之后再执行main函数,中断就类似这样一个概念,使用中断可以减少CPU的无效浪费,降低能耗。
3、寄存器调度
(1)LED1的初始化。。同前两节,就是SEL,DIR,INP三个,还有附初始状态。
(2)外部中断初始化(S1的外部中断初始化)
按键S1外部中断初始化方法:
P0IEN = 0X01; | P00 设置为中断方式 |
PICTL = 0X01; | 下降沿触发 |
IEN1 = 0X20; | 允许P0口中断;(S1中断) |
P0IFG = 0x00; | 初始化中断标志位 |
开中断时,还要开启中断总闸
EA = 1; //开总中断
4、代码实现(AIR环境下)
#include<ioCC2540.h> #define LED1 P1_0 //定义LED1,方便查阅代码 #define KEY1 P0_0 //定义按键S1 //函数声明 void Delayms(unsigned int t); //延时函数,当我们按下S1的时候,开发板会检测到无数个触发沿,对此,在不用中断 //的条件下,只能使用延时,过滤掉多余的不必要的触发沿。 void Init();//初始化函数 void Delayms(unsigned int t) //控制t被的延时周长 { unsigned int i,j; for(i=t;i>0;i--) { for(j=1;j<500;j++); } } void Init()//初始化函数 { P1SEL = 0X00; //实现LED的初始化 P1DIR = 0X01; P1INP = 0X00; LED1 = 0; P0IEN = 0X01; //开P0的中断 PICTL = 0X01; //下降沿触发 IEN1 = 0X20; //允许P0中断 P0IFG = 0X00; //清空标志位 EA=1; //开启中断总闸 } #pragma vector = P0INT_VECTOR //格式:#pragma vector = 中断向量. 紧接着是中断处理程序 __interrupt void fu(void) { Delayms(10); //除抖动 LED1=~LED1; P0IFG=0; //清除中断标志 } void main(void) { Init(); while(1) { } }
三、实验结果