0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

讲述Nordic nRF5 SDK的主要调试手段,以帮助大家快速定位问题

Nordic半导体 来源:lp 2019-04-15 15:38 次阅读

本文将讲述NordicnRF5SDK的主要调试手段,以帮助大家快速定位问题,并解决问题。一般来说,你可以通过打log方式,IDE的debug模式,SDK自带的app_error_check函数,以及命令行方式等多种手段来调试你的代码。

1. 通过打log方式进行调试

nRF5SDK支持UART和SWDJ-Link(RTT)两种底层通信方式来打印日志,SDK14之后日志也可以通过蓝牙或者Flash进行输出和存储打印,一般来说,UART和SWD用得比较多,其中UART使用串口助手来查看日志,SWD使用J-LinkRTTViewer(仅适用Windows)或者J-LinkRTTClient(Windows/Mac/Linux系统)来查看打印日志。由于UART日志打印方式会占用一个UART口,而大部分nRF5芯片都只有一个UART口,从而导致资源冲突,为此推荐大家使用RTT方式来打印日志,从而可以将UART口留给正常应用,更重要的是RTT打印方式功耗非常低(几乎可以忽略不计),大家可以在正式release的产品中也使能它,从而发现产品部署后有可能会出现的问题(UART打印方式功耗非常高,在正式release产品中必须关掉它)。

如果使用SWD接口进行日志打印,那么你可以使用J-LinkRTTViewer或者RTTClient来显示日志,二者选其一即可。在Windows平台推荐使用RTTviewer,否则使用RTTClient。

1.1 J-Link RTT Viewer

RTTviewer配置方式如下所示:

RTTviewer日志打印窗口如下所示:(使用的是SDK15.3中的ble_app_hrs例子,下同)

1.2 J-Link RTTClient

RTTclient配置方式如下所示(直接使用jlink命令进行配置):

RTTclient打印窗口如下所示:

1.3 UART串口助手

串口助手配置方式如下所示:

Baudrate:115200

8 data bits

1 stop bit

No parity

HWflowcontrol:None

随便选择一款你熟悉的串口助手,比如Putty或者Termite,Termite打印窗口如下所示:

Putty打印窗口如下所示:

1.4 日志打印模块nRF_Log

nRF5SDK日志打印功能是通过nRF_Log模块实现的(上面展示的日志都是通过nRF_Log打印出来的),SDK包含的大部分例子都自带打印功能,也就是说包含了nRF_Log模块。一般来说,例子都是默认使用UART进行打印的,如果需要改为RTT进行打印,需要对nRF_Log模块进行配置。在具体讲述nRF_Log模块的配置选项之前,先大概讲述一下nRF_Log的工作原理

nRF_Log工作原理

nRF_Log模块包含前端和后端两部分代码。前端是面向用户的打印接口,比如NRF_LOG_INFO,它把用户要打印的数据放在一块RAM中。后端用来具体实现打印功能,即把前端RAM中的数据通过不同的后端接口打印出去。目前nRF_Log支持的后端接口有:UART,RTT,Flash和蓝牙。不管采用哪一种后端接口,对用户来说,其调用的前端API是一样的,nRF_Log模块会根据用户的配置自动适配相应后端接口,而且用户可以同时使能多个后端接口,即把日志同时打印到多个后端端口上。nRF_Log模块可以单独使能或禁止某一个模块的打印功能,比如advertising模块,当你调试advertising模块的时候,可以把log打开,调试完毕,把log关闭以让log界面变得更清爽。nRF_Log模块还可以设置打印的级别(Level),如果不分级别的话,打印界面会包含很多打印信息,让我们每次调试都要花费很多时间去寻找自己想要的日志上。设定级别后,我们可以有选择的打印需要的日志信息,没问题时,我们只打印info级别的日志;有问题时,我们就可以把所有debug级别的日志都打印出来。nRF_Log还有一个功能:Deferred,如果不使能Deferred,那么调用NRF_LOG_INFO等API的时候,立马就Flush,即把日志打印出去;如果使能了Deferred,那么调用NRF_LOG_INFO等API的时候,只是把打印数据放在RAM中,真正的打印由main函数中的NRF_LOG_PROCESS完成,这样可以最大程度降低打印对应用本身的影响,尤其在执行一些时序很关键的操作的时候。nRF_Log还支持时间戳打印,即在每条日志之前加上时间戳信息。

nRF_Log配置

从SDK12以后,nRF_Log模块的配置主要放在sdk_config.h文件中,以工程nRF5_SDK_15.3.0_59ac345examplesle_peripheralle_app_hrspca10040s132arm5_no_packs为例,nRF_Log的配置选项如下所示:

