积分规则 网站地图 帮助中心    
嵌入式软件 单 片 机 DSP 存储器 传感控制 光电显示
嵌入式硬件 CPLD/FPGA SOPC AD/DA 接口电路 模拟设计
I C设计 通信产品 汽车电子 电源产品 消费电子 数控系统
工业控制 军工/航天 安防产品 医疗电子 计算机外设 测试测量
供应 I C
求购 公司库

  IC 求购 销售 公司 论文 DATASHEET 参考设计 论坛
当前位置: 电子技术 >> 嵌入式硬件 >> ARM
  相关分类: 相关文章 | ARM | 新产品 | 下载 | MIPS | X86 |
S3C2410中断程序的实现
 
作者:闫明 李欣 吴伟   来源:电子开发网    点击数:95   更新时间:2008-8-19
您可以添加到网摘 让更多人关注此文章:

          S3C2410(IRQ)中断处理过程:

       在此要注意的是区别中断向量表和异常向量表。中断发生后总是从IRQ 或者FIQ 异常入口处进入,然后跳转到相应的异常处理程序处执行,这个异常处理程序一般都是进行查找中断向量表的操作,然后调用中断处理程序。

      以下是在应用中中断处理实现的过程:从中不难体会到中断的处理过程。

      定义中断向量表的物理地址:

      代码 
      .equ pISR_DABORT , (_ISR_STARTADDRESS+0x10) 
      .equ pISR_RESERVED, (_ISR_STARTADDRESS+0x14) 
      .equ pISR_IRQ , (_ISR_STARTADDRESS+0x18) 
      .equ pISR_FIQ , (_ISR_STARTADDRESS+0x1c) //异常向量表
