https://www.cnblogs.com/BlueMountain-HaggenDazs/p/4295468.html
实验内容
通过外部中断方式依次按下按键S1控制LED1的亮灭
实验过程
比如说我们在执行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)
{
}
}