Beaglebone Black JTag segger



我在Ubuntu linux下使用arm-none-eabi工具链在Beaglebone Black上使用Segger J-link进行裸机编程。

所以现在我得到每次错误没有源可用的"0x...."

当我暂停骨骼时,我在反汇编中得到以下内容:

b6e93ce1:   inc %ebx
b6e93ce2:   fdivl -0x4922eb40(%esi)
b6e93ce8:   call 0xdfa019f7
b6e93ced:   add %ch,%bl
b6e93cef:   mov $0x50,%dh
b6e93cf1:   add $0xdd,%al
b6e93cf3:   mov $0xa4,%dh
b6e93cf5:   or %ebp,%ebx
b6e93cf7:   mov $0xcc,%dh
b6e93cf9:   inc %eax
b6e93cfa:   fnsave -0x4922bf2c(%esi)
b6e93d00:   add %al,(%eax)
b6e93d02:   add %al,(%eax)
b6e93d04:   add %al,(%eax)
b6e93d06:   add %al,(%eax)
b6e93d08:   js 0xb6e93d4c
b6e93d0a:   fnsave -0x4922bb54(%esi)
b6e93d10:   xor $0x42,%al
b6e93d12:   fnsave -0x4922cfc0(%esi)
b6e93d18:   mov $0x42,%ah
b6e93d1a:   fnsave -0x4922cf98(%esi)
b6e93d20:   cmp $0x31,%al
b6e93d22:   fnsave -0x4922b92c(%esi)
b6e93d28:   xorb $0xdd,(%edx)
b6e93d2b:   mov $0xe0,%dh
b6e93d2d:   xor %ebx,%ebp
b6e93d2f:   mov $0xf0,%dh

当我开始调试程序时,J-Link重新启动骨骼正确,但随后linux启动,而不是我的程序。

您可能在这里遇到几个问题,但最严重的是您使用的是针对英特尔处理器的gdb版本:ebx, esi和朋友是英特尔32位寄存器。

你必须使用arm-none-eabi-gdb,而不是Ubuntu自带的gdb。

避免混淆的一个简单方法是在脚本和生成文件中显式地使用arm-none-eabi-gcc、arm-none-eabi-as、arm-none-eabi-ld等。

J-Links附带了一个GDB -server软件,它充当GDB和JTAG硬件之间的中介。一旦GDB -server开始运行,您就可以启动调试会话,假设您正在使用与目标处理器匹配的GDB调试器版本。

这显然不是您的情况,因为您的反汇编代码看起来很像x86汇编语言代码。这使我认为您正在使用为x86目标编译的GDB可执行文件。因此,您确实需要编译一个用于ARM目标的GDB版本。

您将在Linaro工具链的bin目录中找到适合您需要的版本,适用于Windows或Linux。它的名称将是arm-none-eabi-gdb.exe (Windows)或arm-none-eabi-gdb (Linux)。

相关内容

  • 没有找到相关文章

最新更新