连接是不稳定的使用JTAG与我的自定义板。

⚠️
大家好. .谢谢你来到论坛。令人兴奋的消息!我们现在正在转移到新的论坛平台,它将提供更好的功能,包含在主对话网站中。所有岗位和账户都已迁移。我们现在只接受新论坛的流量-请在上面发布任何新帖子//www.wsdof.com/support.我们将在未来几天修复bug /优化搜索和标记。
12个职位/ 0个新职位
最后发表
daniel59
离线
最后看到:一年6个月前
加入:2016-01-08 04:34
连接是不稳定的使用JTAG与我的自定义板。

你好,

我的连接是不稳定的使用JTAG与我的自定义板。

首先,我可以检测我的板,但当我进入工具箱,并下载引导固件,它出错。

日志显示如下:

[INFO General @19-01-11 16:33:26]找到ID为0x0BB11477的SWD-DP
[INFO General @19-01-11 16:33:26]找到了Cortex-M0 r0p0, Little endian。
[INFO General @19-01-11 16:33:26] FPUnit: 4 code (BP)插槽和0字面值插槽
[INFO General @19-01-11 16:33:26] CoreSight组件:
[INFO General @19-01-11 16:33:26] ROMTbl 0 @ E00FF000
[INFO General @19-01-11 16:33:26] ROMTbl 0 [0]: FFF0F000, CID: B105E00D, PID: 000BB008 SCS
[INFO General @19-01-11 16:33:26] ROMTbl 0 [1]: FFF02000, CID: B105E00D, PID: 000BB00A DWT
[INFO General @19-01-11 16:33:26] ROMTbl 0 [2]: FFF03000, CID: B105E00D, PID: 000BB00B fbb
[INFO General @19-01-11 16:33:26] BTLE设备已选择。
[INFO General @19-01-11 16:33:34]找到ID为0x0BB11477的SWD-DP
[ERROR General @19-01-11 16:33:34]在读取DP-Ctrl-Stat寄存器时发生DAP错误。
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMemHW读取内存地址0x50003200
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMemHW读取内存地址0x50003201
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMemHW读取内存地址0x50003202
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMemHW读取内存地址0x50003200
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMemHW读取内存地址0x50003204
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMemHW读取内存地址0x50003208
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMemHW读取内存地址0x5000320c
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMem读取内存地址0x50040200
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法使用JLINKARM_ReadMem函数读取内存地址0x50040204
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMem读取内存地址0x50040208
[INFO General @19-01-11 16:33:35]无法测量总红外len。TDO恒定高。
[ERROR General @19-01-11 16:33:35]无法用函数JLINKARM_ReadMem读取内存地址0x5004020c
[ERROR General @19-01-11 16:33:35]打开JLink连接时没有发现已知芯片。终止过程中…
[ERROR Booter @19-01-11 16:33:35]下载固件到单板失败。

是什么问题?我的有线电视还是冲浪板?

设备:
PM_Dialog
离线
最后看到:2天13小时前
工作人员
加入:2018-02-08 11:03
嗨daniel59,

嗨daniel59,

这是来自Jlink软件的指示,而不是来自Smart Snippets(当通过JTAG连接时,Smart Snippets使用Jlink来访问设备)。你提到你有一个自定义电路板,那么你在自定义PCB上有JTAG吗?或者你在使用Pro或Basic DK来为你的电路板编程?我强烈建议您检查是否已正确配置SPI Flash引脚在SmartSnippets工具箱的板设置选项卡。可能在自定义PCB上的处理器和尝试与设备通信的Jlink fw之间没有连接。这可能是任何事情,从连接到PCB问题,使580无法操作。我的建议是检查引导加载程序是否正在执行,以验证580是否正确运行。您可以探测P04和P05引脚,这两个引脚应该被切换为引导加载程序的执行部分,因此当连接到终端时,您应该看到设备打印垃圾。此外,我建议您使用Jlink本身连接板,而不是使用智能片段,我也会尝试通过Keil下载代码。

谢谢,PM_Dialog

daniel59
离线
最后看到:一年6个月前
加入:2016-01-08 04:34
嗨PM_Dialog,

嗨PM_Dialog,

我想我正在使用一个自定义JTAG设备,连接到我的自定义板。

