英文全称Real Time Transfer,可以不用串口直接用上位机和芯片进行通讯,作用跟串口一样,优点就是不占用串口资源。
上行和下行的Buffer是单独分开处理的,有各自的通道。
RTT实现代码大约需要500字节的ROM空间,RAM的占用跟Buffer个数相关,24字节的ID + 24字节的单个通道控制块。每个通道都需要一些缓冲区的内存。根据输入/输出负载的不同,上行通道推荐的大小为1k字节,下行通道推荐的大小为16到32字节。
官网上面下载个JLINK安装包,里面会带三个工具J-Link RTT Viewer/J-Link RTT Client/J-Link RTT Logger,装完就会有。
如果纯查看的话推荐用J-Link RTT Viewer,界面比较友好,打开之后就长下面这样,选个接口和芯片就行,这是三个工具里面最好的。
要下发字符串的话推荐用J-Link RTT Client,缺点就是看不了颜色,有时候打印不出来,要重新打开窗口才行。
用法差不多,但功能上是三个工具里面最拉胯的,不建议用。
要把底层源码弄到工程里面去,安装完JLINK之后会有这个压缩包
解压之后把解压包的这五个文件弄到现有的工程里面。
我测试过有个很特别的点,无论从哪个终端输入,芯片都能接收到,推测下行buffer只有一个,如果有哪位同学有不同的结果可以帮忙纠正一下。
uint8_t UpBufferCH1[64] = {0};
uint8_t DownBufferCH1[64] = {0};
void SEGGER_RTT_Test(void)
{
SEGGER_RTT_ConfigUpBuffer(1,"RTTUP", UpBufferCH1,64,SEGGER_RTT_MODE_NO_BLOCK_SKIP);
//配置通道1上行buffer
SEGGER_RTT_ConfigDownBuffer(1,"RTTDOWN",DownBufferCH1, 64,SEGGER_RTT_MODE_NO_BLOCK_SKIP);
//配置通道1下行buffer
while(1){
uint8_t pBuffer[10] = {0};
SEGGER_RTT_SetTerminal(0);//选择通道0
SEGGER_RTT_printf(0, RTT_CTRL_TEXT_RED"terminal 0 output\r\n");
//0是打印到电脑,1是打印到电路板
//RTT_CTRL_TEXT_RED是红色字体
if(SEGGER_RTT_Read(0,pBuffer,10)){//从buffer的0位置读出10个字节到pBuffer
if(pBuffer){
SEGGER_RTT_SetTerminal(1);//选择通道1
SEGGER_RTT_printf(0, RTT_CTRL_TEXT_GREEN"terminal 1 get is %s\r\n",pBuffer);//将读取到的信息ASCII输出到终端1
}
}
vTaskDelay(100);
}
}
芯片将信息打印到通道0
芯片将收到的信息打印到通道1
接口 | 作用 |
SEGGER_RTT_Read() | 从下行的buffer里面读取内容 |
SEGGER_RTT_Write() | 将内容写到上行的buffer里面 |
SEGGER_RTT_WriteString() | 将字符串写到上行的buffer里面 |
SEGGER_RTT_printf() | 将打印信息到上位机,里面调用了SEGGER_RTT_Write() |
SEGGER_RTT_GetKey() | 这三个接口跟秘钥没啥关系,单纯看看下行的buffer第0个字节能不能读出来,读不出来就是下行的buffer锁住了。 |
SEGGER_RTT_Haskey() | |
SEGGER_RTT_WaitKey() | |
SEGGER_RTT_ConfigUpBuffer() | 配置上行的buffer,主要配置个名字、buffer长度,阻塞模式还是非阻塞模式。 |
SEGGER_RTT_ConfigDownBuffer() | 配置下行的buffer |
SEGGER_RTT_Init() | 初始化RTT,使用之前调用一次就行 |
SEGGER_RTT_SetTerminal() | 设置要把信息打印到哪个终端 |
SEGGER_RTT_Terminalout() | 发送字符串给虚拟终端 |
?