嵌入式技巧:ARM的三种中断调试方法介绍

发布者:science56最新更新时间:2012-04-10 来源: 赛迪网 关键字:嵌入式  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中断入口函数中,获取中断源、清除中断挂起标志、通过已定义的中断源函数指针进入用户具体某中断处理程序。 [page]

void ISR_IrqHandler(void)
{
    IntOffSet = (unsigned int)INTOFFSET;
    Clear_PendingBit(IntOffSet>>2) ;
(*InterruptHandlers[IntOffSet>>2])();

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

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

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 Linux开机后自动运行特定程序的方法
下一篇:恩智浦发布针对ARM微控制器的emWin图形库中文用户手册

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

arm-linux-gcc 常用参数讲解 gcc编译器使用方法
我们需要编译出运行在ARM平台上的代码,所使用的交叉编译器为 arm-linux-gcc。下面将arm-linux-gcc编译工具的一些常用命令参数介绍给大家。 在此之前首先介绍下编译器的工作过程,在使用GCC编译程序时,编译过程分为四个阶段: 1. 预处理(Pre-Processing) 2. 编译(Compiling) 3. 汇编(Assembling) 4. 链接(Linking) Linux程序员可以根据自己的需要让 GCC在编译的任何阶段结束,以便检查或使用编译器在该阶段的输出信息,或者对最后生成的二进制文件进行控制,以便通过加入不同数量和种类的调试代码来为 今后的调试做好准备。和其它常用的编译器一样,GCC也提供了
[单片机]
ARM裸机程序研究 - S3C2440时钟初始化
2440内部的时钟主要有3个, FCLK, HCLK, PCLK。 FCLK 提供给ARM920T内核使用, HCLK主要提供给高速外设使用,如显示接口,内存控制器, PCLK提供给低速外设使用,如串口,SPI, GPIO 等。另外还有一个UCLK, 只提供给USB Host 和USB Device使用。 2440的时钟来源有两种,外部时钟和通过外接晶振提供时钟。时钟源的选择通过引脚OM2和OM3来决定。因此,在芯片上电的时刻,就已经确定了时钟源。典型的时钟源配置是外界一个12M的无源晶振。 时钟源确定后,下面就是进一步确定各个时钟得频率。2440内部有一个PLL来合成频率,该PLL称为MPLL。它利用前面选择的时钟源,合
[单片机]
嵌入式Linux之我行——LED驱动在2440上的实例开发
一、开发环境 主 机:VMWare--Fedora 9 开发板:Mini2440--64MB Nand 编译器:arm-linux-gcc-4.3.2 二、实现步骤 1. 硬件原理图分析。由原理图得知LED电路是共阳极的,并分别由2440的GPB5、GPB6、GPB7、GPB8口控制的 2. 去掉内核已有的LED驱动设置,因为IO口与mini2440开发板的不一致,根本就不能控制板上的LED。 #gedit arch/arm/plat-s3c24xx/common-smdk.c //注释掉以下内容 static struct p
[单片机]
<font color='red'>嵌入式</font>Linux之我行——LED驱动在2440上的实例开发
外媒评软银收购ARM:这个投资很孙正义
    日本软银集团斥资322亿美元收购英国芯片设计公司ARM的交易,引来各方关注。对于此外国媒体纷纷发表评论,认为此次收购将震动整个芯片行业,有利于软银布局上游供应市场。 软银收购ARM   金融时报:英国并未失去投资吸引力   英国选择退出欧盟后,英国商业社区的吸引力开始受到质疑。与英国其他公司相比,作为芯片设计领域的全球力量,ARM受到英国退欧的影响不大。因为ARM在芯片行业中的关键领域处于领先地位,且主要以赚取美元为主。英国退欧导致英镑对日元汇率降低了30%左右,这令ARM成为有吸引力的收购目标。英国新任财政大臣菲利普·哈蒙德(Philip Hammond)表示,软银收购ARM可能是来自亚洲对英国的最大笔投资。这笔投
[手机便携]
ARM汇编----IMPORT
IMPORT伪操作告诉编译器当前的符号不是在本源文件中定义的,而是在其他源文件中定义的,在本源文件中可能引用该符号,而且不论本源文件是否实际引用该符号,该符号都将被加入到本源文件的符号表中。 语法格式: IMPORT symbol{ } 其中,symbol为声明的符号的名称。它是区分大小写的。 指定这个选项后,如果symbol在所有的源文件中都没有被定义,编译器也不会产生任何错误信息,同时编译器也不会到当前没有被INCLUDE进来的库中去查找该符号。 使用说明: 使用IMPORT伪操作声明一个符号是在其他源文件中的定义。如果连接器在连接处理时不能解析该符号,而IMPORT伪操作中没有指定 选项,则连接器将会报告错误。如果连
[单片机]
ARM的世界:特殊的生存之道
智能手机、平板机和移动互联网的兴起,让原本默默无闻的英国小公司ARM成了世界瞩目的焦点,甚至搞得半导体霸主Intel狼狈不堪,屡屡受挫。2008年开始,Intel不断尝试进入移动便携领域,但始终未能站稳脚跟。随着全新22nmSoC工艺和全新Atom架构的披露,Intel终于开始大发神威,ARM也从低调的后台走出来,畅谈自己的发展策略。Intel经常这么干,但是对ARM来说还是第一次。 有前媒体近日将刊登连载文章,从多个不同角度去深入探寻ARM的世界,今天是第一部分:ARM的商业模式是如何工作的? 在传统PC领域,半导体厂商一般有两种路子可选。首先是Intel那样的,从头到尾自己大包大揽,架构和芯片的设计、生产一律不依靠任何
[单片机]
linux下ARM处理器对16位FPGA的访问问题
有一个朋友在调试arm和FPGA接口的时候碰到了一个奇怪的问题,向我寻求帮助。 问题描述: arm使用s3c2440,fpga和arm的接口为16位,使用地址线,片选线为ncs3,操作系统使用linux-2.4 测试程序为:test.c #define FPGA_Address 0x18000000 int main( ) { unsigned char *sp; unsigned short mem; int memfd; memfd=open ( /dev/mem ,O_RDWR); sp=(unsigned char *)mmap(0,10000,PROT_READ|PROT_WRITE,MAP_SHARED
[单片机]
苹果收购ARM将导致智能手机市场格局崩盘
  尽管ARM公司和分析师都对苹果收购传闻表示否定。但是,这不表示苹果绝不可能收购ARM,只是比收购PA Semi、Intrinisity这类小型IC设计公司复杂多了。毕竟空穴来风,传闻往往最后都成真...   那么如果这一收购成真,对于苹果又有什么好处呢?   首先,收购有助于苹果降低成本。   ARM的商业模式是具有知识产权的IP授权及按照厂商销售的芯片数量来提取一定比例的收入。虽然总体的费用比较低廉,但随着苹果iPhone销售数量的不断增加,此笔费用也会相应提高,所谓积少成多。而如果拿下ARM后,苹果在芯片成本方面肯定会所有降低,当然,降低的幅度取决于苹果iPhone及iPad未来的销量。   第二,在芯片层面增加创
[手机便携]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

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

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

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