注意:nRF5SDKv11.0.0及以前版本是没有sdk_config.h文件的,此时你需要到optionsfortarget->C/C++->define里面定义一个宏(Keil工程),如果定义“NRF_LOG_USES_UART=1”选择UART日志打印;如果定义”NRF_LOG_USES_RTT=1”则选择RTT日志打印,如下:

还是以nRF5_SDK_15.3.0_59ac345examplesle_peripheralle_app_hrspca10040s132arm5_no_packs为例,当nRF_Log配置为info级别,无timestamp,打印信息如下(与前面配置一样)

当nRF_Log配置为debug级别,打开timestamp,打印信息如下所示:

2. 使用IDE调试界面进行调试

Nordic产品支持单步,断点,寄存器查看,内存查看,callstack查看等所有常规调试手段。需要注意的是,由于softdevice在底层要维持一定的时钟以及处理很多中断事件,一旦蓝牙跑起来后,只能用一个断点进行全速跑,也就是说,执行完一个断点后,程序内部逻辑和时序已经紊乱,此时不能再继续全速跑第二个断点。如果要看第二个断点的内容,只能删掉第一个断点,重新开始执行。

Keil IDE

通过以下方式打开nRF5SoC内部寄存器查看窗口:

用得比较多的几个Keil窗口:

Segger embedded studio IDE

SES的调试界面如下所示(跟Keil很像):

这里要特别强调一下,所有SES工程都包含2个版本:Release版和Debug版,Release是没有包含debug信息以节省代码空间,所以如果你要debug一个工程,请先选择debug版本,然后再进行debug,如下所示:

3. nRF5 SDK自带的APP_ERROR_CHECK函数

APP_ERROR_CHECK是nRF5SDK定义的一个用来检查API返回值是否正确的函数,在nRF5SDK中,NRF_SUCCESS(0)为正确返回值,其它返回值皆为错误值。nRF5SDK所有协议栈API调用,以及SDK库函数调用,都会用APP_ERROR_CHECK去检查调用的返回值。当出现非法调用时,比如传入的实参不对,API返回值就不会为NRF_SUCCESS,此时APP_ERROR_CHECK就会派上大用场。通过查看APP_ERROR_CHECK函数定义,如下所示:

你会发现APP_ERROR_CHECK行为受宏DEBUG和有没有挂仿真器两个因素的影响,当没有定义DEBUG宏时,系统将直接产生软复位;当定义了DEBUG宏并且没有挂仿真器时,系统将把错误信息保存在callstack中。不管怎么配置,APP_ERROR_CHECK都会把相应的错误信息打印出来,以方便你去排查问题,如下所示。通过打印出来的错误信息,你就可以知道是哪个文件哪一行代码出了什么类型的错误。

注意在SDK14以前,app_error_check不会主动把错误信息打印出来,而是把错误信息存在RAM中,然后通过debug模式可以直接查看相关错误信息,如下所示:

默认情况下,nRF5SDK是没有定义DEBUG宏的,所以一旦函数返回值不对,系统就会复位。这里要特别指出的是,在你开发调试过程中,经常会碰到复位的情况,这其中大部分都是由APP_ERROR_CHECK引起的。针对这种情况的复位,你只需要在optionsfortarget->C/C++->define里面定义一个宏:DEBUG,就可以快速找出是哪一个文件哪一行代码引出的复位,以及复位原因是什么,如下所示:

4.使用命令行(CLI)方式进行调试

打log方式只能单方面输出,而不能接受终端的输入,在很多情况下,我们需要动态调整log信息,比如动态更改log的级别,动态更改log的颜色等等,这个时候就需要用到nrf_cli模块,跟nRF_Log相似,nrf_cli同时支持5种后端接口:UART,RTT,BLE,Flash和USBCDC。由于nrf_cli也有log输出功能,因此nRF_Log模块可以直接选择nrf_cli为其后端接口。这里再次强调一下,nrf_log和nrf_cli是两个完全独立的模块,但是nrf_log可以选用nrf_cli为其后端接口,由nrf_cli完成后端打印功能。SDK中提供了三个cli的例子,分别为:

examplesperipheralclipca10040lankarm5_no_packs

examplesle_peripheralexperimentalle_app_clipca10040s132arm5_no_packs

examplesle_central_and_peripheralexperimentalle_app_interactivepca10040s132arm5_no_packs

如果大家的应用需要命令行交互方式,可以参考上面3个例子,以examplesperipheralclipca10040lankarm5_no_packs为例,交互成功后的界面如下所示:

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 串口
    +关注

    关注

    14

    文章

    1483

    浏览量

    74481
  • uart
    +关注

    关注

    22

    文章

    1155

    浏览量

    99868
  • 函数
    +关注

    关注

    3

    文章

    3859

    浏览量

    61297

