【ARM】2410裸机系列-中断处理
2020-01-23 来源:eefocus
目的
为了更好地掌握S3C2410中断的原理及中断程序的编写。
内容利用S3C2410的外部中断0和外部中断1实现两个按键功能
原理
本次选择的是外部中断EXTINT0和EXTINT11。中断的产生分别来自按钮SB1202和SB1203,当按钮按下时,EXTINT0(对应管脚GPF0)或EXTINT11(对应管脚GPG3)和地连接,输入低电平,从而向CPU发出中断请求。
当CPU受理后,进入相应的中断服务程序,通过超级终端的主窗口显示当前进入的中断号。
程序
#include '2410addr.h'//这头文件找了好久啊,mdk里面没有,后来在一个实例中提取出来的
#include '2410lib.h'
void __irq int0_int(void) //外部中断0处理函数
{
uart_printf('EINT0 interrupt occurred. n');
ClearPending(BIT_EINT0); //清除中断源
}
void __irq int11_int(void) //外部中断11处理函数
{
if(rEINTPEND==(1<<11)) //判断外部中断挂起寄存器,确定是否外部中断11
{
uart_printf('EINT11 interrupt occurred. n');
rEINTPEND=(1<<11); //清除中断挂起寄存器
}
ClearPending(BIT_EINT8_23);
}
void int_init(void) //中断初始化
{
rGPFCON=(rGPFCON & ~(3<<0) | (0x2<<0)); //将CPFO配置为EINT0
rGPGCON=(rGPGCON & ~(3<<6) | (0x2<<6)); //将CPF3配置为EINT11
pISR_EINT0=(UINT32T)int0_int; //注册中断处理函数
pISR_EINT8_23=(UINT32T)int11_int;
//注册处理中断11处理函数,EINT8~23共用此函数,需要在处理函数中加入对源中断的判断
rEINTPEND=0xffffff; //清除所有外部中断挂起状态
rSRCPND=BIT_EINT0 | BIT_EINT8_23; //清除源的挂起状态
rINTPND=BIT_EINT0 | BIT_EINT8_23; //清除挂起状态
rEXTINT0=(rEXTINT0 & ~(7<<0)) | (0x2<<0); //EINT0下降沿触发
rEXTINT1=(rEXTINT1 & ~(7<<0)) | (0x2<<12); //EINT1Ï下降沿触发
rEINTMASK &= ~(1<<11); //打开外部中断11
rINTMSK &= ~(BIT_EINT0 | BIT_EINT8_23); //打开INTMSK中的中断0和中断8~23
}
int main()
{
int_init();
while(1);
}
//#define ClearPending(bit) {rSRCPND=bit;rINTPND=rINTPND;}
//写入错误的数据
//清除中断源,注意清除的顺序,要从源头开始清除
上一篇:【ARM】串行通信
下一篇:【ARM】ARM程序规范
- 松下汽车电子系统与 Arm 携手推进软件定义汽车标准化
- arm处理器中a5 a8 a9,v6 v7,arm7 arm9 arm11都是依据什么来分类的
- ARM处理器架构
- Linux Kernel之flush_cache_all在ARM平台下是如何实现的
- Arm 引领软件定义汽车革新, 共同迈向汽车行业未来
- arm召开2025二季度财报会,V9架构继续大获成功
- ARM、Intel、MIPS处理器啥区别?看完全懂了
- makefile初步制作,arm-linux- (gcc/ld/objcopy/objdump)详解
- ubuntu下使用qemu模拟ARM(六)------驱动程序
- Ubuntu下安装arm-linux-gnueabi-xxx编译器