MCU输出日志和调试信息的几种方法

这篇具有很好参考价值的文章主要介绍了MCU输出日志和调试信息的几种方法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

基于MCU的嵌入式软件开发,可能在某些情况下没有多余存储空间,从而没有在本地有效保存调试和日志信息。

这时,通过某种方式把调试(Debug)和日志(Log)信息输出就显得有意义了。

下面就来讲讲关于嵌入式开发中输出调试和日志信息的几点内容。

标准库 printf 直接输出

在MCU嵌入式开发中,通过UART串口 printf 输出调试和日志信息的方式是最常见的一种。

在Linux、Windows这种大型系统中,使用标准C库没有问题,但在MCU这种资源有限的平台,通常使用微库。

1.使用微库配置方法

在使用的IDE中,比如 Keil 和 IAR 都需要在工程选项中进行配置才能正常使用微库。

Keil 使用微库:

Project -> Options for Target -> Target,勾选"Use MicroLIB"

mcu如何查看日志,单片机,stm32,嵌入式硬件

IAR 使用微库:

Project -> Options for Node -> General Options -> Library Configuration,选择"Full"

mcu如何查看日志,单片机,stm32,嵌入式硬件

额外说明一下,IAR 中使用库有四个选择:

None:无

Normal:选择常规配置的运行时库

Full:选择完整配置的运行时库

Custom:选择定制运行时库

这里关于微库以及IDE配置,可以参看我的文章:

微库和标准C库有什么区别?

Keil系列教程05_工程目标选项配置(一)

IAR系列教程06_工程节点选项配置(一)

2.重定义函数

你要输出信息,肯定要有路径才行啊,是UART,还是CAN。所以,就需要重定义函数才行。

以UART串口为例,最常见一种方式:

#include <stdio.h>
int fputc(int ch, FILE *f){  DEBUG_SendByte((uint8_t)ch);
  return ch;}
int fgetc(FILE *f){  while(USART_GetFlagStatus(DEBUG_COM, USART_FLAG_RXNE) == RESET);
  return (int)USART_ReceiveData(DEBUG_COM);}

当然,串口里面具体的实现方式,与你底层有关。

有以上配置,就可以直接使用 printf 函数了。

自定义 printf 输出

有些情况下,需要指定要求输出调试或日志信息,就需要自定义输出格式。

举例1:

比如:我要设置一个 “DBUGE 开关”,在开发测试阶段,我需要打开开关,产品量产后,我不需要开启调试信息输出。

#define DEBUG(Type, ...)   if(DEBUG_EN(Type)) \                           { \                             printf(__VA_ARGS__); \                           }

说明:__VA_ARGS__它是一个可变参数的宏,就是将左边宏中“...” 的内容原样抄写在右边 __VA_ARGS__ 所在的位置。

举例2:

还比如:输出日志信息,添加“时间戳”:

#define DEBUG(Type, ...)   if(DEBUG_EN(Type)) \                           { \                             printf("%s:", GetTimeStr());\                             printf(__VA_ARGS__); \                           }

更多自定义:

实际项目可能有很多需求,还比如:针对不同类型的传感器,输出日志带有“传感器编号”的日志信息。

所以说,项目需求和复杂不同,其输出调试或日志信息可能有不同的方式,具体要不要实现,还需要综合评估。

SWO 输出

类似UART串口输出,SWO(Serial Wire Output)串行线输出也是其中的一种,但需要MCU支持SWO功能才行(目前很多MCU都支持)。

可以在线调试时,输出到IDE界面,比如:

mcu如何查看日志,单片机,stm32,嵌入式硬件

还可以离线输出到一些工具界面,比如:

mcu如何查看日志,单片机,stm32,嵌入式硬件

CLI调试输出信息

上面几种方式都是单纯的输出调试/日志信息,相对更高级一点的做法就是通过CLI(Command Line Interface)命令行的方式获取调试信息。

命令行相信大家不模式,做嵌入式开发的都知道,像Linux的终端就是一个命令行,只是我们这里说的命令行,相对Linux的终端来说要简单的多。但是原理类似,都是通过输入命令来查看数据或执行某个动作。

1.相对printf优势

通过CLI可以任意时刻查看指定信息,执行某种操作。

2.相对printf劣势

需要在代码中集成CLI组件,以及对应的(查看、执行动作等)代码,更占用资源。(当然,可以使用轻量级的CLI,相对不占资源那种)

比如我之前用的一种,估计占用Flash不到1K的空间:

mcu如何查看日志,单片机,stm32,嵌入式硬件

其实,很多RTOS都集成了CLI组件,想用其实也不是想象中的那么复杂,和移植RTOS差不多,甚至更简单。文章来源地址https://www.toymoban.com/news/detail-840319.html

