mirror of
https://github.com/armink/EasyLogger.git
synced 2025-02-08 00:54:09 +08:00
117 lines
4.9 KiB
Markdown
117 lines
4.9 KiB
Markdown
# EasyLogger Flash插件移植说明
|
||
|
||
---
|
||
|
||
## 1、准备工作
|
||
|
||
在使用Flash插件前,保证EasyLogger的核心功能已经在项目中移植成功([移植文档点这里](https://github.com/armink/EasyLogger/blob/master/docs/zh/port/kernel.md))。再确认已下载的源码中存在`\easylogger\plugins\flash`文件夹,该文件夹为Flash插件的所有源码。
|
||
|
||
## 2、导入项目
|
||
|
||
目前只有STM32F10x平台的RT-Thread系统Demo里面使用了Flash插件,如果你的项目与这个Demo平台一致,则可以先直接跳过2、3、4章节,按照第5章的要求设置参数,并运行、验证Demo。验证通过再按照下面的导入项目要求,将Demo中的移植文件直接导入到项目中即可。
|
||
|
||
- 1、打开`\easylogger\plugins\flash`文件夹,内部文件结构如下:
|
||
|
||
|源文件 |描述 |
|
||
|:------------------------------ |:----- |
|
||
|elog_flash.c |Flash插件源码|
|
||
|elog_flash.h |Flash插件头文件|
|
||
|elog_flash_cfg.h |Flash插件配置头文件|
|
||
|elog_flash_port.c |Flash插件移植文件|
|
||
|
||
|
||
- 2、将`\easylogger\plugins\flash`下的所有文件拷贝到项目中;
|
||
- 3、添加`elog_flash.c`及`elog_flash_port.c`这些文件到项目的编译路径中;
|
||
- 4、添加插件所在文件夹到编译的头文件目录列表中;
|
||
|
||
## 3、移植接口
|
||
|
||
### 3.1 移植初始化
|
||
|
||
Flash插件移植初始化。初始化Flash插件移植所需的资源等等。
|
||
|
||
```C
|
||
ElogErrCode elog_flash_port_init(void)
|
||
```
|
||
|
||
### 3.2 Flash中的日志被读取后的输出接口
|
||
|
||
将日志从Flash中读取后,调用`elog_flash_outout()`、`elog_flash_outout_all()`及`elog_flash_outout_recent()`进行输出展示时,将会调用此移植接口。可以在里面增加输出到终端、网络等功能。
|
||
|
||
```C
|
||
void elog_flash_port_output(const char *log, size_t size)
|
||
```
|
||
|
||
|参数 |描述|
|
||
|:----- |:----|
|
||
|log |日志内容|
|
||
|size |日志大小|
|
||
|
||
例子:
|
||
```c
|
||
void elog_flash_port_output(const char *log, size_t size) {
|
||
/* output to terminal */
|
||
rt_kprintf("%.*s", size, log);
|
||
}
|
||
|
||
```
|
||
### 3.3 资源同步锁-加锁
|
||
|
||
对日志写入Flash操作进行加锁,保证日志在并发写入时的正确性。有操作系统时可以使用获取信号量来加锁,裸机时可以通过关闭全局中断来加锁。
|
||
|
||
```C
|
||
void elog_flash_port_lock(void)
|
||
```
|
||
|
||
### 3.4 资源同步锁-解锁
|
||
|
||
与加锁功能对应。
|
||
|
||
```C
|
||
void elog_flash_port_unlock(void)
|
||
```
|
||
## 4、设置参数
|
||
|
||
配置时需要修改项目中的`elog_flash_cfg.h`文件,开启、关闭、修改对应的宏即可。
|
||
|
||
### 4.1 缓冲模式
|
||
|
||
开启后,需要写入Flash的日志会先存储至RAM缓冲区,当缓冲区满时,缓冲区中的所有日志将自动写入Flash。如果关闭,所有日志在输出时会立刻写入Flash。
|
||
|
||
- 默认状态:开启
|
||
- 操作方法:开启、关闭`ELOG_FLASH_USING_BUF_MODE`宏即可
|
||
|
||
#### 4.1.1 缓冲区大小
|
||
|
||
当开启缓冲模式后,此配置才会生效,单位:byte。
|
||
|
||
- 操作方法:修改`ELOG_FLASH_BUF_SIZE`宏对应值即可
|
||
|
||
## 5、测试验证
|
||
|
||
每次使用前,务必核心功能都已经初始化完成,再调用`elog_flash_init()`方法对Flash插件进行初始化,保证初始化没问题后,再调用`elog_start()`方法启动EasyLogger,最后就可以使用Flash插件自带的API方法进行测试。如果使用的RT-Thread的Demo,则可以按照[这里的命令要求](https://github.com/armink/EasyLogger/tree/master/demo/os/rt-thread/stm32f10x#22-flash-log将日志保存到flash中),接上finsh串口,输入finsh命令即可测试。
|
||
|
||
摘取自STM32平台下RT-Thread Demo中的初始化过程([点击查看全部](https://github.com/armink/EasyLogger/blob/master/demo/os/rt-thread/stm32f10x/app/src/app_task.c)):
|
||
```c
|
||
/* 初始化EasyFlash及EasyLogger */
|
||
if ((easyflash_init() == EF_NO_ERR)&&(elog_init() == ELOG_NO_ERR)) {
|
||
/* 设置日志格式 */
|
||
elog_set_fmt(ELOG_LVL_ASSERT, ELOG_FMT_ALL & ~ELOG_FMT_P_INFO);
|
||
elog_set_fmt(ELOG_LVL_ERROR, ELOG_FMT_LVL | ELOG_FMT_TAG | ELOG_FMT_TIME);
|
||
elog_set_fmt(ELOG_LVL_WARN, ELOG_FMT_LVL | ELOG_FMT_TAG | ELOG_FMT_TIME);
|
||
elog_set_fmt(ELOG_LVL_INFO, ELOG_FMT_LVL | ELOG_FMT_TAG | ELOG_FMT_TIME);
|
||
elog_set_fmt(ELOG_LVL_DEBUG, ELOG_FMT_ALL & ~(ELOG_FMT_FUNC | ELOG_FMT_P_INFO));
|
||
elog_set_fmt(ELOG_LVL_VERBOSE, ELOG_FMT_ALL & ~(ELOG_FMT_FUNC | ELOG_FMT_P_INFO));
|
||
/* 设置EasyLogger的断言钩子方法 */
|
||
elog_assert_set_hook(elog_user_assert_hook);
|
||
/* 初始化EasyLogger的Flash 插件 */
|
||
elog_flash_init();
|
||
/* 启动EasyLogger */
|
||
elog_start();
|
||
/* 设置RT-Thread提供的硬件异常钩子方法 */
|
||
rt_hw_exception_install(exception_hook);
|
||
/* 设置RT-Thread断言钩子方法 */
|
||
rt_assert_set_hook(rtt_user_assert_hook);
|
||
}
|
||
```
|