ImageVerifierCode 换一换
格式:DOC , 页数:3 ,大小:39KB ,
资源ID:3519671      下载积分:20 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-3519671.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(AXD_调试问题.doc)为本站会员(hw****26)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

AXD_调试问题.doc

1、ADS(AXD) 调试之我见 以前用 ADS(AXD) 进行 ARM 调试时遇到不少莫名其妙的问题,一会可以一会又不成,昨天跑的好好的,今就跑掉,当时感觉就是 ADS 这个工具不好用。最近有接触了一下 ADS(AXD)调试,觉得其实是以前不太会用,没 adptor 他的性情。总结一下吧:1. AXD 调试没有什么特别的,他的工作原理是将编译好的运行时映像 download 到 ARM相应地址中去,然后捕获 arm 的 PC 强制其到 ADS 中 entry point 所设置的映像入口地址上,然后你一点击 run,pc 就从这个入口地址取指,后面该咋执行就咋执行去了。实际代码的硬件运行环境就是

2、 ARM 芯片的运行环境。首先要明确一点的是 ADS(AXD) 在线 debug 时要将编译好的运行时代码 download 到ARM 的相应地址上去,这里这个 download 的地址,就是 arm 上存储部件的地址,必须是RAM 型的存储特性才可以被 AXD 进行 download,如果这个地址域被映射成是 Flash 存储器,AXD 是 download 不了的,虽然 AXD 不报错,但可以通过在 AXD 下用 dissambly 查看一下,如果是 flash 则看不到正确的指令。2.正确 download 之后就是执行程序了,一般外扩 SDRAM 要有对它时序的配置,这里用AXD 调试

3、注意一点当用外部 SDRAM 进行 download 程序时,比如说刚复位过的 ARM,extern SDRAM 这时还没有对他进行时序配置,这时用 AXDdownload 到 SDRAM 的话可能会有问题,(AXD 是通过 jtag 口在通过 sdram 把 code 放到 sdram 上去的,如果不在 axd 加载 code 前实现配置好 sdram 时序就无法保证加载的正确性,和运行时的正确性,)运行会产生什么异常指令之类的怪现象。sothat ,定要给 AXD 提供一个已经配置好时序确实可用的 SDRAM 这样才能保证 download。3. 正确进行 AXD download 后,接

4、下来就是执行代码了 , 这里也有要注意的事情,就是,代码里不要有再次对 SDRAM 进行时序配置的指令出现,这就好比,程序已经在 SDRAM里运行了,然后在运行的过程中又对 SDRAM 进行了配置,这会出现什么异常之类的怪现象的。4.能运行了,后面要想再跑一遍程序,不要用 AXD 的“reload current image“ 进行reload,最好把 AXD 关掉,然后点 ADS 的 debug 按钮以重新 download 的方式加载映像。感觉上 AXD 的“reload current image“ 还是会破坏 ram 运行时环境的,我指的是和时序相关的运行环境。重新 download

5、不会破坏 bootloader 所建立的 SDRAM 运行环境。5. 可以实现烧一个 bootload 代码让他脱离 ADS 就可运行的那种,在这个 bootloader 里为AXD 做好 RAM 存储域 的 remap 和 SDRAM 的配置,然后用 ADS(AXD)加载映像时 SDRAM 已经就是一个可用的 SDRAM 了, (硬复位bootloaderAXD 截获 cpuPC to image entry point).if 不去 bur 这样的 bootloader 代码,也可以先用 AXD 把一个类似于 bootloader 功能的code download 到ARM 内部 ram

6、中去(internal ram 不用配置时序之类的随时可用) 完成对 sdram 的配置 和 SDRAM 的 remap然后再用 AXD 将要调试的 code download 到这个已经配置好的 SDRAM 上去,这种方式也可以。xx. 还有就是在调试有中断的代码时,要注意 ram remap 到 0x00000000 地址然后重构中断向量表,犯过的一个错误是,在 0x00000000 重构了中断向量表,但是没有先把 sdram remap 到0x00000000 地址,实际填充的 flash 区,当然是写不进去的. cpu 发生中断的跳转地址永远是 0x00000000 - 0x00002

7、0。这与用不用 AXD 没有关系,AXD 不会干预 CPU 中断时 PC 的强跳转到 0x00000000-0x00000020 的特性。xx Processor ARM720T raise a exception cause : the processor was reset这个是 AXD 检测到 PC 指针跳到 0x00000000,从 0x00000000 取指执行 后产生的东东, 一般正常运行情况下 PC 只会产生其他 7 种异常(watch dog 例外). 当 pc 跳转到0x00000000 取指执行时会被 AXD 截获作为异常处理而弹出上面的终止框. (ex. mov pc,#

8、0x0 这样的指令在 AXD 下全速运行时就会引起上面的终止) 其实有时用户就是想要在AXD 监视下仍能使 PC 模拟复位的状况从 0x00000000 执行程序,这样的话可以将 AXD-optionconfigurate processor 对话框中的 vector catch 选项的R 选项去掉. 这个选项就是 AXD 用来监视 PC 从 0x00000000 取指时产生终止的功能 。把它去掉,这样就可以在 AXD 下顺利模拟 PC 从复位(0x00000000)来取指执行了。/其他几个选项是:Table 4.5. BreakpointsVector DescriptionR ResetU

9、 Undefined instructionS Software interrupt (SWI)P Instruction prefetch abortD Data access abortA1 Address exceptionVector DescriptionI Interrupt request (IRQ)F Fast interrupt request (FIQ)E2 Error1 Not used by AXD.2 Not used by AXD or ADW.写了这么多,其实最本质的东西就是,一定要为 AXD 建造一个合适的 RAM 运行环境,很多异常的发生都与这个有关。没有给他合适的运行环境。

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。