嵌入式学习资料之ARM的三种中断调试方法课件_第1页
嵌入式学习资料之ARM的三种中断调试方法课件_第2页
嵌入式学习资料之ARM的三种中断调试方法课件_第3页
嵌入式学习资料之ARM的三种中断调试方法课件_第4页
嵌入式学习资料之ARM的三种中断调试方法课件_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

嵌入式学习资料之ARM的三种中断调试方法1嵌入式软件开发流程链接脚本文件命令脚本文件存储区映像文件启动文件2中断程序设计(1)将中断源函数指针定义在RAM中相对的固定地址(2)在程序中,调用具体某中断源的中断处理函数(3)在0x18处的IRQ或0x1C处的FIQ中断入口函数中3中断调试(1)程序在SDRAM中运行(2)程序在FLASH中运行(3)程序从FLASH中调到SDRAM中运行嵌入式学习资料之ARM的三种中断调试方法1嵌入式软件开发流1参照嵌入式软件的开发流程。第一步:工程建立和配置。第二步:编辑源文件。第三步:工程编译和链接。第四步:软件的调试。第五步:执行文件的固化。在整个流程中,用户首先需要建立工程并对工程做初步的配置,包括配置处理器和配置调试设备。编辑工程文件,包括自己编写的汇编和C语言源程序,还有工程编译时需要编写的链接脚本文件,调试过程中需要编写存储区映像文件和命令脚本文件,以及上电复位时的程序运行入口的启动程序文件。对后四种文件的理解很重要,其作用解释如下:1嵌入式学习资料之嵌入式软件开发流程参照嵌入式软件的开发流程。第一步:工程建立和配置。第二步2(1)链接脚本文件:在程序编译时起作用。该文件描述代码链接定位的有关信息,包括代码段,数据段,地址段等,链接器必须使用该文件对整个系统的代码做正确的定位。在SDRAM中调试程序、在FLASH中调试或固化后运行的链接脚本文件应加以区分。(在IDE开发环境中使用扩展名*.ld)(1)嵌入式学习资料之链接脚本文件(1)链接脚本文件:在程序编译时起作用。该文件描述代码链接3(2)命令脚本文件:在SDRAM中调试程序时起作用。在集成环境与目标连接时、软件调试过程中以及目标板复位后,有时需要集成环境自动完成一些特定的操作,比如复位目标板、清除看门狗、屏蔽中断寄存器、存储区映射等。这些操作可以通过执行一组命令序列来完成,保存一组命令序列的文本文件称为命令脚本文件(在IDE开发环境中使用扩展名*.cs)。(2)嵌入式学习资料之命令脚本文件(2)命令脚本文件:在SDRAM中调试程序时起作用。在集成环4(3)存储区映像文件:在SDRAM中调试程序时起作用。在软件调试过程中访问非法存储区在部分处理器和目标板上会产生异常,如果异常没有处理,则会导致软件调试过程无法继续,为了防止以上问题并调整仿真器访问速度以达到最合适的水平,提供这样一种用于描述各个存储区性质的文件叫存储区映像文件(在IDE开发环境中使用扩展名*.map)。在程序的调试过程中可以选择使用存储区映像文件*.map和命令脚本文件*.cs配合程序的调试。(3)嵌入式学习资料之存储区映像文件(3)存储区映像文件:在SDRAM中调试程序时起作用。在软件5(4)启动文件:它主要是完成一些和硬件相关的初始化的工作,为应用程序做准备。一般,启动代码的第一步是设置中断和异常向量;第二步是完成系统启动所必须的寄存器配置;第三步设置看门狗及用户设计的部分外围电路;第四步是配置系统所使用的存储区分配地址空间;第五步是变量初始化;第六步是为处理器的每个工作模式设置栈指针;最后一步是进入高级语言入口函数(Main函数)。(4)嵌入式学习资料之启动文件(4)启动文件:它主要是完成一些和硬件相关的初始化的工作,6中断调试方面可以采用类似矢量中断动态处理方式,让中断对应的确定地址代码调转到RAM的固定地址处,定义一个函数指针指向该固定地址,就可以随时通过替换RAM固定地址处的代码,实现动态改变中断处理函数。具体方法是:2嵌入式学习资料之中断程序设计中断调试方面可以采用类似矢量中断动态处理方式,让中断对应7

