当前位置:首页 > 单片机 > 单片机
[导读]环境:主机:WIN10开发环境:MDK5.12MCU:STM32F407说明:为单片机设计了一套简单的日志系统,通过日志系统提供的接口可以查看设备状态,并进行一些基本的调试。日志系统通过串口输出,所以单片机需要准备一个串口供日志

环境:

主机:WIN10

开发环境:MDK5.12

MCU:STM32F407


说明:

为单片机设计了一套简单的日志系统,通过日志系统提供的接口可以查看设备状态,并进行一些基本的调试。

日志系统通过串口输出,所以单片机需要准备一个串口供日志系统使用。注意串口发送不能用DMA发送(避免在在中断中打印日志造成的中断竞争),接收可以用DMA接收。


功能:

打开/关闭各个模块的调试输出

输入动作指令,让设备进行一些动作

打印系统运行日志

指令:

H:帮助

O:调试输出全开

O1:打开1号模块,打开其他模块指令类似

F:调试输出全关

F1:关闭1号模块

I:输出系统日志

C:清除系统日志

A1:执行1号动作,执行其他动作指令类似

源代码:

log.h:


/**

*Copyright(c),2015-2025

*@filelog.h

*@brief日志模块主文件

*@authorjdh

*@date2015/5/7

*@update2015/6/19

*@update2015/6/23

*@update2015/6/30

*@update2015/7/8

*@update2015/7/13

*@update2015/8/12

*@update2015/8/18

*@update2016/5/17

*@update2016/6/30

*@update2016/7/22

*@update2016/8/11

*@update2016/8/24

*@update2016/9/2

*@update2016/9/5

*@update2016/9/7

*@update2016/9/9

*/

#ifndef_LOG_H_

#define_LOG_H_

/*********************************************************************

*头文件

**********************************************************************/

#include"world.h"

#include"console.h"

/*********************************************************************

*宏定义

**********************************************************************/

/**

*@brief日志模块数量

*/

#defineNUM_LOG5

/**

*@brief模块编号

*/

#defineLOG_TEST0

#defineLOG_CLOCK1

#defineLOG_DW10002

#defineLOG_DW1000_STATUS3

#defineLOG_DEAL_BUS4

/*********************************************************************

*数据结构

**********************************************************************/

/**

*@brief日志

*/

struct_Log

{

//公有日志

//收到移动点数据次数

uint32_tnum_rf_rx;

//发送超时被删除点数

uint32_tnum_time_out_delete;

//RF发送次数

uint32_tnum_rf_tx;

//RF校时或分配事件次数

uint32_tnum_rf_time;

//RF随机信道发送次数

uint32_tnum_rf_random_tx;

//复位次数

uint32_tnum_reset;

//运行时间,分度为0.5s

uint32_ttime_run;

//收到同步脉冲计数

uint32_tnum_sync_pulse;

//收到422轮询/事件帧次数

uint32_tnum_bus_poll;

//收到422事务命令次数

uint32_tnum_bus_down_cmd;

//收到422事务命令中事件个数

uint32_tnum_bus_down_cmd_dot;

//收到有效的422帧次数

uint32_tnum_valid_bus;

//收到无效的422帧次数

uint32_tnum_invalid_bus;

//接收时间错误

uint32_tnum_time_error;

//私有日志

//dw1000芯片错误次数

uint32_tnum_dw1000_error[NUM_DW1000];

//接收时间错误

uint32_tnum_dw1000_time_error[NUM_DW1000];

//轮询超时被删除点数

uint32_tnum_poll_time_out_delete;

//接收超时复位

uint32_tnum_dw1000_time_out_reset[NUM_DW1000];

//dw1000芯片状态错误次数

uint32_tnum_dw1000_status_error[NUM_DW1000];

};

/*********************************************************************

*函数

**********************************************************************/

/**

*@brief模块加载

*/

voidlog_load(void);

/**

*@brief读取日志

*@retval日志

*/

struct_Loglog_read(void);

/**

*@brief清除日志

*/

voidlog_clear(void);

/**

*@brief收到移动点数据次数

*/

voidlog_write_num_rf_rx(void);

/**

*@brief发送超时被删除点数

*/

voidlog_write_num_time_out_delete(void);

/**

*@briefRF发送次数

*/

voidlog_write_num_rf_tx(void);

/**

*@briefRF校时或分配事件次数

*/

voidlog_write_num_rf_time(void);

/**

*@briefRF随机信道发送次数

*/

voidlog_write_num_rf_random_tx(void);

/**

*@brief复位次数

*/

voidlog_write_num_reset(void);

/**

*@brief运行时间

*@paramadd_time:增加的时间.单位:0.5s

*/

voidlog_write_time_run(uint32_tadd_time);

/**

*@brief收到同步脉冲计数

*/

voidlog_write_num_sync_pulse(void);

/**

*@brief收到422轮询/事件帧次数

*/

voidlog_write_num_bus_poll(void);

/**

*@brief收到422事务命令次数

*/

voidlog_write_num_bus_down_cmd(void);

/**

*@brief收到422事务命令中事件个数

*/

voidlog_write_num_bus_down_cmd_dot(void);

/**

*@brief收到有效的422帧次数

*/

voidlog_write_num_valid_bus(void);

/**

*@brief收到无效的422帧次数

*/

voidlog_write_num_invalid_bus(void);

/**

*@brief收到时间错误

*/

voidlog_write_num_time_error(void);

/**

*@briefdw1000芯片错误次数

*@paramindex:模块序号,从0开始

*/

voidlog_write_num_dw1000_error(uint8_tindex);

/**

*@briefdw1000芯片接收时间错误次数

*@paramindex:模块序号,从0开始

*/

voidlog_write_num_dw1000_time_error(uint8_tindex);

/**

*@brief轮询超时被删除点数

*/

voidlog_write_num_poll_time_out_delete(void);

/**

* @brief dw100

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