【FreeRTOS篇】互斥量

一、什么是互斥量?

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

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

二、什么是优先级翻转?

系统中有3个不同优先级的任务H/M/L,最高优先级任务H和最低优先级任务L通过信号量机制,共享资源。目前任务L占有资源,锁定了信号量,Task H运行后将被阻塞,直到Task L释放信号量后,Task H才能够退出阻塞状态继续运行。但是Task H在等待Task L释放信号量的过程中,中等优先级任务M抢占了任务L,从而延迟了信号量的释放时间,导致Task H阻塞了更长时间,这种现象称为优先级倒置或反转

三、互斥量相关 API 函数

1.创建互斥量

SemaphoreHandle_t xSemaphoreCreateMutex( void );

参数:
无
返回值:
成功,返回对应互斥量的句柄;
失败,返回 NULL 。

2.释放互斥信号量

BaseType_t xSemaphoreGive( SemaphoreHandle_t xSemaphore );

参数:
xSemaphore:要释放的信号量句柄
返回值:
成功,返回 pdPASS ;
失败,返回 errQUEUE_FULL 。

3.获取互斥信号量

BaseType_t xSemaphoreTake( SemaphoreHandle_t xSemaphore,
                            TickType_t xTicksToWait );

参数:
xSemaphore:要获取的信号量句柄
xTicksToWait:超时时间,0 表示不超时,portMAX_DELAY表示卡死等待;
返回值:
成功,返回 pdPASS ;失败,返回 errQUEUE_FULL 。

四、实操

•实验需求:

1. 演示优先级翻转

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

•cubeMX配置

•编程实现 

void StartTaskH(void const * argument)
{
  /* USER CODE BEGIN StartTaskH */
  /* Infinite loop */
  for(;;)
  {
		xSemaphoreTake(myMutexHandle,portMAX_DELAY);
		printf("TaskH:我开始进入厕所,发功中...\r\n");
		HAL_Delay(1000);
		printf("TaskH:我上完厕所了,真舒服...\r\n");
		xSemaphoreGive(myMutexHandle);
    osDelay(1000);
  }
  /* USER CODE END StartTaskH */
}

void StartTaskM(void const * argument)
{
  /* USER CODE BEGIN StartTaskM */
  /* Infinite loop */
  for(;;)
  {
		printf("TaskM:我就是为了占有CPU资源,带女朋友去兜风\r\n");
    osDelay(1000);
  }
  /* USER CODE END StartTaskM */
}

void StartTaskL(void const * argument)
{
  /* USER CODE BEGIN StartTaskL */
  /* Infinite loop */
  for(;;)
  {
		xSemaphoreTake(myMutexHandle,portMAX_DELAY);
		printf("TaskL:我开始进入厕所,发功中...\r\n");
		HAL_Delay(3000);
		printf("TaskL:我上完厕所了,真舒服...\r\n");
		xSemaphoreGive(myMutexHandle);
    osDelay(1000);
  }
  /* USER CODE END StartTaskL */
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿gao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值