STM32 FreeRTOS 第二个实验例子:串口转发(单字节转发)

第二个实验例子:串口转发(单字节转发)

目的:通过队列实现Usart1接收数据,由Usart2转发出去

 

Step1:串口

声明串口接收缓存,并添加串口回调函数

usart.h :

/* USER CODE BEGIN Private defines */

#define UART_BUF_SIZE 1       //缓冲长度为 1

extern  uint8_t UTART_BUF[UART_BUF_SIZE];    //全局变量

/* USER CODE END Private defines */

usart.c :

uint8_t UTART_BUF[UART_BUF_SIZE];

回调函数

/* USER CODE BEGIN 1 */

void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)

{

         if(&huart->Instance==&huart1.Instance)

         {

         BaseType_t xHigherPriorityTaskWoken;  

         xHigherPriorityTaskWoken = pdFALSE;   

         xQueueSendToBackFromISR(myQ01Handle,&UTART_BUF,&xHigherPriorityTaskWoken);

         HAL_UART_Receive_IT(huart,UTART_BUF,UART_BUF_SIZE);

         portYIELD_FROM_ISR(xHigherPriorityTaskWoken);       

         }

}

/* USER CODE END 1 */

在主程序初始化时加入:

HAL_UART_Receive_IT(huart,UTART_BUF,UART_BUF_SIZE);

 

Step2:串口接收队列

创建深度为128,每列一个字节的队列,可以通过Cubemx直接配置。这里要注意由于2个串口采用相同的波特率,因此如果队列深度设置太小会发生丢数据的情况。

  /* Create the queue(s) */

  /* definition and creation of myQ01 */

  osMessageQDef(myQ01, 128, uint8_t);

  myQ01Handle = osMessageCreate(osMessageQ(myQ01), NULL);

在转发线程中加入一下代码:

/* USER CODE END Header_StartTask02 */

void StartTask02(void const * argument)

{

  /* USER CODE BEGIN StartTask02 */

         osEvent osevent;

 

  /* Infinite loop */

  for(;;)

  {

                  osevent= osMessageGet( myQ01Handle,osWaitForever);

                   if(osevent.status==osEventMessage)

                   {

                            HAL_UART_Transmit(&huart2, (uint8_t *)&osevent.value.v, UART_BUF_SIZE,0xFFFF); //将收到的信息发送出去

                                               HAL_UART_Receive_IT(&huart1, (uint8_t *)&UTART_BUF, UART_BUF_SIZE);   //再开启接收中断

                   }

  }

  /* USER CODE END StartTask02 */

}

注:红色部分是添加的代码。

 

Step3:验证

编译后,下载运行。打开2个串口工具一个发数据,另一个接收数据。尝试512个字节一次发送,没有丢数据的现象。

 

 

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

余额充值