http://blog.chinaunix.net/uid-28458801-id-3780127.html
先mark,有的地发还没有完全消化。
总结一下中断配置步骤:
中断涉及:中断源 中断控制器 ARM核中断相关内容
1.中断源配置:
(1)禁止中断
(2)清除中断标志peng寄存器
(3)配置GPIO为中断功能
(4)禁止上下啦
(5)滤波
(6)中断触发方式
2.中断控制器的配置
(1)禁止对应的向量中断=》VICOINTENCLEAR
(2)TZICOINTSELECT把中断配置成VIC/TZIC
(3)把中断配置成IRQ/FRQ
(4)地址清零
(5)把编写的中断服务程序地址写道这个寄存器
3.ARM核配置
(1)中断源的MASK寄存器开启
(2)中断控制寄存器,中断使能
(3)ARM的CSPR的中断控制位开启
eg:
void irq_init(viod):
{
//1.中断源配置
EXTINT2MASK=0xff;//该寄存器为中断屏蔽,0为使能,1为禁止
EXTIN2PEND=0xff;//1中断挂起
GPH2CON|=0xff;//将GPIO口配置为中断功能
GPH2PUD&=0xf;//0禁止上下拉,1使能上下拉
EXTINT2CON = (EXTINT2CON&(~0xff))|0x22;//中断触发使用下降沿
EXTINT2FLT = 0;//不使用滤波
//2.中断控制器的配置
VIC0INTENCLEAR |= (1<<16);//中断清除
TZIC0INTSELECT &= ~(1<<16);//把中断配置成走VIC
VIC0INTSELECT &= ~(1<<16);//把中断配置成走IRQ
VIC0ADDRESS = 0;//清零
VIC0VECTADDR16 = (unsigned int)extint_func;//.配置中断服务程序的地址
//3.开启中断
EXTINT2MASK &= ~0x3;
VIC0INTENABLE |= (1<<16);
enable_irq();
}