ARM 经典40问答(2)
Q:请教:如何定义不被初始化变量
A:让编译器不知道有这个内存地址即可。
A:如用分散加载文件分配RAM故意预留一部分RAM不分配,用它来存您不需要初始化的东西。或者不调用编译器提供的启动代码,不过这样可能编程会麻烦一些。
第22问:
Q:我直接通过JTAG口下载EasyArm板带的Ext1_test程序到arm中,出现中断向量的告警:
interrupt vector is not correct arm is not running freely.
果然复位后芯片不能运行。但是我用串口下载后芯片能正常工作,中断也行的。
并且我用JTAG仿真的话,芯片能正常工作,中断也行的,唯独JTAG口下载不行。
不知道是什么原因
A:仿真器配置中要设置Erase Flash when need.也可以这样试试:
1.可以先打开一个工程在RAM中调试运行;
2.stop程序;
3.使用File->Load Image…重新加载Ext1_test生成的*.axf文件。
Q:仿真器配置中我是设置了Erase Flash when need,但照你说的话,那不是在RAM下调试吗
在RAM下调试我是可以的,但是下载后出现interrupt vector da
我又看了几篇文章,是不是跟中断向量表的累加和不为零有关系啊
A:是的,是向量表的累加和不为零。
因为如果用ISP下载能运行,说明向量表的累加和已为零,而用JTAG下载不能运行的情况可能是 没有正常下载代码。先在RAM中调试,目的是为了后面正确下载程序到FLASH.
第23问:
Q:用Scatter怎样将某个函数或文件定位在Flash的某个位置
A:参考http: //www.zlgmcu.com/download/downs.asp?ID=1009
第24问:
Q:我在仿真时遇到这样的提示:
Error, Flash is protected by user configation!
怎么写到flash里面呢
A:看配套《arm微控制器基础与实战》附录一。
第25问:
Q:我在移植实验中想到了两个问题,如下:
1.Debug和Release以及DebugRel有什么不同,为什么在作2104移植实验时,要用Release
2.在Release中为什么要将RW Base设置为0x40000040 我将其设置为0x40003000,
为什么不能工作
A:都只是一个问题,内存空间的使用,因为跑OS要比较大的内存空间,所以要腾出点地方。
第26问:
Q:请问没有MMU的arm芯片是否支持使用malloc()函数动态分配内存
A:是否支持malloc()函数与芯片没有多大关系,主要与编译器有关。
Q:再问:如果没有操作系统支持呢
A:也支持。
第27问:
Q:在I2C实验程序中,我想查看数据缓冲区DataBuf的值,怎么查看
A:watch窗口或鼠标停留在要查看的变量名上。
Q:我查询的是写入DataBuf缓冲区的值,鼠标在上面根本就不会出现他的值,即使在watch中加入, 结果也是"name not found".
A:变量被优化,调试时可以把该变量定义为全局变量查看。
第28问:
Q:仿真软件和2104开发板连接不上
DBE Warning 00041:
!An unspecified Debug Toolbox call failed
电源和开发板都连好,错误和没接开发板一样,驱动也安装了,安装时按确定键时,软件很长时间才有如上反应,请帮忙
A:1.并口是否正常
2.在其它操作系统(如98)下或其它台式PC下试试。
第29问:
Q:如何生成32位hex文件
我在Release Setting->arm fromELF->Output Format中设置为Intel 32bit HEX,可是好像没有生成hex文件
A:试试这种方法:
Target-->Target Setting--> ost Link中选择"arm fromELF"加上你上面设的应该不成问题。
第30问:
Q:请问关于settings中r0 base rw base的意思
A:ro:read on
第31问:
Q:编译成功后的信息{dy}行,co
A:R0 只读段,即程序代码空间;
RW 可读/写段,即数据变量空间;
ZI 清零变量段,即需要清零初始化的数据变量空间。
第32问:
Q:如何在ADS里面看任务执行的一些情况 比如堆栈。
A:多任务环境下的堆栈,内存等信息需要调试软件的支持才可以实现。
ucos下有一个统计功能的模块可以间接实现部分功能。
第33问:
Q:请问向flash烧数据时出现:exceeds flash limitation 请予赐教!
A:要写入的flash地址超过了范围。如果不是代码太大的问题,可以检查scf文件是否正确。
第34问:
Q:在LPC2214之类的芯片中如何实现数组的{jd1}地址定位,比如51的_at_的用法。
A:*((char*)0x40000300)类似访问
Q:谢谢,但这样做就无须定义数组变量,访问也不便,还有高招吗
A:可以使用分散加载。
第35问:
Q:请问 ADS编译错误"L6221E:Execution region ER_RO overlays with Execution region
ER_ZI" 该如何解决
A:请用我们网站上的工程模板试一试,{zd0}的可能是因为你的RELEASE或者DEBUG选项里面没有正确设置,按照参考《arm微控制器基础与实战》上面的设置,是不会有这个问题的。
第36问:
Q:请教一下:将程序写入flash,再用从JTAG方式调试写入之后再复位程序没什么反映。 看了很多以前的帖子,说memmap寄存器要为1,我用的是一个很简单的控制led的例子,改动了参数之后写入flash的。在这个程序的vectors中找不到关于memmap寄存器操作的部分啊,这是怎么回事,该怎么办呢
A:《arm微控制器基础与实战》上附录有"常见问题",列举了几点程序写到FLASH不能运行的原因。 memmap操作可以在target.c中的TargetResetInit()函数内添加。
第37问:
Q:HEX文件。EASY2100配套《arm微控制器基础与实战》上讲:把项目编译成HEX文件,我不会呀,咋办
A:Target-〉target settings设置Post-linker并且设置Linker-〉fromELF.
Q:再问:我用的是光盘里的例子,打开工程项目里是DebugInarm.DebugInFlash.
RelInFlash.不是《ARM微控制器基础与实战》上的DebugRel呀,我都照《arm微控制器基础与实战》上设置的,可用ISP下载,提示无法找到HEX文件。
A:光盘上的例子是用专用工程模板建立,已经设置好参数,与默认模板不同。
第38问:
Q:Easyarm2100开发板如何通过JTAG接口下载到Flash
我在用Easyarm2100开发板时JTAG接口不能进行Flash中的调试(DebugInFlash),但是可以在RAM中调试(DebugInRAM),且通过ISP编程可以写入Flash.
通过JTAG接口进行DebugInFlash调试时,总是出现如下提示:
Flash Sector 0 write failed!
Warnning interrupt vectors da
Program you downloaded can not run freely!
请问是什么原因 我该如何办
A:仿真器设置选项有一个允许擦除FLASH的选项,选择它。
第39问:
Q:我发现程序在RAM调试时(RO=0X40000000) OK,但是JTAG下载到FLASH(RO=0X00000000),
显示如下:
The session file 'c:\Documents and Settings\jan\default-1-2-0-0.ses'
could not be loaded.
A:这是ADS自身的问题,请不要通过IDE运行AXD,而是通过开始菜单运行,然后Load调试文件调试。
第40问:
Q:我有几个问题想问问大家。
调试主机负责对ARM源程序进行编译链接,{zh0}用什么样的高级语言对arm源程序进行编译链接 使用调试程序(如AXD)进行JTAG调试,AXD是什么调试程序,是否是类似什么软件之类的 到哪能下载AXD的调试程序呢 怎么样进行AXD程序进行JTAG调试
如何通过JTAG仿真器发送到目标机上呢
对于单片机的调试,都用到了什么软件
都个有什么作用呢
A:可以使用 ADS1.2,Keil C也支持。AXD是ADS的一个组件。
您可以在下载 Easyarm2100开发套件快速入门看一看。