Jlink工具下的RTT调试应用

单片机开发过程中,除了debug调试之外,很多人都是通过打印信息进行调试,一般都会分配出来一个调试的串口,如果你的单片机使用jlink烧录器,那么可以使用调试工具-RTT来代替串口进行信息的交互。

RTT( Real Time Terminal)是SEGGER公司新出的可以在嵌入式应用中与用户进行交互的实时终端。J-Link驱动4.90之后的版本都支持RTT。

RTT既可以从MCU上输出信息、也可以向应用程序发送信息,由于其高速的特性,所以不影响MCU的实时性。

实现原理就是J-link与MCU共享内存

本以应用为主。RTT的工作框图如图 1所示。MCU通过J-link与电脑连接并将打印信息输出到电脑上,电脑同时可以通过键盘等向MCU发送数据。

图1 RTT工作框图

如果你想使用它,操作也非常简单,首先从官网下载RTT代码,然后把如图 2所示的4个文件添加到你的工程中。并且在主函数文件的起始处添加SEGGER_RTT.h文件。如下所示。

#include "SEGGER_RTT.h"

图 2  需要添加到工程的文件

然后我们就可以直接在主函数中调用SEGGER_RTT_printf函数来打印调试信息了,该函数用法和printf函数类似,只是多了一个参数用来指定RTT通道。其中通道0,就是我们在调试时使用的通道。在主函数中添加如下代码。

SEGGER_RTT_printf(0,"Times %d\r\n",++u32Counter);

u32Counter 这个变量每次打印完之后都会递增。我们把程序编译,然后进入调试模式,在开始菜单下打开J-link RTT 
Client,可以看到如图 3所示的信息。

图3

如果已经正常连接,就会打印出入红色框内的信息,标明RTT版本号和J-link固件版本号等,如果没有这些信息则表示连接异常。点击全速运行之后,打印出的信息如图 3所示。

图 3 RTT打印信息

是不是感觉很酷?只需要简单的添加几个文件,就可以直接调用SEGGER_RTT_printf函数打印输出了。没有复杂的工程配置,没有MCU内核的限制,并且打印字符还非常的流畅,好像回到了用VC6.0编写Win32控制台程序的时代一样。




注意:

  1. Segger官网关于RTT功能的说明以及库文件的下载可以从这里找到(https://www.segger.com/jlink-rtt.html);
  2. 最简单易用的两个函数是 
    • SEGGER_RTT_ConfigUpBuffer(0,NULL,NULL,0,SEGGER_RTT_MODE_BLOCK_IF_FIFO_FULL):非必要的初始化(不知有什么用?)。它是官方例程RTT_Implementation_141217-Examples-Main_RTT_PrintfTest.c的第一句
    • SEGGER_RTT_WriteString(0,"字符串"):直接输出字符串
    • SEGGER_RTT_printf(0,"字符串",输出格式):相当于printf,可以输出各种数据类型
  3. 查看RTT输出的工具有三个: 
    • RTTViewer:不支持中文。至少要进入一次Debugger才能正常显示输出。建议进入Debugger之后再打开,否则经常不能正常显示输出
    • RTTLogger:支持中文,并且可以保存为log文件。使用具体的正确使用方法不清楚。根据手册说明,log只接收RTT通道1的输出,即SEGGER_RTT_printf(1,"字符串",输出格式)。但是实测,只能输出RTT通道0的信息,并且要求代码中要有使用到通道1的语句。否则收不到数据。
    • RTTClient:必须配合RTTLogger或者keil的Debugger来使用,而RTTLogger也必须配合Debugger使用。Client、Logger和Debugger三个窗口都打开的时候,Client和Logger只有其中一个能正常显示,另外一个会严重丢失数据。
  4. 无论哪个查看RTT的工具,都会丢失数据。可能与输出函数的使用频率过高有关(?)。加大SEGGER_RTT_Conf.h中的#define BUFFER_SIZE_UP的值可以有效降低丢失率。
  5. 从开始菜单栏找到J-Link User Manual (UM08001)文档,里面有JLink各个工具的说明。

    RTTLogger使用



原文出处:http://maker.zlgmcu.com/portal.php?mod=view&aid=1880

你可能感兴趣的:(Jlink工具下的RTT调试应用)