当前位置:首页 > 单片机 > 单片机
[导读]环境:主机: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

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

8位单片机在嵌入式设计领域已经成为半个多世纪以来的主流选择。尽管嵌入式系统市场日益复杂,8位单片机依然不断发展,积极应对新的挑战和系统需求。如今,Microchip推出的8位PIC®和AVR®单片机系列,配备了先进的独立...

关键字: 单片机 嵌入式 CPU

在嵌入式系统开发中,程序烧录是连接软件设计与硬件实现的关键环节。当前主流的单片机烧录技术已形成ICP(在电路编程)、ISP(在系统编程)、IAP(在应用编程)三大技术体系,分别对应开发调试、量产烧录、远程升级等不同场景。...

关键字: 单片机 ISP ICP IAP 嵌入式系统开发

在嵌入式系统开发中,看门狗(Watchdog Timer, WDT)是保障系统可靠性的核心组件,其初始化时机的选择直接影响系统抗干扰能力和稳定性。本文从硬件架构、软件流程、安全规范三个维度,系统分析看门狗初始化的最佳实践...

关键字: 单片机 看门狗 嵌入式系统

本文中,小编将对单片机予以介绍,如果你想对它的详细情况有所认识,或者想要增进对它的了解程度,不妨请看以下内容哦。

关键字: 单片机 开发板 Keil

随着单片机系统越来越广泛地应用于消费类电子、医疗、工业自动化、智能化仪器仪表、航空航天等各领域,单片机系统面临着电磁干扰(EMI)日益严重的威胁。电磁兼容性(EMC)包含系统的发射和敏感度两方面的问题。

关键字: 单片机 电磁兼容

以下内容中,小编将对单片机的相关内容进行着重介绍和阐述,希望本文能帮您增进对单片机的了解,和小编一起来看看吧。

关键字: 单片机 复位电路

在这篇文章中,小编将为大家带来单片机的相关报道。如果你对本文即将要讲解的内容存在一定兴趣,不妨继续往下阅读哦。

关键字: 单片机 异常复位

今天,小编将在这篇文章中为大家带来单片机的有关报道,通过阅读这篇文章,大家可以对它具备清晰的认识,主要内容如下。

关键字: 单片机 仿真器

单片机将是下述内容的主要介绍对象,通过这篇文章,小编希望大家可以对它的相关情况以及信息有所认识和了解,详细内容如下。

关键字: 单片机 中断 boot

一直以来,单片机都是大家的关注焦点之一。因此针对大家的兴趣点所在,小编将为大家带来单片机的相关介绍,详细内容请看下文。

关键字: 单片机 数字信号 模拟信号
关闭