(1)将中断源函数指针定义在RAM中相对的固定地址,建立中断矢量表;

voidSetInterrupt(U32vector,void(*handler)())

{

InterruptHandlers[vector]=handler;

}

voidSetInterrupt(U32vector,void(*handler)())

{

InterruptHandlers[vector]=handler;

}(1)将中断源函数指针定义在RAM中相对的固定地址(1)将中断源函数指针定义在RAM中相对的固定地址,建立中8

(2)在程序中,调用具体某中断源的中断处理函数;如:SetInterrupt(IIC_INT,IICWriteIsr);

/*声明IIC中断处理函数,其中IIC_INT为IIC中断源序号,IICWriteIsr为IIC的写中断处理函数*/(2)在程序中,调用具体某中断源的中断处理函数(2)在程序中,调用具体某中断源的中断处理函数;(2)在9

(3)在0x18处的IRQ或0x1C处的FIQ中断入口函数中,获取中断源、清除中断挂起标志、通过已定义的中断源函数指针进入用户具体某中断处理程序。

voidISR_IrqHandler(void)

{

IntOffSet=(unsignedint)INTOFFSET;

Clear_PendingBit(IntOffSet>>2);

(*InterruptHandlers[IntOffSet>>2])();

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

}(3)在0x18处的IRQ或0x1C处的FIQ中断入口函数(3)在0x18处的IRQ或0x1C处的FIQ中断入口函10

voidISR_IrqHandler(void)

{

IntOffSet=(unsignedint)INTOFFSET;

Clear_PendingBit(IntOffSet>>2);

(*InterruptHandlers[IntOffSet>>2])();

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

}采用动态的中断处理方法,在中断源较多的情况下,中断响应时间和程序性能得到优化。另外,在调试方面,此处理方法具有便于跟踪调试的优点,并且根据需要,可以方便变换中断处理函数。嵌入式学习资料voidISR_IrqHandler(void)嵌入式11软件调试可以在SDRAM中或FLASH中进行。在SDRAM中,读写方便,访问速度快。一般软件调试应在RAM中完成,但当RAM空间小于FLASH程序空间,程序只能在FLASH运行和调试时,或者用户希望了解程序在FLASH中实际运行情况时,就可以在FLASH中进行程序调试。进行中断调试时,应注意中断入口位于SDRAM中或FLASH中0x18或0x1c地址,链接脚本文件必须使整个系统的代码正确定位于0x0起始处,但SDRAM或FLASH对应的链接脚本文件及工程配置注意区别。3嵌入式学习资料之中断调试软件调试可以在SDRAM中或FLASH中进行。在SDRA12

(1)程序在SDRAM中运行在SDRAM中调试,使用SDRAM对应的链接脚本文件。调试过程需要以下几步:编译、链接工程;连接仿真器和电路板;下载程序(在IDE开发环境中使用扩展名*.elf);调试。下载程序前必须启动命令脚本文件完成前述的一些特定的操作,命令脚本文件的启动在连接仿真器时自动进行,其中存储区映射应与程序在SDRAM中运行时相同,保证整个系统的代码正确定位于0x0起始处。下载程序的起始地址也为0x0,下载成功后便可进行调试工作。(1)嵌入式学习资料之程序在SDRAM中运行(1)程序在SDRAM中运行(1)嵌入式学习资料之程序在13在FLASH中调试,使用FLASH对应的链接脚本文件。调试过程需要以下几步:编译、链接工程;连接仿真器和电路板;程序格式转换(*.elf转换为*.bin);固化*.bin程序;调试。连接仿真器后不需要下载程序,存储区映射由本身工程中启动文件运行完成,不需要命令脚本文件。在本环境调试过程中,可以设置两个硬件断点。(2)嵌入式学习资料之程序在FLASH中运行在FLASH中调试,使用FLASH对应的链接脚本文件。调14

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

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

