用户名: 密码: 免费注册 免费试用 简体中文 | ENGLISH
中国·芯片交易在线  
www.ic112.com
IC72论坛
广告服务
网页制作
用户帮助
首页 供应信息 求购信息 库存查询 新闻中心 展会资讯 IC厂商 技术资料 自由区域
当前位置:首页>> 技术资料 >> 正文
ARM的三种中断调试方法的探讨
时间:2006/5/18 10:34:00  作者:  来源:ic72  浏览人数:1393
 
 

1 概述

      sung公司的S3C4510B是基于以太网应用系统的高性价比16/32位RISC微控制器,内含一个由ARM公司设计的16/32位ARM7TDMI RISC处理器核,ARM7TDMI为低功耗、高性能的16/32核,是目前应用广泛的一款ARM芯片。作者通过对这款典型芯片在网络通讯应用项目的开发,掌握了ARM的技术特点和开发流程,并且在中断调试方面获得了一些高级技巧。

2 硬件特点

S3C4510B的主要特性描述如下:
    支持ROM/SRAM、FLASH、DRAM和外部I/O以8/16/32位的方式操作;
    100M/10Mbps IEEE802.3标准兼容、提供MII和7线制10Mbps接口Ethernet控制器;
    2个10Mbps HDLC (High-Level Data Link Control) 高层数据链路协议通道; 
    2个可工作于DMA方式或中断方式的UART模块,支持红外发送和接收;
    IIC接口(主控模式);
    2个可编程32位定时器;18个可编程I/O口;2个DMA通道;
    21个中断源,包括4个外部中断源;
    外部时钟可由片内PLL倍频;工作频率最高为50MHz。
      SOC开发平台360元 豪华单片机开发系统498元 单片机学习板138 无线nRF-9E5模块100元 S3C44B0 ARM7开发板398元 Genius NSP通用编程器260元 Mini ARM Debugger330元 LABTOOL-48UXP2800元 S3C2410 ARM9开发板800

3 调试环境
 
      开发环境包括Embest IDE集成开发环境,Embest 仿真器,基于ARM(S3C4510B)的电路板。参照嵌入式软件的开发流程,如图1所示。在整个流程中,用户首先需要建立工程并对工程做初步的配置,包括配置处理器和配置调试设备。编辑工程文件,包括自己编写的汇编和C语言源程序,还有工程编译时需要编写的链接脚本文件,调试过程中需要编写存储区映像文件和命令脚本文件,以及上电复位时的程序运行入口的启动程序文件。 

ic72 新闻中心
图1 开发流程

      对后四种文件的理解很重要,其作用解释如下。
 
      (1)链接脚本文件:在程序编译时起作用。该文件描述代码链接定位的有关信息,包括代码段,数据段,地址段等,链接器必须使用该文件对整个系统的代码做正确的定位。在SDRAM中调试程序、在FLASH中调试或固化后运行的链接脚本文件应加以区分。(在IDE开发环境中使用扩展名*.ld) 

      (2)命令脚本文件:在SDRAM中调试程序时起作用。在集成环境与目标连接时、软件调试过程中以及目标板复位后,有时需要集成环境自动完成一些特定的操作,比如复位目标板、清除看门狗、屏蔽中断寄存器、存储区映射等。这些操作可以通过执行一组命令序列来完成,保存一组命令序列的文本文件称为命令脚本文件(在IDE开发环境中使用扩展名*.cs)。 

      (3)存储区映像文件:在SDRAM中调试程序时起作用。在软件调试过程中访问非法存储区在部分处理器和目标板上会产生异常,如果异常没有处理,则会导致软件调试过程无法继续,为了防止以上问题并调整仿真器访问速度以达到最合适的水平,提供这样一种用于描述各个存储区性质的文件叫存储区映像文件(在IDE开发环境中使用扩展名*.map)。在程序的调试过程中可以选择使用存储区映像文件*.map和命令脚本文件*. cs配合程序的调试。      
 
      (4)启动文件:它主要是完成一些和硬件相关的初始化的工作,为应用程序做准备。一般,启动代码的第一步是设置中断和异常向量;第二步是完成系统启动所必须的寄存器配置;第三步设置看门狗及用户设计的部分外围电路;第四步是配置系统所使用的存储区分配地址空间;第五步是变量初始化;第六步是为处理器的每个工作模式设置栈指针;最后一步是进入高级语言入口函数(Main函数)。