到了这里,关于MCU输出日志和调试信息的几种方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 清理 SQL Server 数据库日志的几种方法

    在 SQL Server 数据库中,日志文件起着记录数据库操作和事务日志的重要作用。然而,随着时间的推移,日志文件可能会变得非常庞大,占用大量磁盘空间。为了解决这个问题,本文将介绍几种清理 SQL Server 数据库日志的方法。 方法一:备份日志并截断 备份数据库日志是清理

    2024年02月05日
    浏览(34)
  • RISC-V/ARM mcu OpenOCD 调试架构解析

    最近有使用到risc-v的单片机,所以了解了下risc-v单片机的编译与调试环境的搭建,面试时问到risc-v的调试可参看以下内容。 risc-v根据官方的推荐,调试器服务是选择OpenOCD,DopenOCD(开放片上调试器)是一个开源的片上调试器,旨在提供针对嵌入式设备的调试、系统编程和边界扫

    2024年04月28日
    浏览(30)
  • stm32 MCU液晶TM1622 HT1622驱动调试

    本文使用的例程软件工程代码如下 (1条消息) stm32MCU液晶TM1622HT1622驱动调试,源代码,实际项目使用资源-CSDN文库 HT1622/HT1622G/TM1622是一款常用的LCD驱动芯片 TM1622/HT1622厂家不一样,但是芯片功能基本上一直,硬件上基本上可以做到pin2pin兼容,这个需要根据自己的做微调整 以T

    2024年02月13日
    浏览(32)
  • vscode+gcc+jlink调试mcu程序(用于替代IDE)

    几年前写过一篇类似的文章,那时是用于调试rtthread系统:使用 VSCode、arm-none-eabi-gdb、J-Link GDB Server 调试RTThread。 当时有关vscode和gcc调试MCU的文章很少,所以只是写了个大概。 最近又遇到了类似的问题,网上搜了一些资料,发现此方面的内容已经比较成熟了,借鉴了一些资料

    2024年02月13日
    浏览(28)
  • 汽车信息安全--车规MCU的密钥管理

    目录 1.密钥分类及作用概述 2.密钥管理策略 3.小结 随着智能网联汽车的飞速发展,接入网络的车辆收到黑客攻击的场景越来越多。为保护网联汽车免受网络攻击,使用密码学对个人隐私数据、整车敏感数据进行保护逐渐引起了业内人士的重视。 在CP AUTOSAR中针对车内ECU间CAN

    2024年01月21日
    浏览(37)
  • 精简高效与安全兼备:ARM32与MCU32平台上的信息协议设计新思路

    信息协议作为通信系统的核心组成部分,承担着确保数据准确、高效传输的重要任务。在ARM32平台和MCU32单片机平台上,合理设计的信息协议不仅能提高通信效率,还能确保系统安全稳定运行。 信息协议(Information Protocol)是一组规定,它定义了在网络中数据如何被格式化、传

    2024年02月04日
    浏览(31)
  • 从应用层到MCU,看Windows处理键盘输入 [1.在应用层调试Notepad.exe (按键消费者)]

    文本编辑器/文本编辑框是应用层常见的键盘处理程序。微软泄露的WinXP源码下有文本编辑器Notepad的实现: 文本编辑器的实现并不复杂,微软又(被迫)提供了Sample,因此本文就不重复造轮子了。本文从调试器的角度观察Notepad.exe如何消费键盘按键. 首先评估一下调试Notepad.exe的难

    2024年02月08日
    浏览(26)
  • python的几种输出方式

    1.输出百分比方法 2. print(f “{}”) 的用法 3. .format格式   4. 加号拼接(针对字符串) 扩展知识 -格式化输出 字符 含有 %s 字符串 %d 有符号十进制整数,%06d表示输出的整数显示位数字,不足的地方使用0补全 %f 浮点数,%.02f表示小数点后只显示两位 %% 输出%  %s:代表字符串的占

    2024年04月15日
    浏览(35)
  • chatGPT流式输出的几种方式

    前言 chatGPT是一款高效强大的语言模型,能够给我们的生活带来极大的改变。无论是学习知识还是工作效率,chatGPT都能为我们提供有力的帮助。它可以帮助我们快速获取所需的知识,同时可以帮助我们提高工作效率,包括写文章、文案、推荐策略、生成代码、写周报,流程图

    2024年02月06日
    浏览(32)
  • 手机web前端调试页面的几种方式

    PC端web页面调试比较容易,这里主要说几种移动端调试的方法,从简单到复杂、从模拟调试到远程调试,大概分为几部分: 1、Chrome DevTools(谷歌浏览器)的模拟手机调试 2、weinre(web inspector remote)远程调试工具 3、微信的“web开发者工具”,集成了Chrome DevTools和weinre,做的比较好

    2024年02月09日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包