(b)将自己编写的Bootloader搬运程序调试通过并将Bootloader.bin文件固化到FLASH的0扇区地址空间,搬运程序在系统上电后,将(a)中FLASH某一非0扇区地址空间存储的程序,搬运到在SDRAM调试中同样的空间位置,实现程序在SDRAM中运行的目的。另外注意,因为用户实际的程序中断入口必须位于FLASH的0x18或0x1c地址,所以Bootloader搬运程序还应具有中断入口的跳转功能,即把PC指针由此转向处于SDRAM空间的中断程序入口表,就是整个用户程序被搬运到SDRAM的那一位置。如:LDRPC,=HandleIRQ

//HandleIRQ位于SDRAM空间中断程序入口表嵌入式学习资料(b)将自己编写的Bootloader搬运程序调试通过并16嵌入式学习资料之ARM的三种中断调试方法1嵌入式软件开发流程链接脚本文件命令脚本文件存储区映像文件启动文件2中断程序设计(1)将中断源函数指针定义在RAM中相对的固定地址(2)在程序中,调用具体某中断源的中断处理函数(3)在0x18处的IRQ或0x1C处的FIQ中断入口函数中3中断调试(1)程序在SDRAM中运行(2)程序在FLASH中运行(3)程序从FLASH中调到SDRAM中运行嵌入式学习资料之ARM的三种中断调试方法1嵌入式软件开发流17参照嵌入式软件的开发流程。第一步:工程建立和配置。第二步:编辑源文件。第三步:工程编译和链接。第四步:软件的调试。第五步:执行文件的固化。在整个流程中,用户首先需要建立工程并对工程做初步的配置,包括配置处理器和配置调试设备。编辑工程文件,包括自己编写的汇编和C语言源程序,还有工程编译时需要编写的链接脚本文件,调试过程中需要编写存储区映像文件和命令脚本文件,以及上电复位时的程序运行入口的启动程序文件。对后四种文件的理解很重要,其作用解释如下:1嵌入式学习资料之嵌入式软件开发流程参照嵌入式软件的开发流程。第一步:工程建立和配置。第二步18(1)链接脚本文件:在程序编译时起作用。该文件描述代码链接定位的有关信息,包括代码段,数据段,地址段等,链接器必须使用该文件对整个系统的代码做正确的定位。在SDRAM中调试程序、在FLASH中调试或固化后运行的链接脚本文件应加以区分。(在IDE开发环境中使用扩展名*.ld)(1)嵌入式学习资料之链接脚本文件(1)链接脚本文件:在程序编译时起作用。该文件描述代码链接19(2)命令脚本文件:在SDRAM中调试程序时起作用。在集成环境与目标连接时、软件调试过程中以及目标板复位后,有时需要集成环境自动完成一些特定的操作,比如复位目标板、清除看门狗、屏蔽中断寄存器、存储区映射等。这些操作可以通过执行一组命令序列来完成,保存一组命令序列的文本文件称为命令脚本文件(在IDE开发环境中使用扩展名*.cs)。(2)嵌入式学习资料之命令脚本文件(2)命令脚本文件:在SDRAM中调试程序时起作用。在集成环20(3)存储区映像文件:在SDRAM中调试程序时起作用。在软件调试过程中访问非法存储区在部分处理器和目标板上会产生异常,如果异常没有处理,则会导致软件调试过程无法继续,为了防止以上问题并调整仿真器访问速度以达到最合适的水平,提供这样一种用于描述各个存储区性质的文件叫存储区映像文件(在IDE开发环境中使用扩展名*.map)。在程序的调试过程中可以选择使用存储区映像文件*.map和命令脚本文件*.cs配合程序的调试。(3)嵌入式学习资料之存储区映像文件(3)存储区映像文件:在SDRAM中调试程序时起作用。在软件21(4)启动文件:它主要是完成一些和硬件相关的初始化的工作,为应用程序做准备。一般,启动代码的第一步是设置中断和异常向量;第二步是完成系统启动所必须的寄存器配置;第三步设置看门狗及用户设计的部分外围电路;第四步是配置系统所使用的存储区分配地址空间;第五步是变量初始化;第六步是为处理器的每个工作模式设置栈指针;最后一步是进入高级语言入口函数(Main函数)。(4)嵌入式学习资料之启动文件(4)启动文件:它主要是完成一些和硬件相关的初始化的工作,22中断调试方面可以采用类似矢量中断动态处理方式,让中断对应的确定地址代码调转到RAM的固定地址处,定义一个函数指针指向该固定地址,就可以随时通过替换RAM固定地址处的代码,实现动态改变中断处理函数。具体方法是:2嵌入式学习资料之中断程序设计中断调试方面可以采用类似矢量中断动态处理方式,让中断对应23

