stm32 freeRTOS 互斥量实验 (HAL版)

stm32 freeRTOS 互斥量实验 (HAL版)

本实验是通过创建一个互斥量和三个优先级不同的任务来通过不同任务对互斥量的信号量的获取和释放来实现的,实现现象是通过LED灯的闪烁和串口的输出来显示的。

HAL配置:

在这里插入图片描述
这个是互斥量的配置。
以及三个任务的配置
在这里插入图片描述

主要需要调用的API

在这里插入图片描述

实验主要代码:

void StartTask_Low(void *argument)
{
  /* USER CODE BEGIN StartTask_Low */
  osStatus_t xReturn;
  int i;
  /* Infinite loop */
  for(;;)
  {
    xReturn=osMutexAcquire(myMutex_TestHandle,portMAX_DELAY);
    if(xReturn==osOK)
    {
      printf("低优先级获得信号量\r\n");
    }
    for(i=0;i<0xffff;i++)
    {
      HAL_GPIO_TogglePin(GPIOB,GPIO_PIN_0);
    }
    xReturn=osMutexRelease(myMutex_TestHandle);
		if(xReturn==osOK)
    {
      printf("低优先级释放信号量\r\n");
    }
    osDelay(1);
  }
  /* USER CODE END StartTask_Low */
}

/* USER CODE BEGIN Header_StartTask_Normal */
/**
* @brief Function implementing the myTask_Normal thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask_Normal */
void StartTask_Normal(void *argument)
{
  /* USER CODE BEGIN StartTask_Normal */
  /* Infinite loop */
  for(;;)
  {
    printf("中优先级启动\r\n");
    vTaskDelay(1000);
    osDelay(1);
  }
  /* USER CODE END StartTask_Normal */
}

/* USER CODE BEGIN Header_StartTask_High */
/**
* @brief Function implementing the myTask_High thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask_High */
void StartTask_High(void *argument)
{
  /* USER CODE BEGIN StartTask_High */
  osStatus_t xReturn;
  int i;
  /* Infinite loop */
  for(;;)
  {
    xReturn=osMutexAcquire(myMutex_TestHandle,portMAX_DELAY);
    if(xReturn==osOK)
    {
      printf("最高优先级获得信号量\r\n");
    }
     for(i=0;i<50;i++)
    {
      HAL_GPIO_TogglePin(GPIOB,GPIO_PIN_1);
      vTaskDelay(100);
    }
		xReturn=osMutexRelease(myMutex_TestHandle);
		if(xReturn==osOK)
    {
      printf("最高优先级释放信号量\r\n");
    }
    osDelay(1);
  }
  /* USER CODE END StartTask_High */
}

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 */

/* 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_Low */
osThreadId_t myTask_LowHandle;
const osThreadAttr_t myTask_Low_attributes = {
  .name = "myTask_Low",
  .priority = (osPriority_t) osPriorityLow,
  .stack_size = 128 * 4
};
/* Definitions for myTask_Normal */
osThreadId_t myTask_NormalHandle;
const osThreadAttr_t myTask_Normal_attributes = {
  .name = "myTask_Normal",
  .priority = (osPriority_t) osPriorityNormal,
  .stack_size = 128 * 4
};
/* Definitions for myTask_High */
osThreadId_t myTask_HighHandle;
const osThreadAttr_t myTask_High_attributes = {
  .name = "myTask_High",
  .priority = (osPriority_t) osPriorityHigh,
  .stack_size = 128 * 4
};
/* Definitions for myMutex_Test */
osMutexId_t myMutex_TestHandle;
const osMutexAttr_t myMutex_Test_attributes = {
  .name = "myMutex_Test"
};

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

/* USER CODE END FunctionPrototypes */

void StartDefaultTask(void *argument);
void StartTask_Low(void *argument);
void StartTask_Normal(void *argument);
void StartTask_High(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 */
  /* Create the mutex(es) */
  /* creation of myMutex_Test */
  myMutex_TestHandle = osMutexNew(&myMutex_Test_attributes);

  /* 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_Low */
  myTask_LowHandle = osThreadNew(StartTask_Low, NULL, &myTask_Low_attributes);

  /* creation of myTask_Normal */
  myTask_NormalHandle = osThreadNew(StartTask_Normal, NULL, &myTask_Normal_attributes);

  /* creation of myTask_High */
  myTask_HighHandle = osThreadNew(StartTask_High, NULL, &myTask_High_attributes);

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

}

/* 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_Low */
/**
* @brief Function implementing the myTask_Low thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask_Low */
void StartTask_Low(void *argument)
{
  /* USER CODE BEGIN StartTask_Low */
  osStatus_t xReturn;
  int i;
  /* Infinite loop */
  for(;;)
  {
    xReturn=osMutexAcquire(myMutex_TestHandle,portMAX_DELAY);
    if(xReturn==osOK)
    {
      printf("低优先级获得信号量\r\n");
    }
    for(i=0;i<0xffff;i++)
    {
      HAL_GPIO_TogglePin(GPIOB,GPIO_PIN_0);
    }
    xReturn=osMutexRelease(myMutex_TestHandle);
		if(xReturn==osOK)
    {
      printf("低优先级释放信号量\r\n");
    }
    osDelay(1);
  }
  /* USER CODE END StartTask_Low */
}

/* USER CODE BEGIN Header_StartTask_Normal */
/**
* @brief Function implementing the myTask_Normal thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask_Normal */
void StartTask_Normal(void *argument)
{
  /* USER CODE BEGIN StartTask_Normal */
  /* Infinite loop */
  for(;;)
  {
    printf("中优先级启动\r\n");
    vTaskDelay(1000);
    osDelay(1);
  }
  /* USER CODE END StartTask_Normal */
}

/* USER CODE BEGIN Header_StartTask_High */
/**
* @brief Function implementing the myTask_High thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask_High */
void StartTask_High(void *argument)
{
  /* USER CODE BEGIN StartTask_High */
  osStatus_t xReturn;
  int i;
  /* Infinite loop */
  for(;;)
  {
    xReturn=osMutexAcquire(myMutex_TestHandle,portMAX_DELAY);
    if(xReturn==osOK)
    {
      printf("最高优先级获得信号量\r\n");
    }
     for(i=0;i<50;i++)
    {
      HAL_GPIO_TogglePin(GPIOB,GPIO_PIN_1);
      vTaskDelay(100);
    }
		xReturn=osMutexRelease(myMutex_TestHandle);
		if(xReturn==osOK)
    {
      printf("最高优先级释放信号量\r\n");
    }
    osDelay(1);
  }
  /* USER CODE END StartTask_High */
}

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

/* USER CODE END Application */

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

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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实验让我们深入了解了嵌入式系统分析和调试的方法和工具,有助于我们更好地理解嵌入式系统的工作原理,提高嵌入式系统的可靠性和性能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值