TQ2440之按鍵中斷

程序是我自己編的,有一開始自己寫的有點亂然后后邊整理了一下并且參考了別人編程的風格習慣所以就形成了我下面給出的程序,有在板子上運行處成功,關于一些頭文件跟c文件就不說了,真正有心在做裸機的知道解決方法。#include "2440addr.h"
#include"option.h"
#define LED1_ON (rGPBDAT &= ~(1<<5) ) //置0燈亮,置1燈滅
#define LED1_OFF (rGPBDAT |=(1<<5) )
#define LED2_ON (rGPBDAT &= ~(1<<6) )
#define LED2_OFF (rGPBDAT |=(1<<6) )
#define LED3_ON (rGPBDAT &= ~(1<<7) )
#define LED3_OFF (rGPBDAT |=(1<<7) )
#define LED4_ON (rGPBDAT &= ~(1<<8) )
#define LED4_OFF (rGPBDAT |=(1<<8) )
void delay(void)
{
unsigned int i,j;
for(i=0;i<1000;i++)
for(j=0;j<6000;j++)//純粹是為了燈亮的好看不會閃爍;
;
}
void __irq Key1_ISR(void)//提前定義,不然下邊的pISR_EINT那里會報錯,原因c語言檢測不到函數定義
{
rSRCPND |= (1<<1);//清除中斷標志位,下面相同
rINTPND |= (1<<1);
LED1_ON;
delay();
LED1_OFF;
}
void __irq Key2_ISR(void)
{
rSRCPND |= (1<<4);
rINTPND |= (1<<4);
rEINTPEND |= (1<<4);//使能EINT4,因為它是復用的,所以要加上這句
rEINTMASK &= (~(1<<4));//中斷屏蔽
LED2_ON;
delay();
LED2_OFF;
}
void __irq Key3_ISR(void)
{
rSRCPND |= (1<<2);
rINTPND |= (1<<2);
LED3_ON;
delay();
LED3_OFF;
}
void __irq Key4_ISR(void)
{
rSRCPND |= (1<<0);
rINTPND |= (1<<0);
LED4_ON;
delay();
LED4_OFF;
}
void led_init(void)//初始化燈
{
rGPBCON = 0x15400;//全部設置為I/O輸出
rGPBUP = 0x00;//使能上拉電阻
rGPBDAT |= (1<<5)|(1<<6)|(1<<7)|(1<<8);//先讓燈全滅,不然看不到效果
}
void key_init(void)//初始化中斷
{
rGPFCON |= (1<<1)|(1<<3)|(1<<5)|(1<<9); //設置寄存器為中斷方式
rEXTINT0 |= (1<<1)|(1<<5)|(1<<9)|(1<<17);//設置外部中斷為下降沿方式觸發
rEINTMASK &= (~(1<<4));//EINT4中斷有效
rEINTPEND |= (1<<4);//寫1清除EINT4中斷標志位
rSRCPND |= (1<<0)|(1<<1)|(1<<2)|(1<<4);//EINT0、1、2、4等待請求服務
rINTMSK &= (~(1<<0))&(~(1<<1))&(~(1<<2))&(~(1<<4));//設置cpu服務EINT0、1、2、4
rINTPND |= (1<<0)|(1<<1)|(1<<2)|(1<<4);//優先級的問題,IRQ決定服務哪個哪個中斷源先
pISR_EINT0 = (unsigned)Key4_ISR;
pISR_EINT1 = (unsigned)Key1_ISR;
pISR_EINT2 = (unsigned)Key3_ISR;
}
void Main(void)
{
MMU_Init();
led_init();//初始化燈
key_init();//初始化中斷
while(1);//死循環,等待按鍵中斷
}
最近比較懶,好久沒開博客看看了,下次再把串口裸機程序發上來,做好了,可是懶得寫。最近要復習期末考,做到nand flash的操作裸機程序就暫且放一放,等考完試后再把它完成之后就正式進入驅動的學習,同時可能會學習一下UC/OS ii。


評論