【STM32 FreeRTOS】任务相关API

获取系统中任务的数量

c 复制代码
UBaseType_t uxTaskGetNumberOfTasks( void );

**返回:**RTOS 内核当前正在管理的任务数。这包括所有准备就绪、阻塞和 挂起的任务。已删除但尚未被空闲任务释放的任务也将包含 在计数中。还包括空闲任务和定时器任务(如果已开软件定时器)。

获取任务历史剩余最小堆栈位

c 复制代码
UBaseType_t uxTaskGetStackHighWaterMark
 ( TaskHandle_t xTask );

**返回:**返回的值是以字为单位的高水位标记(例如,在 32 位计算机上, 返回值为 1 表示有 4 个字节的堆栈未使用)。如果返回值为零, 则任务可能已溢出堆栈。如果返回值接近于零,则任务已接近堆栈溢出 。

这个函数主要用于调测任务堆栈大小的设置,建议该返回值与堆栈大小设置值差不多就行,也就是实际任务使用了一半的堆栈。

以表格的形式获取系统中任务的信息

c 复制代码
configUSE_TRACE_FACILITY
configUSE_STATS_FORMATTING_FUNCTIONS

必须在 FreeRTOSConfig.h 中定义为 1,才可使用此函数。

c 复制代码
void vTaskList( char *pcWriteBuffer );
  • pcWriteBuffer:上述详细信息将以 ASCII 形式写入的缓冲区。假设此缓冲区 的大小足以容纳生成的报告。大约为每个任务分配 40 字节的缓冲区就足够了。

pcWriteBuffer中内容为:

第一列:任务名称

第二列:任务状态信息。X:运行态,B:阻塞态,R:就绪态,S:挂起态,D:删除态

第三列:任务优先级

第四列:任务堆栈的高水位线,就是堆栈历史最小剩余值

第五列:任务编号,这个编号是唯一的,当任务名称相同的时候可以使用这个作区分

c 复制代码
	  UBaseType_t task_num = uxTaskGetNumberOfTasks();
	  printf("task_num = %ld\r\n",task_num);

	  UBaseType_t stack_high_water= uxTaskGetStackHighWaterMark(NULL);
	  printf("stack_high_water = %ld\r\n",stack_high_water);

	  char task_list_buffer[40*6];
	  vTaskList(task_list_buffer);
	  printf("%s\r\n",task_list_buffer);
复制代码
task_num = 6
stack_high_water = 76
MyTask1        	X	31	76	2
defaultTask    	R	24	117	1
Tmr Svc        	R	2	246	6
IDLE           	R	0	117	5
MyTask2        	B	31	102	3
MyTask3        	B	31	102	4

任务运行时间统计

c 复制代码
void vTaskGetRunTimeStats( char *pcWriteBuffer );

pcWriteBuffer :执行时间将以 ASCII 形式写入的缓冲区。假设此缓冲区 的大小足以容纳生成的报告。大约为每个任务分配 40 字节的缓冲区就足够了。

c 复制代码
configGENERATE_RUN_TIME_STATS

configUSE_STATS_FORMATTING_FUNCTIONS
 
configSUPPORT_DYNAMIC_ALLOCATION

必须定义为 1,才可使用此函数。此外,应用程序还必须提供

c 复制代码
portCONFIGURE_TIMER_FOR_RUN_TIME_STATS
portGET_RUN_TIME_COUNTER_VALUE

的定义,分别用于配置外设 定时器/计数器和返回定时器的当前计数值。计数器的频率应该至少是 滴答计数的 10 倍。

c 复制代码
tim.c文件中

/* USER CODE BEGIN 0 */
unsigned long FreeRTOSRunTimeTicks;
/* USER CODE END 0 */