(1)将中断源函数指针定义在RAM中相对的固定地址,建立中断矢量表;

voidSetInterrupt(U32vector,void(*handler)())

{

InterruptHandlers[vector]=handler;

}

voidSetInterrupt(U32vector,void(*handler)())

{

InterruptHandlers[vector]=handler;

}(1)将中断源函数指针定义在RAM中相对的固定地址(1)将中断源函数指针定义在RAM中相对的固定地址,建立中24

(2)在程序中,调用具体某中断源的中断处理函数;如:SetInterrupt(IIC_INT,IICWriteIsr);

/*声明IIC中断处理函数,其中IIC_INT为IIC中断源序号,IICWriteIsr为IIC的写中断处理函数*/(2)在程序中,调用具体某中断源的中断处理函数(2)在程序中,调用具体某中断源的中断处理函数;(2)在25

(3)在0x18处的IRQ或0x1C处的FIQ中断入口函数中,获取中断源、清除中断挂起标志、通过已定义的中断源函数指针进入用户具体某中断处理程序。

voidISR_IrqHandler(void)

{

IntOffSet=(unsignedint)INTOFFSET;

Clear_PendingBit(IntOffSet>>2);

(*InterruptHandlers[IntOffSet>>2])();

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

}(3)在0x18处的IRQ或0x1C处的FIQ中断入口函数(3)在0x18处的IRQ或0x1C处的FIQ中断入口函26

voidISR_IrqHandler(void)

{

IntOffSet=(unsignedint)INTOFFSET;

Clear_PendingBit(IntOffSet>>2);

(*InterruptHandlers[IntOffSet>>2])();

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

}采用动态的中断处理方法,在中断源较多的情况下,中断响应时间和程序性能得到优化。另外,在调试方面,此处理方法具有便于跟踪调试的优点,并且根据需要,可以方便变换中断处理函数。嵌入式学习资料voidISR_IrqHandler(void)嵌入式27软件调试可以在SDRAM中或FLASH中进行。在SDRAM中,读写方便,访问速度快。一般软件调试应在RAM中完成,但当RAM空间小于FLASH程序空间,程序只能在FLASH运行和调试时,或者用户希望了解程序在FLASH中实际运行情况时,就可以在FLASH中进行程序调试。进行中断调试时,应注意中断入口位于SDRAM中或FLASH中0x18或0x1c地址,链接脚本文件必须使整个系统的代码正确定位于0x0起始处,但SDRAM或FLASH对应的链接脚本文件及工程配置注意区别。3嵌入式学习资料之中断调试软件调试可以在SDRAM中或FLASH中进行。在SDRA28

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

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论