…………………………………………………………………… 
      .equ pISR_EINT0 , (_ISR_STARTADDRESS+0x20) //中断向量表 
      .equ pISR_EINT1 , (_ISR_STARTADDRESS+0x24) 
      .equ pISR_EINT2 , (_ISR_STARTADDRESS+0x28) 
      .equ pISR_EINT3 , (_ISR_STARTADDRESS+0x2c) 
      将中断处理程序入口地址放入中断向量表: 
      代码 
      pISR_EINT0 = (unsigned int)isrEINT0; // isrEINT0 中断处理程序 
      pISR_EINT1 = (unsigned int)isrEINT1; 
      定义中断处理程序: 
      代码 
      .extern Interrupt_Rbutton 
      .global isrEINT0 
      isrEINT0: 
      IRQHandle Interrupt_Rbutton 
      定义异常向量表: 
      代码 
      b HandlerUndef /* handler for Undefined mode */ 
      b HandlerSWI /* handler for SWI interrupt */ 
      b HandlerPabort /* handler for PAbort */ 
      b HandlerDabort /* handler for DAbort */ 
      .long FileIDTable /* id */ 
      b HandlerIRQ /* handler for IRQ interrupt */ 
      b HandlerFIQ 
      定义异常处理函数: 
      代码 
      HandlerFIQ: HANDLER HandleFIQ 
      HandlerIRQ: HANDLER HandleIRQ 
      HandlerUndef: HANDLER HandleUndef 
      HandlerSWI: HANDLER HandleSWI 
      HandlerDabort: HANDLER HandleDabort 
      HandlerPabort: HANDLER HandlePabort 
      异常处理宏HANDLER的定义: 
      代码 
      .macro HANDLER HandleLabel 
      sub sp,sp,#4 /* decrement sp(to store jump address) */ 
      stmfd sp!,{r0} /* PUSH the work register to stack(lr does't push bec 
      ause it return to original address) */ 
      ldr r0,=HandleLabel /* load the address of HandleXXX to r0 */ 
      ldr r0,[r0] /* load the contents(service routine start address) of 
      HandleXXX */ 
      str r0,[sp,#4] /* store the contents(ISR) of HandleXXX to stack */ 
      ldmfd sp!,{r0,pc} /* POP the work register and pc(jump to ISR) */ 
      .endm 
      定义IRQ 中断处理宏IRQHandle: 
      代码 
      .macro IRQHandle isrHandle: 
      stmdb sp!, {r0-r11, ip, lr} /* save r0-r11, ip, lr */ 
      ldr r0, =isrHandle 
      mov lr, pc 
      bx r0 /* jump to user_handle(void) */ 
      ldmia sp!, {r0-r11, ip, lr} /* restore r0, ip, lr */ 
      subs pc, r14, #4 /* return from interrupt */ 
      .endm 
      申明IRQ 异常的服务程序为:IsrIRQ,即,发生IRQ 异常时,执行“b HandlerIRQ”即是 
      运行IsrIRQ代码: 
      代码 
      ldr r0,=HandleIRQ @ This routine is needed 
      ldr r1,=IsrIRQ @ if there isn't 'subs pc,lr,#4' at 0x18, 0x1c 
      str r1,[r0] 
      IRQ 异常处理程序: 
      代码 
      IsrIRQ: 
      sub sp,sp,#4 @ reserved for PC 
      stmfd sp!,{r8-r9} 
      ldr r9,=INTOFFSET 
      ldr r9,[r9] 
      ldr r8,=HandleEINT0 
      add r8,r8,r9,lsl #2 
      ldr r8,[r8] 
      str r8,[sp,#8] 
      ldmfd sp!,{r8-r9,pc} 
      由上可以知道,当一个IRQ 中断发生时,CPU将从0X18(IRQ 异常入口地址)取指执行,在这一步PC 的跳转是有硬件实现的。在入口0x18 地址处放的是一条跳转指令,这条指令将跳到IRQ 异常处理程序运行,IRQ 异常处理程序主要是根据中断源查找中断向量表。获得中断入口地址后,接着CPU 跳转中断处理程序运行。
在嵌入式系统中异常向量表和中断向量表都是存于FLASH起始的一段空间中。而异常处理和中断处理程序都是运行在RAM中的。



相关文章
· 基于嵌入式Linux平台多协议路由器的设计[256]
· ARM CPU S3C44B0X与C54X DSP的接口设计[111]
· 基于ARM单片机的条码精密测量系统[245]
· 一种基于ARM的新型智能化航迹仪的设计[193]
· 低成本ARM系列LM3S101微控制器的结构与应用[207]
热门评论排行
·VHDL设计中电路简化问题的
·江苏嵌入式Linux教育培训
·锐极LINUX驱动培训班定于
·基于实时操作系统μC/OS-
·ARM嵌入式系统基础教程(N

文章评论
    没有任何评论
*只显示最新10条评论。评论内容只代表网友观点,与本站立场无关。更多评论
发表评论
  * 请先[登陆]再进行评论,谢谢。
评分: 1分 2分 3分 4分 5分
内容: *
发帖须知:
一.所发文章必须遵守《互联网电子公告服务管理规定》;
二.严禁发布供求代理信息,公司介绍,产品信息等广告宣传信息;
三.严禁恶意重复发帖;
四.严禁对个人,实体,民族,国家等进行漫骂,污蔑,诽谤。
 
热点新闻 [更多]
 
华虹NEC的0.13微米嵌入式工艺取
映绿色风潮 奇美电子在日发
尔必达注资力晶半导体新台币35亿-4
WSTS调降近三年IC市场预期&nb
Vishay 推出具有业界
具备革命性数字安全特性的英飞凌SLE
祥硕科技采用一系列 MIP
安森美半导体荣获德尔福苏州E&S优质
赛普拉斯为用于机器视觉与运动分析应用
赛普拉斯针对机器视觉与全息数据存储应
 
热门下载 [更多]
 
[ PCB设计] Protel99教程下载
[ ] 手把手学单片机20个例
[ ] 单片机做的智能台灯
[ ] 单片机入门书
[ ] linux系统移植开发文档
[ ] IC卡的读写程序
[ ] 8051单片机C语言彻底应用
[ 常用软件] 555定时器电路设计软件V1.2
[ 常用软件] 51定时器计算软件
[ ] ARM处理器应用开发4步骤
 
论坛新帖 [更多]
 
硬件工程师面试题及答案(模拟电...
如何在C语言中跳出多重循环?—...
ARM入门开发步骤...
linux学习点滴...
在linux上安装配置samb...
[转帖]WinCE 5 mem...
四折批发各种数码相机,摄相机等...
最低价销售各种品牌手机...
震撼出售各种品牌笔记本电脑等!...
IC design 的流程...

 
赞助商 [更多]
 

ICP许可证号:[粤 05056597]
联系电话:010-82517432 82517615 传真: 010-82517615

版权所有 Copyright © 2006 嵌入式技术网