void MX_TIM7_Init(void)
{

  /* USER CODE BEGIN TIM7_Init 0 */

  /* USER CODE END TIM7_Init 0 */

  TIM_MasterConfigTypeDef sMasterConfig = {0};

  /* USER CODE BEGIN TIM7_Init 1 */
/*
 * TIM7的时钟源是84MHz
 * 分频比设置为84,则一个周期的频率是1MHz(1us)
 * 周期数设置为10,则10us才会产生一个中断
 * */
  /* USER CODE END TIM7_Init 1 */
  htim7.Instance = TIM7;
  htim7.Init.Prescaler = 84-1;
  htim7.Init.CounterMode = TIM_COUNTERMODE_UP;
  htim7.Init.Period = 10-1;
  htim7.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  if (HAL_TIM_Base_Init(&htim7) != HAL_OK)
  {
    Error_Handler();
  }
  sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  if (HAL_TIMEx_MasterConfigSynchronization(&htim7, &sMasterConfig) != HAL_OK)
  {
    Error_Handler();
  }
  /* USER CODE BEGIN TIM7_Init 2 */

  /* USER CODE END TIM7_Init 2 */

}


/* USER CODE BEGIN 1 */

void configureTimerForRunTimeStats()
{
	FreeRTOSRunTimeTicks=0;

	//我们FreeRTOS中的时基是1ms
	//任务运行时间统计API中的时基分辨率最少需要是10倍,我们采取100倍,也就是10us
	//所以配置的TIM7的中断周期是10us.
	HAL_TIM_Base_Start_IT(&htim7);
}


unsigned long getRunTimeCounterValue()
{
	return FreeRTOSRunTimeTicks;
}
/* USER CODE END 1 */
c 复制代码
tim.h文件中

/* USER CODE BEGIN Private defines */
extern unsigned long FreeRTOSRunTimeTicks;
/* USER CODE END Private defines */
c 复制代码
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
  /* USER CODE BEGIN Callback 0 */

  /* USER CODE END Callback 0 */
  if (htim->Instance == TIM6) {
    HAL_IncTick();
  }
  /* USER CODE BEGIN Callback 1 */
  if(htim->Instance ==TIM7)
  {
	  FreeRTOSRunTimeTicks++;
  }
  /* USER CODE END Callback 1 */
}
复制代码
FreeRTOSConfig.h文件中

/* USER CODE BEGIN 2 */
/* Definitions needed when configGENERATE_RUN_TIME_STATS is on */
#define portCONFIGURE_TIMER_FOR_RUN_TIME_STATS configureTimerForRunTimeStats
#define portGET_RUN_TIME_COUNTER_VALUE getRunTimeCounterValue
/* USER CODE END 2 */
c 复制代码
char task_list_buffer[40*6];
vTaskGetRunTimeStats(task_list_buffer);
printf("%s\r\n",task_list_buffer);
复制代码
MyTask1        	2154		<1%
defaultTask    	1080		<1%
IDLE           	998846		99%
MyTask2        	10		<1%
MyTask3        	11		<1%
Tmr Svc        	1		<1%

第一列:任务名称

第二列:运行时间统计时钟的tick数,实际时间为 tick*10us(本例中运行时间统计时钟的频率为10us)

第三列:百分比值

相关推荐
血腥甘蔗27 分钟前
下一代防火墙组网全解析
网络·智能路由器
2301_8217271727 分钟前
vlan综合实验
网络
yuanyun_elber1 小时前
安全配对(一)
网络·安全
Menior_2 小时前
【从网络基础到实战】理解TCP/IP协议体系的核心要点(包含ARP协议等其他协议介绍)
网络·tcp/ip·智能路由器
枷锁—sha3 小时前
【BUUCTF系列】[极客大挑战 2019]Http 1
网络·网络协议·http
gAlAxy...3 小时前
HTTP 请求转发与重定向详解及其应用(含 Java 示例)
网络·网络协议·http
Be Legendary-CGK3 小时前
三极管的基极为什么需要下拉电阻
单片机·嵌入式硬件·硬件工程
曼岛_4 小时前
[系统架构设计师]信息安全技术基础知识(三)
网络·web安全·系统架构
失散134 小时前
深度学习——03 神经网络(3)-网络优化方法
网络·深度学习·神经网络
2301_804389905 小时前
HCIP综合大实验,笔记
网络