在做项目中,遇到了同时调用串口通信时程序崩溃的问题,在项目中,串口1用作调试串口,串口2用作MQTT通信串口,串口3用作下位机通信串口,
串口1重定向以后,用库函数自带的printf函数打印字符串
串口2使用自己写的u2_printf函数,即va_list这套变参宏定义后使用vsprintf函数打印字符串
串口3刚开始使用串口2一样的打印方式,程序在调试调用到串口3打印函数时直接崩溃,后续将串口3改用dma转存输出,仍然无法正常调用
多次研究以后,采用三个串口都使用重定向后的库函数自带的printf函数进行输出,问题得以解决,该方法可以灵活运用于多个串口输出的情况下
现将各个模块代码进行分析:
首先介绍一下串口初始化部分
串口初始化需要使能串口,使能所用的gpio引脚,若是收发模式,还需配置中断部分,代码为:
串口1初始化:
该程序为了修改方便,先定义了串口指针
USART_TypeDef * DEBUG_USARTx = USART1; //定义串口指针,通过指针指到使用串口的各个寄存器,(SR状态寄存器,DR数据寄存器)
void USART_Config(void)
{
uart1_init(9600);
uart2_init(115200);
uart3_init(115200);
}//配置波特率函数
void uart1_init(u32 bt)
{
GPIO_InitTypeDef GPIO_InitStructure; //声明一个结构体变量,用来初始化GPIO
NVIC_InitTypeDef NVIC_InitStructure; //中断结构体定义
USART_In

在项目中遇到串口通信崩溃的问题,通过重定向库函数printf到不同串口解决。串口1用于调试,串口2用于MQTT,串口3起初引起崩溃,后改用DMA仍无效。最终所有串口使用统一的printf重定向方法,问题解决。串口初始化涉及GPIO配置、中断设置和波特率设定。

6355

被折叠的 条评论
为什么被折叠?



