stm32——freeRTOS互斥量

一、什么是互斥量?

         在多数情况下,互斥型信号量和二值型信号量非常相似,但是从功能上二值型信号量用于同步,而互斥型信号量用于资源保护。

        互斥型信号量和二值型信号量还有一个最大的区别,互斥型信号量可以有效解决优先级反转现象。

二、什么是优先级翻转

        当高优先级任务正等待信号量(此信号量被一个低优先级任务拥有着)的时候,一个介于两个任务优先之间的中等优先级任务开始执行——这就会导致一个高优先级任务在等待一个低优先级任务,而低优先级任务却无法执行类似死锁的情形发生。 

         优先级继承:优先级继承就是为了解决优先级反转问题而提出的一种优化机制。 当一个互斥量正在被一个低优先级的任务持有时,如果此时有个高优先级的任务也尝试获取这个互斥量,那么这个高优先级的任务会被阻塞。不过这个高优先级的任务会将低优先级任务的优先级提升到与自己相同的优先级。临时提升其优先级。以前其能更快的执行并释放同步资源。释放同步资源后再恢复其原来的优先级。

        优先级继承并不能完全消除优先级翻转的问题,它只是尽可能的降低优先级翻转带来的影响。

三、互斥量相关api函数

         互斥量不能用于中断服务函数中。

函数
        描述
xSemaphoreCreateMutex()
        使用动态方法创建互斥信号量。
xSemaphoreCreateMutexStatic()
        使用静态方法创建互斥信号量。
SemaphoreHandle_t xSemaphoreCreateMutex( void )

 参数:无

返回值:

        互斥量创建成功,返回对应互斥量的句柄;

        失败,返回NULL

四、 实际代码演示:

需求: 

        1、演示优先级翻转

        2、使用互斥量优化优先级翻转问题。

——优先级翻转代码演示如下——

cubeMX 

1、创建任务(3个不同优先级的任务)

 

2、创建一个二值信号量

 keil5:

 运行结果:即使低优先级任务拥有信号量,中优先级任务依旧会打断运行。

 ——使用互斥量优化翻转问题——

1、cubeMX

删除创建的二值信号量

创建一个互斥量:

 keil5(将获取、放回信号量的句柄改为互斥量的句柄)

 运行结果:

 可以看到,中优先级抢占不了低优先级的cpu进行运行。低优先级可以完整运行

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用STM32CubeMX配置FreeRTOS时,你可以使用互斥锁来实现多任务之间的互斥访问。互斥锁是一种同步机制,它可以确保在任何给定时间只有一个任务可以访问共享资源。 要在FreeRTOS中使用互斥锁,你需要进行以下步骤: 1. 在STM32CubeMX中打开项目配置。 2. 打开RTE(Run-Time Environment)配置窗口。 3. 在RTE组件中搜索"mutex"或"互斥锁",并选择适合你的微控制器的互斥锁组件。 4. 为你的任务创建互斥锁。 创建互斥锁的代码示例: ```c #include "cmsis_os.h" // 声明互斥锁句柄 osMutexId mutexHandle; // 在任务初始化函数中创建互斥锁 void task_init(void const * argument) { // 创建互斥锁 osMutexDef(mutex); mutexHandle = osMutexCreate(osMutex(mutex)); // ... } // 在任务中使用互斥锁 void task_example(void const * argument) { // 等待获取互斥锁 if(osMutexWait(mutexHandle, osWaitForever) == osOK) { // 临界区代码 // ... // 释放互斥锁 osMutexRelease(mutexHandle); } // ... } ``` 在上面的示例中,首先在任务初始化函数中创建了一个互斥锁,然后在任务中使用了该互斥锁来保护临界区代码。使用`osMutexWait`函数等待获取互斥锁,如果成功获取到互斥锁,则进入临界区代码执行,并在临界区代码执行完毕后使用`osMutexRelease`函数释放互斥锁。 这样就可以确保只有一个任务可以同时访问被保护的临界区代码,从而实现了任务间的互斥访问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值