4 中断程序设计 

      S3C4510B支持21个中断源,其中包括4个外部中断源,基于优先级的中断处理,可以识别两种类型的中断:正常中断请求(IRQ)和快速中断请求(FIQ)。
 
      S3C4510B的中断处理模式是一种典型的中断处理方法。当系统产生中断的时候,系统将中断悬挂寄存器(Interrupt Pending Register)中对应中断的标志位置位,然后跳转到位于0x18处的IRQ或0x1C处的FIQ中断处理函数中,该中断函数通过读取中断悬挂寄存器来判断中断源,并根据优先级关系再跳转到对应中断源的处理代码内。 

      对此,一般采取的中断处理方法是在0x18处的IRQ或0x1C处的FIQ中断处理函数中进行获取中断源、清除中断挂起标志、进入用户中断函数的相关程序。显然,在用户程序复杂,中断源较多的情况下,采用此法必须进行中断源的判断和散转处理,这样会影响中断处理的响应时间和程序性能。
 
      在我们的应用开发过程中,在中断调试方面采用了类似矢量中断动态处理方式,让中断对应的确定地址代码调转到RAM的固定地址处,定义一个函数指针指向该固定地址,就可以随时通过替换RAM固定地址处的代码,实现动态改变中断处理函数。 

      具体方法是: 
      (1)将中断源函数指针定义在RAM中相对的固定地址,建立中断矢量表; 
      void SetInterrupt (U32 vector, void (*handler)()) 
      {
      InterruptHandlers[vector] = handler; 
      } 
      (2)在程序中,调用具体某中断源的中断处理函数; 
      如:  SetInterrupt(IIC_INT,IICWriteIsr);  
      /* 声明IIC中断处理函数,其中IIC_INT为 IIC中断源序号,IICWriteIsr为 IIC的写中断处理函数 */ 
      (3)在0x18处的IRQ或0x1C处的FIQ中断入口函数中,获取中断源、清除中断挂起标志、通过已定义的中断源函数指针进入用户具体某中断处理程序。  
      void ISR_IrqHandler(void) 
      { 
          IntOffSet = (unsigned int)INTOFFSET; 
          Clear_PendingBit(IntOffSet>>2) ; 
      (*InterruptHandlers[IntOffSet>>2])(); 
      // 调用具体某中断处理程序 
      } 
      采用动态的中断处理方法,在中断源较多的情况下,中断响应时间和程序性能得到优化。另外,在调试方面,此处理方法具有便于跟踪调试的优点,并且根据需要,可以方便变换中断处理函数。


5 中断调试 

      软件调试可以在SDRAM中或FLASH中进行。在SDRAM中,读写方便,访问速度快。一般软件调试应在RAM中完成,但当RAM空间小于FLASH程序空间,程序只能在FLASH运行和调试时,或者用户希望了解程序在FLASH中实际运行情况时,就可以在FLASH中进行程序调试。
 
      进行中断调试时,应注意中断入口位于SDRAM中或FLASH中0x18或0x1c地址,链接脚本文件必须使整个系统的代码正确定位于0x0起始处,但SDRAM或FLASH对应的链接脚本文件及工程配置注意区别。 

      (1)程序在SDRAM中运行 

      在SDRAM中调试,使用SDRAM对应的链接脚本文件。调试过程需要以下几步:编译、链接工程;连接仿真器和电路板;下载程序(在IDE开发环境中使用扩展名*.elf);调试。
 
      下载程序前必须启动命令脚本文件完成前述的一些特定的操作,命令脚本文件的启动在连接仿真器时自动进行,其中存储区映射应与程序在SDRAM中运行时相同,保证整个系统的代码正确定位于0x0起始处。下载程序的起始地址也为0x0,下载成功后便可进行调试工作。 

      (2)程序在FLASH中运行 

      在FLASH中调试,使用FLASH对应的链接脚本文件。调试过程需要以下几步:编译、链接工程;连接仿真器和电路板;程序格式转换(*.elf转换为*.bin);固化*.bin程序;调试。 

      连接仿真器后不需要下载程序,存储区映射由本身工程中启动文件运行完成,不需要命令脚本文件。在本环境调试过程中,可以设置两个硬件断点。
 
      (3)程序从FLASH中调到SDRAM中运行 

      在某些应用场合,强调程序运行速度的情况下,希望程序在SDRAM中运行,这样就需要将FLASH中存储的程序,在系统上电后搬运到SDRAM某空间位置,然后自动运行。这种所谓的Bootloader技术,在DSP系统中常被采用。 

      调试过程分两步: 
      (1)首先将用户程序在SDRAM中调试通过,然后将*.bin文件固化到FLASH某一非0扇区地址空间;
