2022-11-11 21:20:58 +08:00
|
|
|
|
# bsp_log
|
|
|
|
|
|
|
|
|
|
<p align='right'>neozng1@hnu.edu.cn</p>
|
|
|
|
|
|
2022-11-11 21:49:03 +08:00
|
|
|
|
> TODO:
|
|
|
|
|
>
|
|
|
|
|
> 1. 在未接入调试器的时候,将日志写入flash中,并提供接口读取
|
|
|
|
|
> 2. 增加日志分级,提供info、warning、error三个等级的日志
|
|
|
|
|
|
2022-11-11 21:20:58 +08:00
|
|
|
|
## 使用说明
|
2022-11-11 21:49:03 +08:00
|
|
|
|
|
|
|
|
|
bsp_log是基于segger RTT实现的日志打印模块。
|
|
|
|
|
|
2023-06-03 21:58:21 +08:00
|
|
|
|
推荐使用`bsp_log.h`中提供了三级日志:
|
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
#define LOGINFO(format,...)
|
|
|
|
|
#define LOGWARNING(format,...)
|
|
|
|
|
#define LOGERROR(format,...)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
分别用于输出不同等级的日志。
|
|
|
|
|
|
|
|
|
|
**若想启用RTT,必须通过`launch.json`的`debug-jlink`启动调试(不论使用什么调试器)。**
|
|
|
|
|
|
|
|
|
|
注意,若你使用的是cmsis-dap和daplink,**请在调试任务启动之后再打开`log`任务。**(均在项目文件夹下的.vsocde/task.json中,有注释自行查看)。
|
|
|
|
|
|
|
|
|
|
在ozone中查看log输出,直接打开console调试任务台和terminal调试中断便可看到调试输出。
|
|
|
|
|
|
|
|
|
|
> 由于ozone版本的原因,可能出现日志不换行或没有颜色。
|
|
|
|
|
|
|
|
|
|
## 自定义输出
|
|
|
|
|
|
|
|
|
|
你也可以自定义输出格式,详见Segger RTT的文档。
|
|
|
|
|
|
2022-11-11 21:49:03 +08:00
|
|
|
|
```c
|
|
|
|
|
int printf_log(const char *fmt, ...);
|
|
|
|
|
void Float2Str(char *str, float va);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
调用第一个函数,可以通过jlink或dap-link向调试器连接的上位机发送信息,格式和printf相同,示例如下:
|
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
printf_log("Hello World!\n");
|
|
|
|
|
printf_log("Motor %d met some problem, error code %d!\n",3,1);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
第二个函数可以将浮点类型转换成字符串以方便发送:
|
|
|
|
|
|
|
|
|
|
```c
|
|
|
|
|
float current_feedback=114.514;
|
|
|
|
|
char* str_buff[64];
|
|
|
|
|
Float2Str(str_buff,current_feedback);
|
|
|
|
|
printf_log("Motor %d met some problem, error code %d!\n",3,1);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
或直接通过`%f`格式符直接使用`printf_log()`发送日志,可以设置小数点位数以降低带宽开销。
|
2023-06-03 21:58:21 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|