stm32 cubemx freertos 中断二值信号量卡死问题【杂记】

文章讲述了在使用按键中断时,由于抢占优先级过高导致RTOS无法正常响应。通过将EXTI0_IRQn的抢占优先级从0降低到7,解决了xSemaphoreGiveFromISR在ISR中的问题,LED灯能正确响应按键输入。
摘要由CSDN通过智能技术生成

功能: 按键中断里面释放二值信号量,  然后点亮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);


 
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值