(2)将自己编写的Bootloader搬运程序调试通过并将Bootloader.bin文件固化到FLASH的 0扇区地址空间,搬运程序在系统上电后,将(1)中FLASH某一非0扇区地址空间存储的程序,搬运到在SDRAM调试中同样的空间位置,实现程序在SDRAM中运行的目的。
 
      另外注意,因为用户实际的程序中断入口必须位于FLASH的0x18或0x1c地址,所以Bootloader搬运程序还应具有中断入口的跳转功能,即把PC指针由此转向处于SDRAM空间的中断程序入口表,就是整个用户程序被搬运到SDRAM的那一位置。  
      如:LDR    PC,    =HandleIRQ 
      // HandleIRQ位于SDRAM空间中断程序入口表 
      在本项目开发过程中,由于系统实时性要求高,定时器中断达到微秒级,程序在FLASH中运行时,速度不能达到系统要求,故采用把程序从FLASH中调到SDRAM中运行的方式,问题得到解决。

6 结束语 

      上述有关中断动态处理方法及其3种运行方式,是基于S3C4510B系统调试的一点小结,在ARM技术的实际应用中具有典型性和代表性,读者可根据自己的应用场合及应用目的参考指正。

 

 
【相关文章】
·基于单片机技术的光电检测研究
·复用的SOC测试技术
·利用可编程逻辑器件设计有限冲激响应滤波器
·ARM的三种中断调试方法的探讨
· 软件有助于RFIC与摩尔定律并驾齐驱
·用于433MHz ISM频带的低功耗超再生接收器
·LT6011在霍尔传感器和DAC放大器中的应用
·AMBA片上总线在SoC芯片设计中的应用
·基于PDIUSBD12芯片的USB接口设计
·在线放大器参数评估工具加快运算放大器选择过程
·利用综合技术来扩展无线局域网的覆盖范围
·为DTV地面广播接收机选择高质量的解调解码芯片
·锐和微电子率先推出UIC4101芯片将USB线延长至30-50米
·TI 最新 VoIP 片上系统与软件
·输出能驱动多个负载的立体声放大器IC
·基于PLD的高速数据采集系统
 
 
新闻搜索
 
新闻热点
基于红外超声光电编码器的室内移动小车定位系
基于闪烁存储器的TMS320VC5409DSP并行引导装载方法
非移动市场需求飙升,ARM预计2010年出货量超50亿片
一种快速响应的电容式湿度传感器感湿薄膜设计
利用特殊应用模拟开关改进便携式设计
无线传感器网络跨层通信协议的设计
基于GSM技术的汽车防盗系统的设计
热电阻在烟叶初烤炕房温度控制中的应用
高速数据转换系统对时钟和数据传输的性能要求
Zetex迷你晶体管功率达1.25W
友情连接
 关于我们  IC论坛  意见反馈  设置首页  广告服务  用户帮助  联系我们
copyright:(1998-2005) IC72 中国·芯片交易在线
(北京)联系电话:(010)82614113、82614123 传真:(010)82614123 客户服务:service@IC72.com 库存上载:IC72@IC72.com
在线MSN咨询:ic72sale8@hotmail.com 通信地址:北京市西城区西直门内大街2号大厦15层 邮政编码:100013
(深圳)联系方式: 在线MSN咨询:ic72sale6@hotmail.com 在线QQ咨询:191232636 通信地址:深圳市福田区振华路
注 册 号: 1101081318959(1-1)

A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 0 1 2 3 4 5 6 7 8 9