stm32 cubemx freertos 中断二值信号量卡死问题

功能: 按键中断里面释放二值信号量,  然后点亮LED灯

问题: 卡在xSemaphoreGiveFromISR

代码:

void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin){
	  uint32_t ulReturn;
		BaseType_t pxHigherPriorityTaskWoken;
	  /* 进入临界段,临界段可以嵌套 */
  ulReturn = taskENTER_CRITICAL_FROM_ISR();
	
	if(GPIO_Pin == KEY1_Pin){

		BaseType_t pxHigherPriorityTaskWoken;
	  xSemaphoreGiveFromISR(BinarySem_Handle,&pxHigherPriorityTaskWoken);	//释放二值信号量
		//如果需要的话进行一次任务切换
		portYIELD_FROM_ISR(pxHigherPriorityTaskWoken);
	}
	  /* 退出临界段 */
  taskEXIT_CRITICAL_FROM_ISR( ulReturn );
}

static void LED_Task(void* parameter)
{	
	BaseType_t xReturn = pdPASS;/* 定义一个创建信息返回值,默认为pdPASS */
  uint32_t r_queue;	/* 定义一个接收消息的变量 */

  while (1)
  {
    //获取二值信号量 xSemaphore,没获取到则一直等待
		xReturn = xSemaphoreTake(BinarySem_Handle,/* 二值信号量句柄 */
                              portMAX_DELAY); /* 等待时间 */
    if(pdPASS == xReturn)
    {

      printf("收到数据");

    }
		
		
		HAL_GPIO_WritePin( LED0_GPIO_Port,LED0_Pin,0);
    vTaskDelay(500);   /* 延时500个tick */
    
    HAL_GPIO_WritePin( LED0_GPIO_Port,LED0_Pin,1);;     
    vTaskDelay(500);   /* 延时500个tick */
  }
}

  /* EXTI interrupt init*/
  HAL_NVIC_SetPriority(EXTI0_IRQn, 0, 0);
  HAL_NVIC_EnableIRQ(EXTI0_IRQn);

解决方案:  按键抢占优先级太高了,导致rtos不能抢占, 所以改低抢占优先级为7就可以

  /* EXTI interrupt init*/
  HAL_NVIC_SetPriority(EXTI0_IRQn, 7, 0);
  HAL_NVIC_EnableIRQ(EXTI0_IRQn);

 

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值