FreeRTOS实验_线程安全和中断安全printf方式

单片机相关 徐 自远 1213℃

很多嵌入式开发人员都喜欢在开发过程中利用串口进行调试,这在裸机程序中无疑是很方便的。但是在搭载操作系统,使用多线程的情况下,几个线程同时打印数据甚至在打印过程中产生了中断并且中断程序中也要打印数据,这就难免发生数据交叉打印的现象。

下面就详细说明一下,如何解决这种问题。

首先,我们来看如何利用串口将printf数据显示到电脑的终端上。

由于printf最终是调用fputc实现一个字节一个字节的输出,所以我们只要重写fputc函数即可:

这样用串口助手连接到STM32的串口1就可以看到打印信息了。

实现串口重定向之后,我们就来看一下如何实现线程安全了。

首先我们来参考一下printf的源码:

但是这样做也只是在printf的基础上封装了一层线程安全机制,难免效率会很低。

接下来我们对它进行进一步改进,直接将要打印的数据从串口1发送出去:

这样线程安全的printf就构建好了,但是在实际使用过程中却发现,该函数不能用在中断里面,原因就是osThreadSuspendAll()和osThreadResumeAll()是非中断安全的。

仔细想一下,在中断里面我们是不需要挂起线程的;当然了,在打印过程中也不希望进入中断,想清楚这些我们就可以进一步改造了。

首先我们要清楚的是,调用该函数的是线程还是中断:

当然了,如果你觉得每次打印东西的时候就把其它线程挂起太浪费资源了。

OK,到此为止线程安全,中断安全的printf函数就封装好了。

转载请注明:徐自远的乱七八糟小站 » FreeRTOS实验_线程安全和中断安全printf方式

喜欢 (0)

苏ICP备18041234号-1 bei_an 苏公网安备 32021402001397号