STM32 FreeRTOS 第一个实验例子:LED闪灯(任务队列)

软件环境:IDE Keil5+CubeMx5.1

硬件环境:STM32F103ZE

 

吐槽一下:

CubeMx我最早用的是4.2版本,后来开始使用5.0.1版本,结果发现如果工程路径中有中文在生成代码时就会报错,而且在打开和保存文件时可以看到所有中文文件夹都无法正常显示,没办法只能把有关路径都改为英文。今天在网上看到有5.1版本了,可以支持中文了,赶紧下载并安装。运行后点击File->Load Project,发现确实可以显示中文。然后就开始研究FreeRTOS了,先做一个闪灯的程序,因此建了个文件夹“闪灯”,配置完后生成工程,结果发现还是报错,说明ST软件升级后显示问题解决了,但是还是存在BUG。无奈把文件夹名称改为英文。

废话不说了进入正题。

第一个实验例子:LED闪灯

先在CubeMx做相关配置这里就不多说了,关键是配置FreeRTOS:

         在Pinout & Configuration下的Middleware中选择FREERTOS,如下图:

添加2个Task:

第一个任务配置为:

任务名:MsgProducter,

优先级:osPriorityNormal,

任务堆栈:128,

函数名:MsgProducterTask

第二个任务配置为:

任务名:MsgConsumer,

优先级:osPriorityNormal,

任务堆栈:128,

函数名:MsgConsumerTask

 

再添加一个任务队列myQ01,深度 16字,每个单元数据类型uint16_t。

 

然后保存并生成工程。

在keil5中添加代码:

  1. 找到freertos.c;
  2. 给MsgProducterTask添加代码:

/* USER CODE BEGIN Header_MsgProducterTask */

/**

  * @brief  Function implementing the MsgProducter thread.

  * @param  argument: Not used

  * @retval None

  */

/* USER CODE END Header_MsgProducterTask */

void MsgProducterTask(void const * argument)

{

  /* init code for FATFS */

  MX_FATFS_Init();

 

  /* init code for USB_DEVICE */

  MX_USB_DEVICE_Init();

 

  /* USER CODE BEGIN MsgProducterTask */

  /* Infinite loop */

  for(;;)

  {

                  

    osDelay(1000);

                   osMessagePut(myQ01Handle,1,osWaitForever);

    osDelay(1000);

                   osMessagePut(myQ01Handle,3,osWaitForever);

    osDelay(1000);

                   osMessagePut(myQ01Handle,5,osWaitForever);

    osDelay(2000);

  }

  /* USER CODE END MsgProducterTask */

}

 

  1. 给MsgConsumerTask添加代码

/* USER CODE BEGIN Header_MsgConsumerTask */

/**

* @brief Function implementing the MsgConsumer thread.

* @param argument: Not used

* @retval None

*/

/* USER CODE END Header_MsgConsumerTask */

void MsgConsumerTask(void const * argument)

{

  /* USER CODE BEGIN MsgConsumerTask */

         osEvent osevent;

  /* Infinite loop */

  for(;;)

  {

                   osevent= osMessageGet( myQ01Handle,osWaitForever);

                   if(osevent.status==osEventMessage)

                   {

                            while(osevent.value.v--)

                            {

                                     HAL_GPIO_WritePin( LED1_GPIO_Port,LED1_Pin,GPIO_PIN_RESET);

                                     HAL_GPIO_WritePin( LED2_GPIO_Port,LED2_Pin,GPIO_PIN_RESET);

                                     osDelay(100);

                                     HAL_GPIO_WritePin( LED1_GPIO_Port,LED1_Pin,GPIO_PIN_SET);

                                     HAL_GPIO_WritePin( LED2_GPIO_Port,LED2_Pin,GPIO_PIN_SET);

                                     osDelay(100);

                            }

                   }

  }

  /* USER CODE END MsgConsumerTask */

}

 

  1. 编译、下载后运行,发现LED先闪1次,一秒后再闪3次,等一秒又闪5次,如此循环。

 

 

至此第一的例程完成。是不是有点感觉,由于采用CubeMx,确实减少了很多工作量。

  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值