添加串口和虚拟终端输出帮助调试



在使用IAR开发STM32项目时,使用串口或者是虚拟终端来输出我们想看的信息是一个非常好而且简便的方式。

首先来看看串口怎么实现信息输出。简单来说串口输出信息就是将标准输出重定向到串口,在上位机的超级终端或者串口助手等工具中查看结果。

在使用串口之前要配置串口,这一点是串口应用的基本知识,如果要通过串口输入参数可能还需要使用中断。关于串口配置和终端配置,应根据具体是用来实现。这里主要说一下标准输出的重定向。

标准库中的printf函数实际调用了intfputc(int ch, FILE *f)函数,所以我们要重载这个函数,实现从串口输出数据。

int fputc(int ch, FILE *f) 
{  while (USART_GetFlagStatus(USARTn, USART_FLAG_TC) == RESET) {} USART_SendData(USARTn, (uint8_t) ch); return ch; 
}

当然,如果想通过串口输入参数还需要从在标准输入函数,如:

int GetKey (void)
{while(!(USARTn->SR & USART_FLAG_RXNE));return((int)( USARTn->DR & 0x1FF));
}

完成以上重载后,在程序中使用printf函数打印信息时,就会从串口输出信息。接到上位软件的画就可以在上位机看到这些信息,便于查看调试。

接下来我们看一看在IAR虚拟终端中查看输出结果,这个相对要简单得多。只需要做一些必要的设置即可将标准输出重定向到IAR虚拟终端中。

在开始之前,必须在使用printf函数的的文件中引用stdio.h。这一点毋庸置疑,与任何外部函数的调用是一样的。然后开始设置:

右键点击项目名称并在弹出菜单中点击“Options”或者在软件“Project”菜单中点击“Options”。

弹出Options界面后在左侧列表框中选择“GeneralOptions”,在右侧的Tab界面中选择“Library Configuration”标签,如下图红框所示:

在“Library Configuration”标签下,将Library改为全库“Full”,将“stdout/stderr”改为“Via SWO”,如下图红框所示。

在完成上述设置后如果没有其他的输出设置,当在线调试时,打开View菜单中的“Terminal IO”(如下图红框所示),就可在IAR中显示输出了,当然也可以输入数据。

如果在使用IAR虚拟终端时重载了输入输出函数,则不会从IAR虚拟终端输出,每次修改很麻烦,我们可以写一个源文件通过条件编译来实现我们想要的输出方式。

定义两个宏来控制我们要要的方式:

/*启用调试使用功能代码*/
#ifndef DEBUG_CODE_ENABLE
#define DEBUG_CODE_ENABLE (1)
#endif

在调试时,将DEBUG_CODE_ENABLE设为1,方便查看,在项目正式发布时则可将DEBUG_CODE_ENABLE设为0将这段代码屏蔽。

/*定义开关串口打印的宏,当为1时使用串口输出,当为0时使用IAR虚拟终端*/
#ifndef USART_PRINT_ENABLE
#define USART_PRINT_ENABLE (0)
#endif

而在使用时,如果输出的内容数量和种类比较多的话,实现起来比较乱而且可能破环其他部分代码的整体性和可读性。我们可以使用函数指针来集中操作,这样无论是代码还是输出信息的完整性都可以保证,而且实现条件编译也变得更简洁。

先定义一个打印对象类型的枚举类型和一个打印对象的结构体,如下:

/*定义一个打印对象数据类型的枚举,有新类型是在此添加即可*/
typedef enum{pChar,pInt8,pInt16,pInt32,pFloat,pString
}PrintType;/*定义一个答应对象的结构体类型*/
typedef struct{PrintTypeprintType;void *objValue;
}PrintObject;

再定义一个函数指针数组用于存放打印函数的指针:

int (*ObjPrintf[])(void*objValue)={CharPrintf,Int8Printf,Int16Printf,Int32Printf,FloatPrintf,StringPrintf};

