2022-11-11 21:20:58 +08:00
|
|
|
#include "bsp_log.h"
|
|
|
|
|
|
|
|
#include "SEGGER_RTT.h"
|
|
|
|
#include "SEGGER_RTT_Conf.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
|
2022-12-05 21:01:26 +08:00
|
|
|
void BSPLogInit()
|
2022-11-12 19:37:16 +08:00
|
|
|
{
|
|
|
|
SEGGER_RTT_Init();
|
2022-11-11 21:49:03 +08:00
|
|
|
}
|
2022-11-11 21:20:58 +08:00
|
|
|
|
2022-12-05 21:01:26 +08:00
|
|
|
int PrintLog(const char *fmt, ...)
|
2022-11-11 21:20:58 +08:00
|
|
|
{
|
|
|
|
va_list args;
|
|
|
|
va_start(args, fmt);
|
2023-03-18 20:36:21 +08:00
|
|
|
int n = SEGGER_RTT_vprintf(BUFFER_INDEX, fmt, &args); // 一次可以开启多个buffer(多个终端),我们只用一个
|
2022-11-11 21:20:58 +08:00
|
|
|
va_end(args);
|
|
|
|
return n;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Float2Str(char *str, float va)
|
|
|
|
{
|
|
|
|
int flag = va < 0;
|
|
|
|
int head = (int)va;
|
|
|
|
int point = (int)((va - head) * 1000);
|
|
|
|
head = abs(head);
|
|
|
|
point = abs(point);
|
|
|
|
if (flag)
|
|
|
|
sprintf(str, "-%d.%d", head, point);
|
|
|
|
else
|
|
|
|
sprintf(str, "%d.%d", head, point);
|
2023-03-18 20:36:21 +08:00
|
|
|
}
|
|
|
|
|