0

这是我第一次使用 Trace32,当我尝试执行此命令时,我试图在 arm 目标上刷新一个简单的 C 程序(据我所知,此命令会刷新目标但不确定?)。

d.load.elf image.axf /Verify /ComPare

我收到以下错误:

验证地址 NSX:0x8000 处的错误

我使用以下命令来编译和链接代码:

armclang --target=aarch64-arm-none-eabi hellofunc.c hellomake.c -g -fdata- 
sections -ffunction-sections -c

armlink --entry=0x8594 hellofunc.o hellomake.o --output=image.axf

如何刷新代码并进行调试?逐步执行每条指令

谢谢

4

2 回答 2

0

如果闪存已经编程,则不能对其进行编程 - 必须先将其擦除。请参阅Trace32 文档的第 93 页。此外,在您编程之前尝试compare将文件写入闪存总是会失败!

您需要擦除闪存启用闪存进行编程。例如:

FLASH.Erase ALL
FLASH.Program ALL
Data.load.elf image.axf /Verify
FLASH.Program off

请注意,如果除了要编程/调试的代码之外,您还有其他数据或闪存中的引导加载程序,则 Erase.ALL 可能不合适。

于 2018-09-11T08:59:32.137 回答
0

/ComPare如果您确实想对内存进行编程,请不要使用加载选项。

选项 /ComPare 表示:不加载任何代码。而是读取内存(在将加载 ELF 的位置)并将内存内容与 ELF 文件进行比较。

如果要将应用程序加载到可写内存并验证加载成功,请执行以下操作:

Data.LOAD.Elf image.axf
Data.LOAD.Elf image.axf /ComPare

或者

Data.LOAD.Elf image.axf
Data.LOAD.Elf image.axf /DIFF
IF FOUND()
( 
    PRINT %ERROR "Faild to load application image.axf at address " TRACK.ADDRESS() 
)

顺便说一句:我不会将这样的应用程序负载称为“闪烁”。在我看来,“闪烁”是关于对非易失性存储器进行编程。

于 2018-09-13T17:13:43.867 回答