并定义一个调用打印的函数:

/*调试时批量打印输出函数*/

void DebugOutput(PrintObject *printObject,uint16_t amount);

对于具体的实现函数根据自己的要求实现就可以了。

在调用时只需要定义一个要输出的对象数组并将其作为参数传递给DebugOutput汗数据可以了。

  /*启用调试辅助代码时,初始化显影的参数*/
#if DEBUG_CODE_ENABLE > (0)chartitle[]="\nThe result is:";PrintObjectprintObject[]={{pString,title},{pFloat,&o2Concentration},{pFloat,&h2Concentration},{pFloat,&ch4Concentration}};/*如果启用了串口打印输出功能,则初始化串口配置*/
#if USART_PRINT_ENABLE > (0)PrintUsartConfiguration();
#endif#endif/*用于测试*/
#if DEBUG_CODE_ENABLE > (0)DebugOutput(printObject,sizeof(printObject)/sizeof(PrintObject));
#endif

如此就可以非常方便的输出信息、并可根据自己的需要控制是否输出调试信息,采用何种信息输出方式了,对调试来说非常有帮助。

欢迎关注:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/499520.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1.1股票数据预处理练习

第一阶段、一个简单策略入门量化投资 1.1股票数据预处理练习 无论我们要对股票市场进行何种探索,在开始前,研究如何获取数据,并进行对应的预处理都是必要的。 本节以美股为例,进行股票数据预处理的练习。正文如下: …

1-2 移动均线交叉策略1

第一阶段、一个简单策略入门量化投资 1-2 移动均线交叉策略1 第一阶段一个简单策略入门量化投资1-2 移动均线交叉策略1前言获取数据移动均线交叉策略数据可视化绘制折线图绘制K线图绘制移动均线 移动均线交叉策略回测什么是回测回溯买卖信号计算收益 未完待续完整代码 前言 …

STM32F412应用开发笔记之一:初识NUCLEO-F412ZG

今天终于收到了期待已久的NUCLEO-F412ZG,感谢电子发烧友论坛! 近几年来基本都是在STM32平台上做一些设计开发工作。STM32F103、STM32F107、STM32F429等都应用过,但却从没有申请过试用。没想到这次申请居然能被选中&a…

STM32F412应用开发笔记之二:基本GPIO控制

NUCLEO-F412ZG板子上的元器件并没有完全焊接,除去ST-LINK部分和电源部分后,还有用一个USB主机接口,三个LED灯和两个按钮,不过很多功能引脚都已经引到了插针。查看原理图可发现,由原理图模块的…

1-3移动均线交叉策略2

第一阶段、一个简单策略入门量化投资 1-3移动均线交叉策略2 上一篇文章1-2 移动均线交叉策略1中我们最后提到: 如果我们从第一天买入股票,一直持有股票,最后一天卖出,获得的收益是每股124.02美元,收益率为412% 如果…

1-4移动均线交叉策略3

第一阶段、一个简单策略入门量化投资 1-4移动均线交叉策略3 上一文1-3移动均线交叉策略2中,我们得到的结果是令人失望的。但我们的探索还要继续。 我们知道,使用投资组合的方式进行分散投资是降低风险的好办法。尽管移动均线交叉策略的表现并不理想&a…

STM32学习及应用笔记一:SysTick定时器学习及应用

 这几年一直使用STM32的MCU,对ARM内核的SysTick计时器也经常使用,但几乎没有仔细了解过。最近正好要在移植一个新的操作系统时接触到了这块,据比较深入的了解了一下。 1、SysTick究竟是什么? 关于SysT…

使用Atom快速打造好用的Markdown编辑器

使用Atom快速打造好用的Markdown编辑器 Atom当前主流的跨平台的三大编辑器(Atom,sublime,vscode)之一 今天尝试了使用Atom来打造Markdown编辑器,快速上手且易用,墙裂推荐! 下面直接进入正题,一步步介绍如何使用Atom快速打造好用…

