stm32 freeRTOS 事件实验 (HAL版)

stm32 freeRTOS 事件实验 (HAL版)

此实验是在freertos中创建一个事件,两个任务。两个任务分别是按键和LED灯。实验流程是,当任何一个按键按下时,LED1翻转,当两个都按下时,LED2翻转,同时通过串口反应出当前状态。

HAL配置

在这里插入图片描述
事件的配置,其余配置同之前文章。

主要需要调用的API

在这里插入图片描述

实验主要代码:

void StartTask_Key(void *argument)
{
  /* USER CODE BEGIN StartTask_Key */
  /* Infinite loop */
  for(;;)
  {
    if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_0)==1)
    {
      printf("事件一设置成功\r\n");
      osEventFlagsSet(myEvent_TestHandle,event1);
      while(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_0)==1);
    }
    if(HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_13)==1)
    {
      printf("事件二设置成功\r\n");
      osEventFlagsSet(myEvent_TestHandle,event2);
      while(HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_13)==1);
    }
    osDelay(20);
  }
  /* USER CODE END StartTask_Key */
}

/* USER CODE BEGIN Header_StartTask_LED */
/**
* @brief Function implementing the myTask_LED thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask_LED */
void StartTask_LED(void *argument)
{
  /* USER CODE BEGIN StartTask_LED */
  uint32_t xReturn_1;
  /* Infinite loop */
  for(;;)
  {
    xReturn_1=osEventFlagsWait(myEvent_TestHandle,event1|event2,osFlagsWaitAny|osFlagsNoClear,osWaitForever);
    if((xReturn_1 & (event1))==(event1)||(xReturn_1 & (event2))==(event2))
    {
      HAL_GPIO_TogglePin(GPIOB,GPIO_PIN_0);
      printf("响应一个按键成功\r\n");
    }

    xReturn_1=osEventFlagsWait(myEvent_TestHandle,event1|event2,osFlagsWaitAll,portMAX_DELAY);
    if((xReturn_1 & (event1|event2))==(event1|event2))
    {
      HAL_GPIO_TogglePin(GPIOB,GPIO_PIN_1);
      printf("响应两个按键成功\r\n");
    }

    // osDelay(1);
  }

freertos.c

/* USER CODE BEGIN Header */
/**
  ******************************************************************************
  * File Name          : freertos.c
  * Description        : Code for freertos applications
  ******************************************************************************
  * @attention
  *
  * <h2><center>&copy; Copyright (c) 2022 STMicroelectronics.
  * All rights reserved.</center></h2>
  *
  * This software component is licensed by ST under Ultimate Liberty license
  * SLA0044, the "License"; You may not use this file except in compliance with
  * the License. You may obtain a copy of the License at:
  *                             www.st.com/SLA0044
  *
  ******************************************************************************
  */
/* USER CODE END Header */

/* Includes ------------------------------------------------------------------*/
#include "FreeRTOS.h"
#include "task.h"
#include "main.h"
#include "cmsis_os.h"

/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */
#include "usart.h"
/* USER CODE END Includes */

/* Private typedef -----------------------------------------------------------*/
/* USER CODE BEGIN PTD */

/* USER CODE END PTD */

/* Private define ------------------------------------------------------------*/
/* USER CODE BEGIN PD */

/* USER CODE END PD */

/* Private macro -------------------------------------------------------------*/
/* USER CODE BEGIN PM */

/* USER CODE END PM */

/* Private variables ---------------------------------------------------------*/
/* USER CODE BEGIN Variables */
#define event1 1<<1//事件1
#define event2 1<<2//事件2
/* USER CODE END Variables */
/* Definitions for defaultTask */
osThreadId_t defaultTaskHandle;
const osThreadAttr_t defaultTask_attributes = {
  .name = "defaultTask",
  .priority = (osPriority_t) osPriorityNormal,
  .stack_size = 128 * 4
};
/* Definitions for myTask_Key */
osThreadId_t myTask_KeyHandle;
const osThreadAttr_t myTask_Key_attributes = {
  .name = "myTask_Key",
  .priority = (osPriority_t) osPriorityNormal,
  .stack_size = 128 * 4
};
/* Definitions for myTask_LED */
osThreadId_t myTask_LEDHandle;
const osThreadAttr_t myTask_LED_attributes = {
  .name = "myTask_LED",
  .priority = (osPriority_t) osPriorityNormal,
  .stack_size = 128 * 4
};
/* Definitions for myEvent_Test */
osEventFlagsId_t myEvent_TestHandle;
const osEventFlagsAttr_t myEvent_Test_attributes = {
  .name = "myEvent_Test"
};

/* Private function prototypes -----------------------------------------------*/
/* USER CODE BEGIN FunctionPrototypes */

/* USER CODE END FunctionPrototypes */

void StartDefaultTask(void *argument);
void StartTask_Key(void *argument);
void StartTask_LED(void *argument);

void MX_FREERTOS_Init(void); /* (MISRA C 2004 rule 8.1) */

/**
  * @brief  FreeRTOS initialization
  * @param  None
  * @retval None
  */
void MX_FREERTOS_Init(void) {
  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* USER CODE BEGIN RTOS_MUTEX */
  /* add mutexes, ... */
  /* USER CODE END RTOS_MUTEX */

  /* USER CODE BEGIN RTOS_SEMAPHORES */
  /* add semaphores, ... */
  /* USER CODE END RTOS_SEMAPHORES */

  /* USER CODE BEGIN RTOS_TIMERS */
  /* start timers, add new ones, ... */
  /* USER CODE END RTOS_TIMERS */

  /* USER CODE BEGIN RTOS_QUEUES */
  /* add queues, ... */
  /* USER CODE END RTOS_QUEUES */

  /* Create the thread(s) */
  /* creation of defaultTask */
  defaultTaskHandle = osThreadNew(StartDefaultTask, NULL, &defaultTask_attributes);

  /* creation of myTask_Key */
  myTask_KeyHandle = osThreadNew(StartTask_Key, NULL, &myTask_Key_attributes);

  /* creation of myTask_LED */
  myTask_LEDHandle = osThreadNew(StartTask_LED, NULL, &myTask_LED_attributes);

  /* USER CODE BEGIN RTOS_THREADS */
  /* add threads, ... */
  /* USER CODE END RTOS_THREADS */

  /* Create the event(s) */
  /* creation of myEvent_Test */
  myEvent_TestHandle = osEventFlagsNew(&myEvent_Test_attributes);

  /* USER CODE BEGIN RTOS_EVENTS */
  /* add events, ... */
  /* USER CODE END RTOS_EVENTS */

}

/* USER CODE BEGIN Header_StartDefaultTask */
/**
  * @brief  Function implementing the defaultTask thread.
  * @param  argument: Not used
  * @retval None
  */
/* USER CODE END Header_StartDefaultTask */
void StartDefaultTask(void *argument)
{
  /* USER CODE BEGIN StartDefaultTask */
  /* Infinite loop */
  for(;;)
  {
    osDelay(1);
  }
  /* USER CODE END StartDefaultTask */
}

/* USER CODE BEGIN Header_StartTask_Key */
/**
* @brief Function implementing the myTask_Key thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask_Key */
void StartTask_Key(void *argument)
{
  /* USER CODE BEGIN StartTask_Key */
  /* Infinite loop */
  for(;;)
  {
    if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_0)==1)
    {
      printf("事件一设置成功\r\n");
      osEventFlagsSet(myEvent_TestHandle,event1);
      while(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_0)==1);
    }
    if(HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_13)==1)
    {
      printf("事件二设置成功\r\n");
      osEventFlagsSet(myEvent_TestHandle,event2);
      while(HAL_GPIO_ReadPin(GPIOC,GPIO_PIN_13)==1);
    }
    osDelay(20);
  }
  /* USER CODE END StartTask_Key */
}

