sentry_chassis_hzz/bsp/log/bsp_log.md

1.7 KiB
Raw Blame History

bsp_log

neozng1@hnu.edu.cn

TODO:

  1. 在未接入调试器的时候将日志写入flash中并提供接口读取
  2. 增加日志分级提供info、warning、error三个等级的日志

使用说明

bsp_log是基于segger RTT实现的日志打印模块。

推荐使用bsp_log.h中提供了三级日志:

#define LOGINFO(format,...)
#define LOGWARNING(format,...)
#define LOGERROR(format,...)

分别用于输出不同等级的日志。

若想启用RTT必须通过launch.jsondebug-jlink启动调试(不论使用什么调试器)。

注意若你使用的是cmsis-dap和daplink请在调试任务启动之后再打开log任务。(均在项目文件夹下的.vsocde/task.json中有注释自行查看

在ozone中查看log输出直接打开console调试任务台和terminal调试中断便可看到调试输出。

由于ozone版本的原因可能出现日志不换行或没有颜色。

自定义输出

你也可以自定义输出格式详见Segger RTT的文档。

int printf_log(const char *fmt, ...);
void Float2Str(char *str, float va);

调用第一个函数可以通过jlink或dap-link向调试器连接的上位机发送信息格式和printf相同示例如下

printf_log("Hello World!\n");
printf_log("Motor %d met some problem, error code %d!\n",3,1);

第二个函数可以将浮点类型转换成字符串以方便发送:

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()发送日志,可以设置小数点位数以降低带宽开销。