我可以使用Keil进入调试会话,但当我运行代码,使用ble_app_barebone项目,它去代码:
if (GetWord16(SYS_STAT_REG) & DBG_IS_UP) == DBG_IS_UP)
__asm(“BKPT # 0 \ n”);

我测试了我的5块板子,只有1块板子能通过代码。

我的冲浪板质量不好吗?

PM_Dialog
离线
最后看到:2天13小时前
工作人员
加入:2018-02-08 11:03
嗨daniel59,

嗨daniel59,

你能解释一下定制JTAG设备是什么意思吗?你使用的是哪个版本的J-Link ?这意味着你会得到一个NMI。你能试着调试你的代码并试着找出NMI的原因吗?您的应用程序代码会卡在哪里?如果你不知道如何才能找到NMI的原因,我建议你去看看第8课:调试methods_v1.1从我们的支持门户。另外,很有可能是错误是由于你们的PCB质量不好造成的。

谢谢,PM_Dialog

daniel59
离线
最后看到:一年6个月前
加入:2016-01-08 04:34
谢谢,PM_Dialog

嗨,PM_Dialog

呃…我指的是定制的J-link设备。这就像J-Link EDU Mini,但只有swdio, swclk, vcc和gnd。

我使用的是jlink v5.12f, SmartSnippets studio v2.0.6推荐用于da14580。

我看教程8,但我不能找到错误是使用两种方法。

我在考虑我的电源。常用的J-link是直接连接swdio到引脚25,swclk到引脚26,vcc到引脚15,gnd到引脚16,使用QFN40 DA14580。

但是对于我,因为我想充电电池和JTAG,我连接swdio销25日swclk销26,接地针16但vcc电池管理芯片ltc4054锂电池充电,然后将电池连接到3.3 v LDO, LDO 3.3 v输出连接到15针。

这会让事情变糟吗?

我尝试了很多次,有时工具箱可以找到芯片,但显示CPU不能停止,有时工具箱找不到芯片,有时直接显示写文件D:\Desktop\empty_peripheral_template_580失败。地址20000000的十六进制。

PM_Dialog
离线
最后看到:2天13小时前
工作人员
加入:2018-02-08 11:03
嗨daniel59,

嗨daniel59,

请注意,我们使用H-Link Lite在我们的开发板,我不完全确定,如果我们曾经使用J-Link EDU Mini。你能试着用Keil下载固件到SysRAM中以确保你的自定义板工作正常吗?只有一个董事会有这个问题,还是所有董事会都有?

谢谢,PM_Dialog

daniel59
离线
最后看到:一年6个月前
加入:2016-01-08 04:34
嗨,PM_Dialog

嗨,PM_Dialog

下载固件到SysRAM使用Keil意味着使用Keil进入调试会话?

只有我的一些黑板有这个问题…

有时日志显示无法启动CPU核心。(错误代码:1)。

和一些电路板后,我尝试和尝试,它可以连接SPI Flash程序员,但然后下次失败。如附件日志所示。

我用J-link连接我的板的电缆长度会影响连接吗?

丹尼尔

附件:
PM_Dialog
离线
最后看到:2天13小时前
工作人员
加入:2018-02-08 11:03
嗨daniel59,

嗨daniel59,

请检查您是否正确配置了smartnippet的“Booter & Board Setup”标签中的SPI Flash引脚?“SPI Flash引脚配置”应根据您的板连接。您提到您能够连接到SPI Flash,所以当过程失败时,试图读取或写入Flash ?电缆的长度可能是个问题,所以尽量使用较短的电缆。关于syram,是的,我想用Keil下载你的固件。这是一个有点奇怪的行为,所以这可能是你的PCB上的硬件问题。你也提到只有一些董事会有这个问题,所以我想问你一个问题。除了那些板,你能告诉我你是否有完全功能的板(连接,读,写SPI Flash,引导,并开始广告?)

谢谢,PM_Dialog

daniel59
离线
最后看到:一年6个月前
加入:2016-01-08 04:34
嗨,PM_Dialog

嗨,PM_Dialog

使用keil,当我运行代码,使用ble_app_barebone项目,它去代码:
if (GetWord16(SYS_STAT_REG) & DBG_IS_UP) == DBG_IS_UP)
__asm(“BKPT # 0 \ n”);

SPI flash错误我的意思是,例如,这次我按连接它显示成功,下次我按连接它显示失败。

是的,我有一个完全功能的板,它可以正确地连接。所以我认为J-link装置工作得很好。

丹尼尔

PM_Dialog
离线
最后看到:2天13小时前
工作人员
加入:2018-02-08 11:03
嗨daniel59,

嗨daniel59,

这意味着您的应用程序代码会卡在NMI_HandlerC或HardFault_HandlerC上。你能解释一下如果在哪里卡住了吗?我已经向你推荐了一篇教程,教你如何找到NMI / HARDFAULT的原因。因为你有功能板,你运行一些代码,我认为你的一些板有硬件问题。

谢谢,PM_Dialog

daniel59
离线
最后看到:一年6个月前
加入:2016-01-08 04:34
嗨PM_Dialog,

嗨PM_Dialog,

是的,我尝试了教程8,和2种方法都不工作。

Show callee just跳转到__asm("BKPT #0\n");

MSP方法显示地址0xFFFF0000;是MOVS r0 r0

也许是因为我定制的j-link设备?

有什么方法可以检测出是坏芯片还是坏板吗?

PM_Dialog
离线
最后看到:2天13小时前
工作人员
加入:2018-02-08 11:03
嗨daniel59,

嗨daniel59,

您是否检查了引导加载程序是否正在执行,以验证580是否正确运行?您可以探测P04和P05引脚,这两个引脚应该被切换为引导加载程序的执行部分,因此当连接到终端时,您应该看到设备打印垃圾。

谢谢,PM_Dialog