/* USER CODE BEGIN Header_StartTask_LED */
/**
* @brief Function implementing the myTask_LED thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask_LED */
void StartTask_LED(void *argument)
{
  /* USER CODE BEGIN StartTask_LED */
  uint32_t xReturn_1;
  /* Infinite loop */
  for(;;)
  {
    xReturn_1=osEventFlagsWait(myEvent_TestHandle,event1|event2,osFlagsWaitAny|osFlagsNoClear,osWaitForever);
    if((xReturn_1 & (event1))==(event1)||(xReturn_1 & (event2))==(event2))
    {
      HAL_GPIO_TogglePin(GPIOB,GPIO_PIN_0);
      printf("响应一个按键成功\r\n");
    }

    xReturn_1=osEventFlagsWait(myEvent_TestHandle,event1|event2,osFlagsWaitAll,portMAX_DELAY);
    if((xReturn_1 & (event1|event2))==(event1|event2))
    {
      HAL_GPIO_TogglePin(GPIOB,GPIO_PIN_1);
      printf("响应两个按键成功\r\n");
    }

    // osDelay(1);
  }
  /* USER CODE END StartTask_LED */
}

/* Private application code --------------------------------------------------*/
/* USER CODE BEGIN Application */

/* USER CODE END Application */

/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/

实验现象:

在这里插入图片描述

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: STM32是一款微控制器,它的复杂程度和能力都取决于它的固件库和支持软件。FreeRTOS是一款实时操作系统,能够在嵌入式系统中管理任务和资源。Tracealyzer是一种用于调试和性能分析的软件,它通过收集和分析实时数据流,使用户能够更好地了解系统的行为和性能。 进行STM32 FreeRTOS Tracealyzer实验时,我们会导入Tracealyzer插件,并且在整个系统的各个层面集成较高的可观测性,这使得我们能够收集关键系统事件,包括任务的调度、事件的等待和释放、内存堆管理、中断和通信。Tracealyzer还能在数据可视化方面进行相应的支持,以帮助用户更好地理解数据。同时,在调试期间,还可以在Tracealyzer中启用多种实用程序和分析工具,以找出性能瓶颈和问题,并加以优化。 总体来说,进行STM32 FreeRTOS Tracealyzer实验能够帮助我们深入理解嵌入式系统的性能和行为,从而更好地进行调试和优化。Tracealyzer插件及其支持的功能将使开发人员更轻松地检测和解决问题,从而显著提高系统的性能和稳定性,为用户提供更好的产品体验。 ### 回答2: 在STM32 FreeRTOS Tracealyzer实验中,我们学习如何使用Percepio Tracealyzer工具对嵌入式系统进行分析和调试。该工具可以通过USB连接,实时捕获FreeRTOS任务和ISR的事件,并以图表和日志的形式呈现给用户。我们在实验中使用了STM32F4Discovery开发板和FreeRTOS操作系统。 经过实验,我们发现Tracealyzer可以帮助我们及时发现系统中出现的问题和瓶颈,并精确定位问题所在。例如,我们可以通过任务的启动和结束时间差来确定是否存在任务瓶颈,通过堆栈使用情况来发现内存泄漏,通过ISR调度时间来分析系统响应等问题。 此外,Tracealyzer还提供了可视化的分析工具,如任务时间轴,CPU利用率图表和队列统计图等,这些图表能够帮助我们直观地了解系统运行情况和性能瓶颈。 总的来说,STM32 FreeRTOS Tracealyzer实验让我们深入了解了嵌入式系统分析和调试的方法和工具,有助于我们更好地理解嵌入式系统的工作原理,提高嵌入式系统的可靠性和性能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值