PID控制器开发笔记之一:PID算法原理及基本实现

 在自动控制中,PID及其衍生出来的算法是应用最广的算法之一。各个做自动控制的厂家基本都有会实现这一经典算法。我们在做项目的过程中,也时常会遇到类似的需求,所以就想实现这一算法以适用于更多的应用场景。…

十分钟能学会的简单python爬虫

简单爬虫三步走,So easy~ 本文介绍一个使用python实现爬虫的超简单方法,精通爬虫挺难,但学会实现一个能满足简单需求的爬虫,只需10分钟,往下读吧~ 该方法不能用于带有反爬机制的页面,但对于我这样的非专业…

PID控制器开发笔记之二:积分分离PID控制器的实现

前面的文章中,我们已经讲述了PID控制器的实现,包括位置型PID控制器和增量型PID控制器。但这个实现只是最基本的实现,并没有考虑任何的干扰情况。在本节及后续的一些章节,我们就来讨论一下经典PID控制器的优化与改进。这一节我们首…

利用python实现短信和电话提醒功能

有时候,我们需要程序帮我们自动检测某些事件的发生 这个需求是广泛存在的 因此,这里整理了利用python实现短信和电话提醒功能的方法 主要需要完成以下4个步骤: - 安装核心库:twilio - 注册账号及配置 - 发送短信示例 - 电话…

PID控制器开发笔记之三:抗积分饱和PID控制器的实现

积分作用的引入是为了消除系统的静差,提高控制精度。但是如果一个系统总是存在统一个方向的偏差,就可能无限累加而进而饱和,极大影响系统性能。抗积分饱和就是用以解决这一问题的方法之一。这一节我们就来实现抗积分饱和的PID算法。 1、抗积…

如何获取STM32 MCU的唯一ID

前段时间由于应用需要对产品授权进行限制,所以研究了一下有关STM32 MCU的唯一ID的资料,并最终利用它实现了我们的目标。 1、基本描述 在STM32的全系列MCU中均有一个96位的唯一设备标识符。在ST的相关资料中,对其功能的描述有3各方面&#x…

SHA256算法原理详解

1. SHA256简介 SHA256是SHA-2下细分出的一种算法 SHA-2,名称来自于安全散列算法2(英语:Secure Hash Algorithm 2)的缩写,一种密码散列函数算法标准,由美国国家安全局研发,属于SHA算法之一&…

学习笔记:区块链概念入门

本文是100天区块链学习计划的第二篇学习笔记,其实就是按照阮一峰的网络日志-区块链入门教程的讲解进行的简单梳理。也是时间有点紧张的原因,相比于上一篇SHA256算法原理详解,个人感觉质量和原创程度明显下降。待对区块链有了更深的理解后&…

PID控制器开发笔记之四:梯形积分PID控制器的实现

从微积分的基本原理看,积分的实现是在无限细分的情况下进行的矩形加和计算。但是在离散状态下,时间间隔已经足够大,矩形积分在某些时候显得精度要低了一些,于是梯形积分被提出来以提升积分精度。 1、梯形积分基本思路 在PID控制…

SHA256 的C语言实现

前几天总结了SHA256的算法原理一文 SHA2系列的原理并不复杂,但是需要注意细节还是挺多的。不少中文博客贴出的代码都有错,这两天也踩了几个坑。 代码在这里!!!SHA256的C Code 代码实现主要依照的这个git仓库crypto-…

信息摘要算法之一:MD5算法分析及实现

MD5即Message-DigestAlgorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。 1、MD5算法简介 MD5在90年代初由…

非对称加密概述

非对称加密概述 前言 在阅读《精通比特币》的过程中,我发现比特币系统中有两个重要的概念需要利用非对称加密技术: 比特币地址的生成 交易合法性的验证 因此,我用了几天时间学习了密码学基础知识,尤其是非对称加密技术的原理…