原文标题:[Nordic 博文分享系列] 如何调试nRF5 SDK

文章出处:【微信号:nordicsemi,微信公众号:Nordic半导体】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    蓝牙Mesh技术正式发布,Nordic第一个推出mesh SDK

    )官方认可蓝牙mesh1.0(Bluetooth mesh 1.0)规范的当天,超低功耗RF专业厂商Nordic Semiconductor宣布推出用于mesh的nRF5软件开发套件(SDK),可让
    发表于 07-21 12:29

    NordicnRF52840多协议SoC实现Thread和蓝牙5的同时连接

    nRF52840 SoC及用于Thread 的Nordic nRF5 SDK为基础的Thread产品均可无缝地与蓝牙5设备互操作
    发表于 09-12 17:11

    NordicnRF52840多协议SoC实现Thread和蓝牙5的同时连接分享

    nRF52840 SoC及用于Thread 的Nordic nRF5 SDK为基础的Thread产品均可无缝地与蓝牙5设备互操作
    发表于 12-30 11:30

    nRF5芯片外设GPIO和GPIOTE介绍

    ,别的IO产生的port event就会被忽略。为此,在处理port event中断的时候,nRF5 SDK app_button模块将每个port event的极性设为toggle,也就是每进入一次
    发表于 02-22 16:38

    nRF5 SDK软件架构和softdevice工作原理

    本文将介绍Nordic nRF5 SDK软件架构以及softdevice工作原理,加深大家Nordi
    发表于 03-07 11:40

    NORDIC NRF52811-QCAA蓝牙5.1支持位置查找,精准定位 QFN32

    5.1测向系统一部分使用的成本受限的蓝牙信标应用,这款SoC器件也是很好的选择。与nRF52811 SoC配套的SDKNordic nRF5软件开发套件(
    发表于 03-07 17:28

    低功耗蓝牙芯片Nrf52840劲爆性能详解

    高端nRF52840 SoC结合Nordic最新的nRF5 SDK和S140 协议栈(RF协议栈),使开发人员充分可以利用蓝牙5的性能优势。
    发表于 04-12 16:10

    蓝牙5.1 NRF52833和NRF52840的区别

    、程序库和驱动程序。Nordic计划于2019年第四季发布分别用于Mesh和用于Thread及ZigBee应用的nRF5 SDKNordic现在提供
    发表于 01-22 15:25

    nrf52840 蓝牙5.0 动能世纪优势供应

    高端nrf52840 SoC结合Nordic最新的nRF5 SDK和S140 协议栈(RF协议栈),使开发人员充分可以利用蓝牙5的性能优势。
    发表于 12-30 15:26

    DALI电源的常规调试和测试手段

    DALI电源的常规调试和测试手段重点在于参数配置和状态查看,但这是建立在DALI系统内所有设备工作正常的前提之下。如果测试的环境中存在故障或者部分设备为待验证功能的新产品,那么采用这种方...
    发表于 01-03 06:34

    Nordic Semiconductor最新nRF5 SDK推出安全的签名空中固件升级功能

    Nordic Semiconductor宣布其最新发布的nRF5 SDK v12.0支持安全的签名空中设备固件升级(OTA-DFU),可增强应用升级的安全性,通过使用安全的签名,在给定设备上确保使用经过验证的可信任来源进行应用更
    发表于 09-05 10:19 1404次阅读

    Nordic开创蓝牙mesh新解决方案

    蓝牙技术联盟(SIG)官方认可Nordic协议栈,同时全新软件开发套件可让开发人员使用NordicnRF5
    的头像 发表于 09-20 17:13 8375次阅读

    如何开发你的第一个NCS(Zephyr)应用程序

      Nordic有2套并存的SDK 1、老的nRF5 SDK 2、新的NCS SDK 两套SDK
    的头像 发表于 12-29 09:47 5900次阅读
    如何开发你的第一个NCS(Zephyr)应用程序

    Nordic Semiconductor宣布推出nRF定位服务

    服务”,这项云产品使得客户能够为自身的基于nRF9160系统级封装(SiP)的蜂窝物联网设备获取更丰富、快速和准确的商业定位服务。 nRF定位
    的头像 发表于 08-16 15:22 2103次阅读

    Nordic nRF5 SDK 学习笔记之七, 功耗评估及电源优化

    NORDIC 官方评估功耗在线测试NORDIC Online Power Profiler,https://devzone.nordicsemi.com/power/NORDIC 关于低功耗的官方
    发表于 01-06 16:14 3次下载
    <b class='flag-5'>Nordic</b> <b class='flag-5'>nRF5</b> <b class='flag-5'>SDK</b> 学习笔记之七,  功耗评估及电源优化