单片机调用printf概率性跑飞解决方法

最近移植软件到不同平台的单片机上时,遇到了软件概率性跑飞的问题,分析后原因均指向和printf相关的库函数(包括sprintf, vsnsprinft),在任务里调用这些函数就有概率在ucos切换任务时跑飞(中断)。增加堆栈大小等各种方法都不行。

后来各种查资料发现,可能是va_list功能不支持重入,被中断打断后,再次返回时无法恢复现场(也可能是任务切换函数写的有问题),继续运行printf时list中的内容被破坏,导致跑飞。

解决方法是自己实现printf函数,并在调用va_list功能时先关闭中断,退出va_list功能时再打开中断。sprintf等相关函数用同样方法处理即可。

复制代码
int my_printf(char* fmt, ...)
{
	va_list ap;
    int RetLen = 0;
    OS_CPU_SR cpu_sr;

    OS_ENTER_CRITICAL(); // 这里屏蔽中断
    
	va_start(ap, fmt);

    ...... // 实现代码

	va_end(ap);

    OS_EXIT_CRITICAL();

    return RetLen;
}
相关推荐
La Pulga5 小时前
【STM32】WDG看门狗
c语言·stm32·单片机·嵌入式硬件·mcu
普中科技6 小时前
【普中Hi3861开发攻略--基于鸿蒙OS】-- 第 29 章 WIFI 实验-TCP 通信
单片机·嵌入式硬件·tcp·liteos·hi3861·普中科技
hazy1k8 小时前
51单片机基础-ADC模数转换
stm32·单片机·嵌入式硬件·51单片机·1024程序员节
顾晨阳——9 小时前
GPIO总结
单片机·嵌入式硬件·gpio
嵌入式老牛9 小时前
【无标题】
单片机·嵌入式硬件·rtc
普中科技10 小时前
【普中DSP28335开发攻略】-- 第 9 章 蜂鸣器实验
单片机·嵌入式硬件·蜂鸣器·dsp28335·ccs·普中科技
ShiMetaPi10 小时前
操作【GM3568JHF】FPGA+ARM异构开发板 使用指南:串口
arm开发·单片机·嵌入式硬件·fpga开发·rk3568
点灯小铭11 小时前
基于单片机的两路PWM信号输出及频率占空比相位差调节系统
单片机·嵌入式硬件·毕业设计·课程设计·期末大作业
普中科技11 小时前
【普中STM32F1xx开发攻略--标准库版】-- 第 9 章 STM32 固件库介绍
stm32·单片机·嵌入式硬件·arm·普中科技·固件库
D.....l12 小时前
STM32学习(MCU控制)(DMA and ADC)
stm32·单片机·学习