实战经验:stm32cubMX自动生成遇到的坑爹问题(Freertos)

简介: 实战经验:stm32cubMX自动生成遇到的坑爹问题(Freertos)

我们来看这段程序:

640.png

上面这段程序,是串口2的中断服务函数,在这里面完成的是接收一帧\r\n的数据。


这样看来,这段程序保护得挺好,在串口在执行接收的过程中不会被中断打断。但如果不注意的话,会被坑,我们来看下面这种情况。


如果是使用stm32cubeMX生成代码,我们会看到在main.c中调用了串口初始化函数,在代码编写规则制定的区域定义了一个信号量,用于处理传感器数据。

640.png

这样看来没毛病,编程思路都是对的,但是灾难就快要发生了,于是我们在msp初始化函数里添加这么一段。

640.png

如果在串口初始化过后,传感器设备不通过串口发送数据,在未触发串口接收中断的时候,庆幸你的设备是可以正常开机运行的。


如果在串口初始化过后,传感器立马就上报数据给MCU,这时候你会突然发现,设备开不了机了?What?这是为什么?


断点调试后发现问题了,我们在这里发出了一个信号量,但信号量还没有初始化吧??

640.png

640.png

我们跟踪断点,进入xSemaphoreGiveFromISR这个函数,看看是为什么就卡死了呢?

640.png

这是一个宏,实际上是调用了xQueueGiveFromISR这个函数,我们继续跟进断点

640.png

我们再单步进这个断言:

640.png

结果发现死在这里了,这就说明我们并没有创建队列句柄。这就是stm32cubeMX给我们带来的坑爹问题了,既要按照它的要求来定义和编写代码,又要防止这样的问题产生。


那如何来解决这样的问题呢?其实很简单,加一个标志变量就可以了,在os没起来之前,我们不让发送信号量的这句话执行,等os起来以后,才让发送信号量这句话执行,否则会带来灾难性的结果。


在os还没有起来之前,我们还没有使用数据,而且信号量还没有创建,这时就不要使用os的信号量的发送和接收函数,于是想到一个解决办法,定义一个is_use_os变量,在os未起来之前这个标志为false,当os起来以后,这个标志就为true。

640.png

在中断服务函数里对标志进行判断:

640.jpg

这样,当os没启动之前,is_use_os这个变量为false,对应的代码不执行,当os启动以后,is_use_of这个变量为true。


我们再来看os启动以后,这个变量还是不是为NULL了?


我们先让代码跑到初始化任务里,这是也就标记着OS已经启动了。

640.jpg

然后再把断点打到刚刚串口中断接收的函数里。

640.png

然后单步进入看看

640.png

这时候我们发现,这个值已经不为NULL 了。


完美解决问题。

往期精彩

侃侃单片机的裸奔程序的框架


C语言将xxx.bin文件转为数组


数组和指针一道非常值得深思的笔试题


开源按键组件MultiButton支持菜单操作(事件驱动型)


第1期 | MultiButton,一个小巧简单易用的事件驱动型按键驱动模块

目录
相关文章
|
9月前
|
存储 数据安全/隐私保护
STM32实战项目—密码锁
本文完整详细地介绍了一个密码锁项目的要求,设计思路,程序实现,问题总结和成果展示内容。
193 2
STM32实战项目—密码锁
|
2月前
|
消息中间件 Web App开发 API
FreeRTOS介绍 和 将FreeRTOS移植到STM32F103C8T6
FreeRTOS介绍 和 将FreeRTOS移植到STM32F103C8T6
FreeRTOS介绍 和 将FreeRTOS移植到STM32F103C8T6
|
2天前
|
传感器 编解码 API
【STM32开发入门】温湿度监测系统实战:SPI LCD显示、HAL库应用、GPIO配置、UART中断接收、ADC采集与串口通信全解析
SPI(Serial Peripheral Interface)是一种同步串行通信接口,常用于微控制器与外围设备间的数据传输。SPI LCD是指使用SPI接口与微控制器通信的液晶显示屏。这类LCD通常具有较少的引脚(通常4个:MISO、MOSI、SCK和SS),因此在引脚资源有限的系统中非常有用。通过SPI协议,微控制器可以向LCD发送命令和数据,控制显示内容和模式。
|
2月前
|
中间件 编译器 调度
STM32cubemx对FreeRTOS的适配(工程模板配置)
STM32cubemx对FreeRTOS的适配(工程模板配置)
136 0
|
9月前
|
存储 索引
STM32实战项目—停车计费系统
本文详细介绍了一个停车计费系统的任务要求,实现思路。最后,给出了详细的程序设计和测试结果。
189 2
STM32实战项目—停车计费系统
|
9月前
STM32实战项目—楼宇人员计数系统
本文介绍了一个基于红外对管的楼宇人员计数系统设计。简单介绍了一下红外对管的原理和使用方法。针对任务要求给出了详细的实现思路和程序设计。
57 3
STM32实战项目—楼宇人员计数系统
|
9月前
|
运维 小程序 API
STM32实战项目—WIFI远程开关灯
本文介绍了如何利用正点原子ESP8266和STM32F103C8T6连接腾讯云,利用舵机实现远程开关灯。给出了详细的腾讯云配置和调试步骤,给出了部分程序设计。
191 0
STM32实战项目—WIFI远程开关灯
No.5 STM32F429IGT6 标准库实战GPIO输出LED灯 点亮闪烁(STM32F429/F767/H743)
No.5 STM32F429IGT6 标准库实战GPIO输出LED灯 点亮闪烁(STM32F429/F767/H743)
|
10月前
|
传感器 物联网 芯片
超轻量级网红软件定时器multi_timer(51+stm32双平台实战)
超轻量级网红软件定时器multi_timer(51+stm32双平台实战)
327 0