嵌入式软件开发流程及ARM的中断调试方法介绍

发布者:数字冒险最新更新时间:2011-11-16 关键字:ARM  中断调试 手机看文章 扫描二维码
随时随地手机看文章

  1 嵌入式软件开发流程

  参照嵌入式软件的开发流程。第一步:工程建立和配置。第二步:编辑源文件。第三步:工程编译和链接。第四步:软件的调试。第五步:执行文件的固化。

  在整个流程中,用户首先需要建立工程并对工程做初步的配置,包括配置处理器和配置调试设备。编辑工程文件,包括自己编写的汇编和C语言源程序,还有工程编译时需要编写的链接脚本文件,调试过程中需要编写存储区映像文件和命令脚本文件,以及上电复位时的程序运行入口的启动程序文件。

  对后四种文件的理解很重要,其作用解释如下。

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

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

  (3)存储区映像文件:在SDRAM中调试程序时起作用。在软件调试过程中访问非法存储区在部分处理器和目标板上会产生异常,如果异常没有处理,则会导致软件调试过程无法继续,为了防止以上问题并调整仿真器访问速度以达到最合适的水平,提供这样一种用于描述各个存储区性质的文件叫存储区映像文件(在IDE开发环境中使用扩展名*.Map)。

  在程序的调试过程中可以选择使用存储区映像文件*.Map和命令脚本文件*. Cs配合程序的调试。

  (4) 启动文件:它主要是完成一些和硬件相关的初始化的工作,为应用程序做准备。一般,启动代码的第一步是设置中断和异常向量;第二步是完成系统启动所必须的寄存器配置;第三步设置看门狗及用户设计的部分外围电路;第四步是配置系统所使用的存储区分配地址空间; 第五步是变量初始化;第六步是为处理器的每个工作模式设置栈指针;最后一步是进入高级语言入口函数(Main函数)。

  2 中断程序设计

  中断调试方面可以采用类似矢量中断动态处理方式,让中断对应的确定地址代码调转到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])();

  // 调用具体某中断处理程序

  }

  采用动态的中断处理方法,在中断源较多的情况下,中断响应时间和程序性能得到优化。另外,在调试方面,此处理方法具有便于跟踪调试的优点,并且根据需要,可以方便变换中断处理函数。[page]

3 中断调试

 

  软件调试可以在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系统中常被采用。

  调试过程分两步:

  (A)首先将用户程序在SDRAM中调试通过,然后将*.Bin文件固化到FLASH某一非0扇区地址空间;

  (B) 将自己编写的Bootloader搬运程序调试通过并将Bootloader.Bin文件固化到FLASH的 0扇区地址空间,搬运程序在系统上电后,将(A)中FLASH某一非0扇区地址空间存储的程序,搬运到在SDRAM调试中同样的空间位置,实现程序在SDRAM中运行的目的。

  另外注意,因为用户实际的程序中断入口必须位于FLASH的0x18或0x1c地址,所以Bootloader搬运程序还应具有中断入口的跳转功能,即把PC指针由此转向处于SDRAM空间的中断程序入口表,就是整个用户程序被搬运到SDRAM的那一位置。

  如:LDR PC, =HandleIRQ

  // HandleIRQ位于SDRAM空间中断程序入口表.

 

 

关键字:ARM  中断调试 引用地址:嵌入式软件开发流程及ARM的中断调试方法介绍

上一篇:ARM宣布公司联合创始人兼CEO布朗将于明年退休
下一篇:基于LPC2214和uC/OS-II的音频处理方案及电路说明

推荐阅读最新更新时间:2024-03-16 12:46

基于ARM-WinCE平台的时钟同步设计
随着计算机技术、网络通信技术的进步,组建分布式网络化测试系统,提高测试效率、共享信息资源,已成为现代测试系统发展的方向。分布式测试系统通过网络等通信媒介把分布于各测试点、独立完成特定功能的测试设备连接起来,以达到测试资源共享和协同工作等目的。时钟同步是分布式系统的核心技术之一,其目的是维护一个全局一致的物理或逻辑时钟,使得系统内各个节点中与时间有关的信息、事件及行为有一个全局一致的解释。IEEE1588精确时钟协议是当前分布式测试系统中时钟同步研究的热点。采用硬件支持的IEEE1588协议能够在以太网中不同结点之间实现纳秒级的时钟同步,为工厂自动化、测试和测量以及通信等领域需要高精度时钟同步的应用提供了一种有效的解决方案。本文采
[单片机]
基于<font color='red'>ARM</font>-WinCE平台的时钟同步设计
基于ARM的低功耗语音增强系统设计
近年来,电子技术的发展促进了多媒体设备的繁荣,同时随着人们对便携式设备和可移动终端的广泛需求,使得低功耗成为了这类电子设备最大的技术难题之一。低功耗意味着在同一时间段内在相同条件下移动终端消耗的能量更少,使得此类设备有更长的续航工作时间。低功耗设计降低了系统功耗,提高了能量利用率。 ARM微处理器因其高性能和低功耗的特性,特别适合于便携式设备的开发与应用。本文设计了一种基于ARM的低功耗语音去噪系统,为应用于便携式移动的语音去噪设备提供了一种很好的设计思路和方法。 1 算法设计 谱减法的原理就是在频域将噪声的频谱分量从带噪语音信号的频谱中减去。其设计思想是在假设加性噪声与短时平稳的语音信号相互独立的条件下,从带噪语音信
[单片机]
基于<font color='red'>ARM</font>的低功耗语音增强系统设计
ARM工控核心板在免疫荧光检测仪中的应用
  免疫荧光检测仪根据荧光免疫分析原理,通过快速定量检测CRP(全程C-反应蛋白)以确定抗原或抗体的性质指导临床用药,检测流程如图1所示。   图1 荧光检测流程   免疫荧光检测仪控制板功能需求:   ●中英文显示界面及触摸屏操作;   ●RS-232接口,用于驱动微打、与单片机通讯;   ●以太网接口,与LIS(实验室信息管理系统)连接;   ●支持浮点运算,快速数据处理;   ●可靠电磁兼容设计,医疗器械认证。   1.1 免疫荧光检测仪控制板设计难点   1. 医疗器械认证失败,销售受阻   医疗检测器械为智能型电子设备,静电、电磁干扰直接影响检测的灵敏度与检测结果的准确性,造成医生误判,间接影
