当前位置:网站首页>Use of j-link RTT
Use of j-link RTT
2022-04-23 01:46:00 【Traceless rain】
Catalog -- Click to get to
Write it at the front
This paper introduces J-Link RTT Part of the use of , Many places refer to and use J-Link Official information of , Some places may not be translated accurately , Please forgive me .
If you want to know more accurate and detailed content , Please order here .
What is? RTT?
RTT(Real Time Transfer) It is a technology used to interact with users in embedded system , It is a combination of SWO And the advantages of half host , High performance .
Use RTT It can be downloaded from MCU Very fast output of debugging information and data , And it doesn't affect MCU The real time . This function can be used for many support J-Link Equipment and MCU, Strong compatibility .
RTT Support multiple channels in two directions , Go to the host , Down to target , It can be used for different purposes , Provide users with as much freedom as possible . The default implementation uses one channel in each direction , For printable terminal input and output .
Use J-Link RTT Viewer, Can be used for “ fictitious ” terminal , Allow printing to multiple windows ( for example , One for standard output , One for error output , One for debugging output ).
RTT How it works
RTT stay MCU Used in memory SEGGER RTT The control block structure manages data reading and writing . The control block contains a... In memory for each available channel ID, adopt J-Link Or ring buffer structure ( Linked list ) Both can pass ID Find the corresponding control block .
The maximum number of available channels can be configured at compile time , And each buffer can be in MCU Configure and use runtime . The upper and lower buffers can be processed separately . Each channel can be configured as blocking or non blocking .
In blocking mode , Waiting for the application buffer to fill , Until all memory can be written , This will cause the application to be blocked , But it can prevent data loss .
In non-blocking mode , Only data suitable for buffer will be written , Or not writing to the buffer at all , The rest of the data will be discarded . This way, even if the debugger is not connected , It can also run in real time . Developers don't have to create special debug versions , And the code can remain in the publishing application .
RTT Performance of
RTT The performance of is significantly higher than any other method used to output data to the host PC The way . The average line of text can be in 1 Output in microseconds or less . It's basically equivalent to making a memcopy() Time for .
RTT The implementation code uses about 500 Bytes of ROM and (n( The channel number ) * (24 byte ID+24 byte )) Of RAM. The recommended size is 1 kByte( Up channel ) and 16 To 32 byte ( Down channel ), It depends on the input / Output load .
Quick use tutorial
1. First installation J-Link Of Software drivers .
2. After installation , open J-Link Installation directory ( Start ->SEGGR->J-Link RTT Viewer-> Right click to open the file -> Then continue to right-click to open the location of the file -> This is the installation directory ),
Find the following path SEGGER\JLink_V632f\Samples\RTT
, Decompress the package SEGGER_RTT_V632f.zip
( Different versions ,V The following numbers may be different ).
3. Copy the extracted file to the code project directory .
4. Add... To the project SEGGER_RTT_V632f\RTT
All four files in the directory . Please add files to the project by yourself .
5. After the project is added to the document , When you want to use RTT The file contains #include "SEGGER_RTT.h"
, Then call directly SEGGER_RTT_printf()
Just fine ,
for example SEGGER_RTT_printf(0,"hello world!")
This and C Linguistic printf The format is similar , Just add a port in front 0
Parameters of .( See... For details Advanced use tutorial )
6. Then click Start ->SEGGR->J-Link RTT Viewer, open J-Link RTT Viewer After choosing your chip model , Click on the confirmation .
7. Then you can see what we printed .
Advanced use tutorial
1. Introduction to some functions :
(1)void SEGGER_RTT_Init (void)
RTT Initialization function , It should be placed at the beginning of the program .
(2)int SEGGER_RTT_GetKey (void);
from RTT The terminal obtains a key character .
Return Value
Value | Meaning |
---|---|
>=0 | Returns the key character (0-255) |
< 0 | There are no valid characters in the cache |
Sample code :
int c; c = SEGGER_RTT_GetKey(); if (c == 'q') { exit(); }
(3)int SEGGER_RTT_HasKey (void);
Detect whether there are still characters in the cache .
Return Value
Value | Meaning |
---|---|
1 | At least one character in the cache is valid |
0 | There are no valid characters in the cache |
Sample code :
if (SEGGER_RTT_HasKey()) { int c = SEGGER_RTT_GetKey(); }
(4)int SEGGER_RTT_printf (unsigned BufferIndex, const char * sFormat, …)
Format output string
Return Value
Value | Meaning |
---|---|
>=0 | Number of characters sent |
< 0 | An error occurred |
Additional information :
The transformation specification has the following syntax :
%[ sign ][ Field width ][. precision ] Convert the specified program
Signs of support :
-: Align left within field width
+: Always print symbolic extensions with symbolic transformations
0: use 0 Instead of spaces . Use “-” Ignore when marking or precision
Supported conversion specifiers :
c: Print the parameter as one character
d: Print parameters as signed integers
u: Print parameters as unsigned integers
x: Print parameters as hexadecimal integers
s: Print the string pointed to by the parameter
p: Print parameters as 8 Hexadecimal integer .
ps. It seems that the official did not give float Type format output mode .
Sample code :
SEGGER_RTT_printf(0, "SEGGER RTT Sample. Uptime: %.10dms.", /*OS_Time*/ 890912);
meanwhile , have access to SEGGER_RTT_printf()
To set the font color and background color :
for example :
SEGGER_RTT_printf(0,RTT_CTRL_BG_WHITE); SEGGER_RTT_printf(0,RTT_CTRL_TEXT_BLUE);
(5)void SEGGER_RTT_SetTerminal(char TerminalId);
Set the virtual terminal ID.
Return Value
Parameter | Meaning |
---|---|
TerminalId | Virtual terminal ID |
Sample code :
// // Send a string to terminal 1 which is used as error out. // SEGGER_RTT_SetTerminal(1); // Select terminal 1 SEGGER_RTT_WriteString(0, "ERROR: Buffer overflow"); SEGGER_RTT_SetTerminal(0); // Reset to standard terminal
SEGGER_RTT_WriteString Medium 0 Parameters , It's the channel number , Not the terminal number .
(6)int SEGGER_RTT_WaitKey (void);
Detect whether there are still characters in the cache .
Return Value
Value | Meaning |
---|---|
≥0 | Wait to return a key value |
Sample code :
int c = 0; do { c = SEGGER_RTT_WaitKey(); } while (c != 'c');
Attach test code
/*terminal 0: if you press any key in the keyboard ,terminal 0 will show the key value witch you press. terminal 1: show the date terminal 2: show the time */ if (SEGGER_RTT_HasKey()) { int c = SEGGER_RTT_GetKey(); SEGGER_RTT_SetTerminal(0); SEGGER_RTT_Write (0, &c, 1); SEGGER_RTT_printf(0,"\n"); } //GET DATA HAL_RTC_GetTime(&hrtc,&_current_time,RTC_FORMAT_BIN); //GET TIME HAL_RTC_GetDate(&hrtc,&_current_date,RTC_FORMAT_BIN); //Printf SEGGER_RTT_SetTerminal(1); SEGGER_RTT_printf(0,"%d . %d . %d \n",_current_date.Year,_current_date.Month,_current_date.Date); SEGGER_RTT_SetTerminal(2); SEGGER_RTT_printf(0,"%d : %d : %d \n\n",_current_time.Hours,_current_time.Minutes,_current_time.Seconds);
Code download link :RTT_Test.zip- Other code resources -CSDN download ( The project involves Keil and IAR )
2019 year 12 month 27 Daily update -- Add print float The function of
Because of the official RTT View Cannot print out float Data of type , So I wrote a simple float Functions that convert strings .
unsigned char *out_float(double value, unsigned char decimal_digit, unsigned char *output_length) { unsigned char _output[20]; unsigned long integer; unsigned long decimal; unsigned char _output_length = 0; unsigned char _length_buff = 0; static unsigned char *return_pointer; unsigned char signal_flag; if (value < 0) signal_flag = 1; else signal_flag = 0; value = fabs(value); integer = (unsigned long)value; decimal = (unsigned long)((value - integer) * pow(10, decimal_digit)); unsigned long integer_buff = integer; unsigned long decimal_buff = decimal; while (1) { if (integer / 10 != 0) _length_buff++; else { _length_buff++; break; } integer = integer / 10; } for (int i = 0; i < _length_buff; i++) { if (i == _length_buff - 1) _output[_output_length] = integer_buff % 10 + 0x30; else { //_output[_output_length] = integer_buff / 10 % 10 + 0x30; _output[_output_length] = integer_buff / (unsigned long)pow(10, _length_buff - i - 1) % 10 + 0x30; integer_buff = integer_buff % (unsigned long)pow(10, _length_buff - i - 1); //integer_buff = integer_buff % 10; } _output_length++; } _output[_output_length] = '.'; _output_length++; _length_buff = 0; while (1) { if (decimal / 10 != 0) _length_buff++; else { _length_buff++; break; } decimal = decimal / 10; } for (int i = 0; i < _length_buff; i++) { if (i == _length_buff - 1) _output[_output_length] = decimal_buff % 10 + 0x30; else { _output[_output_length] = decimal_buff / (unsigned long)pow(10, _length_buff-i-1) % 10 + 0x30; decimal_buff = decimal_buff % (unsigned long)pow(10, _length_buff - i - 1); } _output_length++; } _output[_output_length] = 0x00; _output_length++; return_pointer = (unsigned char *)realloc(return_pointer,_output_length); *output_length = _output_length - 1; if (return_pointer == 0) return 0; else { if (signal_flag == 1) { return_pointer[0] = '-'; memcpy(return_pointer+1, _output, _output_length); } else memcpy(return_pointer, _output, _output_length); } return return_pointer; }
Parameter
Value | Meaning |
---|---|
value | The data you want to print |
decimal_digit | The number of decimal places in a number |
_output_length | The length of the output string |
Return Value
Value | Meaning |
---|---|
unsigned char* | Returns a string pointer |
Sample code :
float value = 3.1415; unsigned char length; SEGGER_RTT_printf(0,"value = %s \n",out_float(value,4,&length));
One 、 Test environment
1> Test environment
System :WIN7
MDK:keil v5.26
Development board :GD32F303C-EVAL
Firmware library :V1.0.2
FreeRTOS edition :V10.4.0
Support kernel : ARM Cortex-M0/M0+/M1/M3/M4/M7/M23/M33 and Renesas RX100/200/600
For more details, please refer to the official website :RTT
Chinese can refer to : Emulator instead of serial port printing
2> find JLINK Driver installation directory .
After decompression, you can see the file shown in the figure below ,Example The catalogue is for reference demo,RTT and Syscalls Under the folder are the files needed for migration
RTT The contents of the catalog :
Syscalls The contents of the catalog :
Two 、 Add files to the project
1> Create a new folder under the project , Put the files mentioned above in this folder
2> Add files to the project
3> Add the header file path
————————————————
Copyright notice : This paper is about CSDN Blogger 「 Sing a song and you worry alone 」 The original article of , follow CC 4.0 BY-SA Copyright agreement , For reprint, please attach the original source link and this statement .
Link to the original text :https://blog.csdn.net/qq_23852045/article/details/108759582
3、 ... and 、 Test use
1> The test code is as follows :
#include "gd32f30x.h"
#include "led.h"
#include "systick.h"
#include "timer.h"
#include <stdio.h>
#include "key.h"
#include "gpio.h"
#include "usart_shell.h"
#include "shell_port.h"
#include "gd25qxx.h"
#include <math.h>
#include <string.h>
#include "SEGGER_RTT.h"
#if 0
/* USER CODE BEGIN 0 */
int test(int i, char ch, char *str)
{
printf("input int: %d, char: %c, string: %s\r\n", i, ch, str);
return 0;
}
int func(int argc, char *agrv[])
{
printf("%dparameter(s)\r\n", argc);
for (char i = 1; i < argc; i++)
{
printf("%s\r\n", agrv[i]);
}
return 0;
}
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0)|SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN), func, func, test2);
// Export to the command list
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0)|SHELL_CMD_TYPE(SHELL_TYPE_CMD_FUNC), test, test, test);
/* USER CODE END 0 */
#endif
volatile int _Cnt=0;
unsigned char *out_float(double value, unsigned char decimal_digit, unsigned char *output_length);
int main(void)
{
float value = 3.1415;
unsigned char length;
delay_init();
/* Add uplink data buffer , The function prototype :
int SEGGER_RTT_ConfigUpBuffer(unsigned BufferIndex, const char* sName, void* pBuffer, unsigned BufferSize, unsigned Flags)
if BufferIndex=0,RTT The component will use the default buffer and size , Its size is determined by SEGGER_RTT_Conf.h Medium BUFFER_SIZE_UP decision , So use this cache 0 Relatively simple ,
Make BufferIndex=0,pBuffer=NULL,BufferSize=NULL
Direction :MCU-->PC
Empathy :SEGGER_RTT_ConfigDownBuffer, Just like it , Just in different directions ,PC-->MCU
*/
SEGGER_RTT_ConfigUpBuffer(0, NULL, NULL, 0, SEGGER_RTT_MODE_BLOCK_IF_FIFO_FULL);
/* Print string function */
SEGGER_RTT_WriteString(0, "SEGGER Real-Time-Terminal Sample\r\n\r\n");
SEGGER_RTT_WriteString(0, "###### Testing SEGGER_printf() ######\r\n");
SEGGER_RTT_WriteString(0, "###### chinese ######\r\n");
SEGGER_RTT_printf(0,"value = %s \n",out_float(value,4,&length));
/* And C In the library printf similar , The difference is that floating point numbers are not supported */
SEGGER_RTT_printf(0, "printf Test: %%c, 'S' : %c.\r\n", 'S');
SEGGER_RTT_printf(0, "printf Test: %%5c, 'E' : %5c.\r\n", 'E');
SEGGER_RTT_printf(0, "printf Test: %%-5c, 'G' : %-5c.\r\n", 'G');
SEGGER_RTT_printf(0, "printf Test: %%5.3c, 'G' : %-5c.\r\n", 'G');
SEGGER_RTT_printf(0, "printf Test: %%.3c, 'E' : %-5c.\r\n", 'E');
SEGGER_RTT_printf(0, "printf Test: %%c, 'R' : %c.\r\n", 'R');
SEGGER_RTT_printf(0, "printf Test: %%s, \"RTT\" : %s.\r\n", "RTT");
SEGGER_RTT_printf(0, "printf Test: %%s, \"RTT\\r\\nRocks.\" : %s.\r\n", "RTT\r\nRocks.");
SEGGER_RTT_printf(0, "printf Test: %%u, 12345 : %u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%+u, 12345 : %+u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%.3u, 12345 : %.3u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%.6u, 12345 : %.6u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%6.3u, 12345 : %6.3u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%8.6u, 12345 : %8.6u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%08u, 12345 : %08u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%08.6u, 12345 : %08.6u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%0u, 12345 : %0u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%-.6u, 12345 : %-.6u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%-6.3u, 12345 : %-6.3u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%-8.6u, 12345 : %-8.6u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%-08u, 12345 : %-08u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%-08.6u, 12345 : %-08.6u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%-0u, 12345 : %-0u.\r\n", 12345);
SEGGER_RTT_printf(0, "printf Test: %%u, -12345 : %u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%+u, -12345 : %+u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%.3u, -12345 : %.3u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%.6u, -12345 : %.6u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%6.3u, -12345 : %6.3u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%8.6u, -12345 : %8.6u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%08u, -12345 : %08u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%08.6u, -12345 : %08.6u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%0u, -12345 : %0u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-.6u, -12345 : %-.6u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-6.3u, -12345 : %-6.3u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-8.6u, -12345 : %-8.6u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-08u, -12345 : %-08u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-08.6u, -12345 : %-08.6u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-0u, -12345 : %-0u.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%d, -12345 : %d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%+d, -12345 : %+d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%.3d, -12345 : %.3d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%.6d, -12345 : %.6d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%6.3d, -12345 : %6.3d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%8.6d, -12345 : %8.6d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%08d, -12345 : %08d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%08.6d, -12345 : %08.6d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%0d, -12345 : %0d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-.6d, -12345 : %-.6d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-6.3d, -12345 : %-6.3d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-8.6d, -12345 : %-8.6d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-08d, -12345 : %-08d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-08.6d, -12345 : %-08.6d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%-0d, -12345 : %-0d.\r\n", -12345);
SEGGER_RTT_printf(0, "printf Test: %%x, 0x1234ABC : %x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%+x, 0x1234ABC : %+x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%.3x, 0x1234ABC : %.3x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%.6x, 0x1234ABC : %.6x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%6.3x, 0x1234ABC : %6.3x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%8.6x, 0x1234ABC : %8.6x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%08x, 0x1234ABC : %08x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%08.6x, 0x1234ABC : %08.6x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%0x, 0x1234ABC : %0x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%-.6x, 0x1234ABC : %-.6x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%-6.3x, 0x1234ABC : %-6.3x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%-8.6x, 0x1234ABC : %-8.6x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%-08x, 0x1234ABC : %-08x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%-08.6x, 0x1234ABC : %-08.6x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%-0x, 0x1234ABC : %-0x.\r\n", 0x1234ABC);
SEGGER_RTT_printf(0, "printf Test: %%p, &_Cnt : %p.\r\n", &_Cnt);
SEGGER_RTT_WriteString(0, "###### SEGGER_printf() Tests done. ######\r\n");
do {
_Cnt++;
SEGGER_RTT_printf(0, "%d\r\n", _Cnt);
delay_xms(100);
} while (1);
}
/*
SEGGER_RTT_printf Floating point is not supported
Here we quote a floating-point character conversion function written by netizens :
https://www.cnblogs.com/snowsad/p/12076740.html
Parameter:
Value Meaning
value The data you want to print
decimal_digit The number of decimal places in a number
_output_length The length of the output string
Return Value:
Value Meaning
unsigned char* Returns a string pointer
*/
unsigned char *out_float(double value, unsigned char decimal_digit, unsigned char *output_length)
{
unsigned char _output[20];
unsigned long integer;
unsigned long decimal;
unsigned char _output_length = 0;
unsigned char _length_buff = 0;
static unsigned char *return_pointer;
unsigned char signal_flag;
if (value < 0)
signal_flag = 1;
else
signal_flag = 0;
value = fabs(value);
integer = (unsigned long)value;
decimal = (unsigned long)((value - integer) * pow(10, decimal_digit));
unsigned long integer_buff = integer;
unsigned long decimal_buff = decimal;
while (1)
{
if (integer / 10 != 0)
_length_buff++;
else
{
_length_buff++;
break;
}
integer = integer / 10;
}
for (int i = 0; i < _length_buff; i++)
{
if (i == _length_buff - 1)
_output[_output_length] = integer_buff % 10 + 0x30;
else
{
//_output[_output_length] = integer_buff / 10 % 10 + 0x30;
_output[_output_length] = integer_buff / (unsigned long)pow(10, _length_buff - i - 1) % 10 + 0x30;
integer_buff = integer_buff % (unsigned long)pow(10, _length_buff - i - 1);
//integer_buff = integer_buff % 10;
}
_output_length++;
}
_output[_output_length] = '.';
_output_length++;
_length_buff = 0;
while (1)
{
if (decimal / 10 != 0)
_length_buff++;
else
{
_length_buff++;
break;
}
decimal = decimal / 10;
}
for (int i = 0; i < _length_buff; i++)
{
if (i == _length_buff - 1)
_output[_output_length] = decimal_buff % 10 + 0x30;
else
{
_output[_output_length] = decimal_buff / (unsigned long)pow(10, _length_buff-i-1) % 10 + 0x30;
decimal_buff = decimal_buff % (unsigned long)pow(10, _length_buff - i - 1);
}
_output_length++;
}
_output[_output_length] = 0x00;
_output_length++;
return_pointer = (unsigned char *)realloc(return_pointer,_output_length);
*output_length = _output_length - 1;
if (return_pointer == 0)
return 0;
else
{
if (signal_flag == 1)
{
return_pointer[0] = '-';
memcpy(return_pointer+1, _output, _output_length);
}
else
memcpy(return_pointer, _output, _output_length);
}
return return_pointer;
}
2> Compile and download , Power on again , Then open the J-Link RTT Viewer, Click on OK You can see the output , If you want to simulate debugging , You need to enter the simulation state first , And then click OK.
3> test result
4> Compile the above code , Enter the simulation , Then open the J-Link RTT Client Software , Here's the picture , Description connection successful .
5> Click full speed operation or single step debugging to see the corresponding printing information in the window .
6>client And viewer difference
client It needs to be used with simulation , and viewer Unwanted .
client Support Chinese output , and viewer I won't support it
Four 、 Input test
1> Enter a single character :
The code is as follows :
volatile int _Cnt;
volatile int _Delay;
static char r;
char acIn[20];
int ReadNum=0;
uint16_t i=0;
/*********************************************************************
*
* main
*/
int main(void) {
SEGGER_RTT_WriteString(0, "SEGGER Real-Time-Terminal Sample\r\n");
SEGGER_RTT_ConfigUpBuffer(0, NULL, NULL, 0, SEGGER_RTT_MODE_NO_BLOCK_SKIP);
while(1)
{
/* The first way to read a key value */
/* Judge RTT Of BUF Whether there is data available in the buffer */
if(SEGGER_RTT_HasKey())
{
/* from RTT Of BUF0 Read a key value in the buffer of */
r = SEGGER_RTT_GetKey();
if(r=='q')
{
SEGGER_RTT_WriteString(0,"input :q\r\n");
}
}
/* The second way to read a key value */
// do{
// r = SEGGER_RTT_WaitKey();
// SEGGER_RTT_printf(0,"input key is: %c\r\n",r);
// }while(r != 'q');
// SEGGER_RTT_printf(0,"host has been read q\r\n");
}
}
Be careful , This way of reading key values , Only support Terminal0, open J-Link RTT Viewer Configure as follows :
If there is no automatic connection , Can press F2 Connect again ,F3 To disconnect .
test result :
2> Enter multiple strings
Test code :
volatile int _Cnt;
volatile int _Delay;
static char r;
char acIn[20];
int ReadNum=0;
uint16_t i=0;
/*********************************************************************
*
* main
*/
int main(void) {
SEGGER_RTT_WriteString(0, "SEGGER Real-Time-Terminal Sample\r\n");
SEGGER_RTT_ConfigUpBuffer(0, NULL, NULL, 0, SEGGER_RTT_MODE_NO_BLOCK_SKIP);
while(1)
{
/* Judge RTT Of BUF Whether there is data available in the buffer */
if(SEGGER_RTT_HasKey())
{
/* from RTT Of BUF0 Read a key value in the buffer of */
ReadNum = SEGGER_RTT_Read(0,&acIn[0],sizeof(acIn));
for(i=0;i<20;i++)
{
if(0x0A != acIn[i])
{
ReadNum++;
}
else
{
break;
}
}
SEGGER_RTT_Write(0,acIn,ReadNum);
ReadNum=0;
memset(acIn,0,sizeof(acIn));
}
}
}
This method supports multiple Terminal, open J-Link RTT Viewer Configure as follows :
test result :
5、 ... and 、 Use tips
Multiple can be used Terminal The terminal outputs different contents , For example, terminals 0 Print out information , terminal 1 Output error message ,J-Link RTT Viewer Most support 16 Terminals .
in addition , You can also configure different printing colors of Fonts , Easy to identify , This is much easier to use than the serial port .
The test code is as follows :
static void _Delay(int period)
{
int i = 100000*period;
do { ; } while (i--);
}
int main(void)
{
int cnt=0;
while(1)
{
SEGGER_RTT_SetTerminal(1);
SEGGER_RTT_WriteString(0,RTT_CTRL_RESET"Red: "\
RTT_CTRL_TEXT_RED"This text is red."\
RTT_CTRL_TEXT_BLACK""\
RTT_CTRL_BG_BRIGHT_GREEN"This background is green."\
RTT_CTRL_RESET"Normal text again.\r\n");
_Delay(200);
cnt++;
SEGGER_RTT_SetTerminal(0);
SEGGER_RTT_WriteString(0,RTT_CTRL_RESET"Terminal:\r\n");
SEGGER_RTT_printf(0,"%sCounter:%s%d\r\n",RTT_CTRL_RESET,RTT_CTRL_TEXT_YELLOW,cnt);
if(cnt > 5)
{
SEGGER_RTT_TerminalOut(0,RTT_CTRL_TEXT_RED"Counter overflow!\r\n");
cnt=0;
}
}
return 0;
}
test result :
This is the information of all terminals , But this color is different from what we want to test , But the information is correct .
You can see here Terminal0, Terminal1 These two terminals are the output of the color we set .
————————————————
Copyright notice : This paper is about CSDN Blogger 「 Sing a song and you worry alone 」 The original article of , follow CC 4.0 BY-SA Copyright agreement , For reprint, please attach the original source link and this statement .
Link to the original text :https://blog.csdn.net/qq_23852045/article/details/108759582
RTT The solution to printing Chinese garbled code
For example, the following routine ,1 Print data once a second .
if (D1s.arrived == 0x01)
{
D1s.arrived = 0x00;
SEGGER_RTT_printf(0, "D1s.arrived \n"); // Debug the general
SEGGER_RTT_printf(0, "1 Seconds to \n"); // Debug the general
}
As shown in the figure below ,RTT Viewer The Chinese displayed in the window is garbled .
Solution 1 :
To open the first RTT Viewer, And on again RTT Client that will do .
Solution 2 :
Completely uninstall all J-Link Software , Install again .( Be careful : Other versions should also be uninstalled )
At present, it has been used for more than a year , Recommended version JLink_Windows_V663d.exe
Solution three : To be added .
————————————————
Copyright notice : This paper is about CSDN Blogger 「 Bright night stars 」 The original article of , follow CC 4.0 BY-SA Copyright agreement , For reprint, please attach the original source link and this statement .
Link to the original text :https://blog.csdn.net/weixin_37787043/article/details/112224654
版权声明
本文为[Traceless rain]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/04/202204230143119452.html
边栏推荐
- Find number (DFS)
- Basic knowledge of software testing, you can meet the interviewer after reading it
- 彻底卸载Antidote 10 ?Antidote卸载不干净怎么办?
- J-link v9 使用技巧之虚拟串口功能
- Abused "architect"!
- iTextSharp 显示中文字体
- 2022.4.22-----leetcode.396
- Unity combines itextsharp to generate PDF preparation DLL
- Redis implements distributed locks
- J-Link RTT使用
猜你喜欢
Problem solving: dpkg DEB: error: package name has characters that are't lowercase alphanums or '- +‘
Custom numeric input control
MySQL basic record
Full Permutation (DFS and next_permutation solution)
Detonate the bomb (DFS)
彻底卸载Antidote 10 ?Antidote卸载不干净怎么办?
J-Link RTT使用
揭秘被Arm编译器所隐藏的浮点运算
Slow response of analysis API
W801 / w800 / w806 unique ID / CPUID / flashid
随机推荐
Unrelated interprocess communication -- creation and use of named pipes
DFS parity pruning
PID精讲
W801/W800/W806唯一ID/CPUID/FLASHID
腾讯云接口进行人脸检测 和签名出错问题
Is the stable currency a super opportunity to accelerate the death of the public chain or replace BTC?
postman里面使用 xdebug 断点调试
mb_substr()、mb_strpos()函数(故事篇)
Performance introduction of the first new version of cdr2022
Google developer tool preserve log
Linux系统下以RPM方式如何安装mysql-5.7.9
Jerry's AI server [chapter]
[experience tutorial] Alipay balance automatically transferred to the balance of treasure how to set off, cancel Alipay balance automatically transferred to balance treasure?
Learning methods and career development guide (2022 Edition)
Qingyan environment and Shenzhen Stock Exchange listing: annual revenue of 180 million and market value of 4.1 billion
LSF的常用使用命令总结
UVC camera encapsulation class
Sqlserver data transfer to MySQL
Redis implements distributed locks
Ziguang micro financial report is outstanding. What does the triple digit growth of net profit in 2021 depend on