[单片机]
<font color='red'>ARM</font>工控核心板在免疫荧光检测仪中的应用
ARM外设flash及SDRAM的地址连接
先提一下位宽的概念,对于具体器件而言,它的位宽是一定的,所谓位宽,指的是“读/写操作时,最小的数据单元”──别说最小单元是“位”,一般设备上没有单独的“位操作”,修改位时通过把整个字节、字或双字读出来、修改,再回写。AM29L800BB这种nor flash位宽是16位。K4S561632C这种SDRAM位宽是32位。 对于CPU来说,一个地址对应的是一个字节(8位),也就是说CPU的地址线(A0~A20)对应的最小数据单元是字节。 这里需要注意的是,不要把“外设的位宽”和“CPU的位数”这两个概念混淆了。外设的位宽是读写外设的最小数据单元,CPU位数是CPU可以一次处理的字节数,32位CPU可以一次处理4字节数据
[单片机]
ARM汇编----IMPORT
IMPORT伪操作告诉编译器当前的符号不是在本源文件中定义的,而是在其他源文件中定义的,在本源文件中可能引用该符号,而且不论本源文件是否实际引用该符号,该符号都将被加入到本源文件的符号表中。 语法格式: IMPORT symbol{ } 其中,symbol为声明的符号的名称。它是区分大小写的。 指定这个选项后,如果symbol在所有的源文件中都没有被定义,编译器也不会产生任何错误信息,同时编译器也不会到当前没有被INCLUDE进来的库中去查找该符号。 使用说明: 使用IMPORT伪操作声明一个符号是在其他源文件中的定义。如果连接器在连接处理时不能解析该符号,而IMPORT伪操作中没有指定 选项,则连接器将会报告错误。如果连
[单片机]
Tiny4412友善之臂ARM开发板静态IP设置(重启有效)
刚入手Tiny4412开发板,发现它的ip地址不是192.168.1.230,老是自动跳变,今天是192.168.1.7,明天开机就变成了192.168.1.8,所以就决定将其设为静态ip地址:192.168.1.240。 首先参考网上提供的一个常见的方案: 要修改arm开发板的IP,如果是yaffs2文件,可以 1、首先要修改/etc/init.d/rcS文件,在/sbin/ifconfig lo 127.0.0.0 下添加一行/sbin/ifconfig eth0 192.168.1.20 up 注:192.168.1.20 只是举例,可以改成你想要修改的IP地址 本来这样修改之后就可以的,但是我发现仍然不行,使用ifco
[单片机]
Tiny4412友善之臂<font color='red'>ARM</font>开发板静态IP设置(重启有效)
基于ARM的实时测控系统开发平台
摘要:基于ARM的实时测控系统开发平台,是将高性能、低功耗32bit RISC结构的ARM内核处理器与开放源码的实时嵌入式多任务操作系统%26;#236;C/OS-Ⅱ相结合,并通过Interniche公司的嵌入式TCP/IP协议栈为平台添加网络传输功能,构建一个新型的实时测控系统开发平台。为开发各种智能化、小型化现代测控系统提供可重用、高性能、图形化、网络化软硬件基础平台和高效的开发模式。充分利用高级语言的优势在多任务操作系统的基础上,为平台添加友好的人机交互方式、图形化界面、网络、各种通信接口驱动,使其平台具备现代嵌入式系统的特征。 关键词:实时测控系统 ARM %26;#236;C/OS-II 嵌入式实时操作系统 嵌入式TC
[嵌入式]
TI嵌入式高层谈与ARM合作策略
引言:TI拥有繁杂的嵌入式产品线,有ARM内核的,也有专有内核的;有DSP的,也有DSP+ARM的,还有一直处于风口浪尖的OMAP,TI对这些产品线是何策略?电子工程专辑独家专访TI嵌入式高层为您解答。 TI可以算是ARM困难时期的贵人,当年就是因为TI使用ARM内核开发了诺基亚手机用的芯片,使得ARM得以进入移动市场,而这个市场正是ARM得以发迹的主力市场。而有趣的是当年为何会选择ARM,据说也是因为TI在DSP领域已经取得领袖地位,但并不熟悉处理器业务,而当时有自己处理器技术,又不那么强势的公司,似乎只有ARM。这段姻缘可以说是一段传奇,促成了当今移动处理器市场的基本格局。今天的ARM已非当年吴下阿蒙,但是它与TI的良好合作关
[手机便携]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved