2、STM32F103HAL FreeRTOSConfig.h解析

FreeRTOSConfig.h 文件中的配置项可分为三大类:“config”配置项、“INCLUDE”配置项 和其他配置项

一、“config”配置项

1、configUSE_PREEMPTION

说明:
	设置系统的调度方式;
赋值:
	configUSE_PREEMPTION = 1 时,系统使用抢占式调度;
	configUSE_PREEMPTION = 0 时,系统使用协程式调度。
默认值:
	#define configUSE_PREEMPTION						1

2、configUSE_PORT_OPTIMISED_TASK_SELECTION

说明:
	选择下一个要执行的任务方式;
赋值:
	configUSE_PORT_OPTIMISED_TASK_SELECTION = 1 时,使用特殊方法;
	configUSE_PORT_OPTIMISED_TASK_SELECTION = 0 时,使用通用方法。
默认值:
	#define configUSE_PORT_OPTIMISED_TASK_SELECTION		1

3、configUSE_TICKLESS_IDLE

说明:
	系统是否进入低功耗模式;
赋值:
	configUSE_TICKLESS_IDLE = 1 时,使能 tickless 低功耗模式;
	configUSE_TICKLESS_IDLE = 0 时,禁止 tickless 低功耗模式。
默认值:
	#define configUSE_TICKLESS_IDLE						0

4、configCPU_CLOCK_HZ

说明:
	设置为CPU的内核时钟频率,单位为 Hz;
赋值:
	#define configCPU_CLOCK_HZ						(SystemCoreClock)	
默认值:
	#define configCPU_CLOCK_HZ			            ( ( unsigned long ) 72000000 )

5、configTICK_RATE_HZ

说明:
	设置FreeRTOS系统节拍的中断频率:,单位为 Hz;(1ms一次)	
默认值:
	#define configTICK_RATE_HZ			            ( ( TickType_t ) 1000 )

6、configMAX_PRIORITIES

说明:
	定义系统支持的最大任务优先级数量, 最大任务优先级数值为:configMAX_PRIORITIES-1;	
默认值:
	#define configMAX_PRIORITIES					(32) 

7、configMINIMAL_STACK_SIZE

说明:
	设置空闲任务的栈空间大小,单位为word;	
默认值:
	#define configMINIMAL_STACK_SIZE				((unsigned short)128)

8、configMAX_TASK_NAME_LEN

说明:
	设置任务名的最大字符数;	
默认值:
	#define configMAX_TASK_NAME_LEN		            ( 16 )

9、configUSE_16_BIT_TICKS

说明:
	定义系统节拍计数器的数据类型;	
赋值:
	configUSE_16_BIT_TICKS = 1 时,系统节拍计数器的数据类型为 16 位无符号整形;
	configUSE_16_BIT_TICKS = 0 时,系统节拍计数器的数据类型为 32 为无符号整型。
默认值:
	#define configUSE_16_BIT_TICKS		            0

10、configIDLE_SHOULD_YIELD

说明:
	同等优先级的任务是否可抢占空闲任务;	
赋值:
	configIDLE_SHOULD_YIELD = 1 时,在抢占调度下,同等优先级的任务可抢占空闲任务;
	configIDLE_SHOULD_YIELD = 0 时,在抢占调度下,同等优先级的任务不抢占空闲任务。
默认值:
	#define configIDLE_SHOULD_YIELD		            1

11、configUSE_TASK_NOTIFICATIONS

说明:
	开启任务通知功能,当开启任务通知功能后,每个任务将多占用 8 字节的内存空间;	
赋值:
	configUSE_TASK_NOTIFICATIONS = 1 时,开启任务通知功能;
	configUSE_TASK_NOTIFICATIONS = 0 时,不开启任务通知功能。
默认值:
	#define configUSE_TASK_NOTIFICATIONS            0

12、configTASK_NOTIFICATION_ARRAY_ENTRIES

说明:
	定义任务通知数组的大小,使用前必须先开启configUSE_TASK_NOTIFICATIONS;	
赋值:
	#define configTASK_NOTIFICATION_ARRAY_ENTRIES	5
默认值:
	//#define configTASK_NOTIFICATION_ARRAY_ENTRIES	5

13、configUSE_MUTEXES

说明:
	是否使能互斥信号量;	
赋值:
	configUSE_MUTEXES = 1 时,使能互斥信号量;
	configUSE_MUTEXES = 0 时,禁止互斥信号量。
默认值:
	#define configUSE_MUTEXES						0

14、configUSE_RECURSIVE_MUTEXES

说明:
	是否使能递归互斥信号量;	
赋值:
	configUSE_RECURSIVE_MUTEXES = 1 时,使能递归互斥信号量;
	configUSE_RECURSIVE_MUTEXES = 0 时,禁止递归互斥信号量。
默认值:
	#define configUSE_RECURSIVE_MUTEXES				0

15、configUSE_COUNTING_SEMAPHORES

说明:
	是否使能计数型信号量;	
赋值:
	configUSE_COUNTING_SEMAPHORES = 1 时,使能计数型信号量;
	configUSE_COUNTING_SEMAPHORES = 0 时,禁止计数型信号量。
默认值:
	#define configUSE_COUNTING_SEMAPHORES 			0

16、configQUEUE_REGISTRY_SIZE

说明:
	定义可以注册的队列和信号量的最大数量,仅用于调试使用;	
赋值:
	#define configQUEUE_REGISTRY_SIZE				8
默认值:
	//#define configQUEUE_REGISTRY_SIZE				8

17、configUSE_QUEUE_SETS

说明:
	是否使能队列集;	
赋值:
	configUSE_QUEUE_SETS = 1 时,使能队列集;
	configUSE_QUEUE_SETS = 0 时,禁止队列集。
默认值:
	#define configUSE_QUEUE_SETS					0

18、configUSE_TIME_SLICING

说明:
	是否使能时间片调度;	
赋值:
	configUSE_TIME_SLICING = 1 时,使能时间片调度;
	configUSE_TIME_SLICING = 0 时,禁止时间片调度。
默认值:
	#define configUSE_TIME_SLICING					1

19、configUSE_NEWLIB_REENTRANT

说明:
	是否为每个任务分配一个 NewLib 重入结构体;	
赋值:
	configUSE_NEWLIB_REENTRANT = 1 时,为每个创建的任务的任务控制块分配一个NewLib重入结构体;
	configUSE_NEWLIB_REENTRANT = 0 时,不为每个创建的任务的任务控制块分配一个NewLib重入结构体。
默认值:
	#define configUSE_NEWLIB_REENTRANT				0

20、configNUM_THREAD_LOCAL_STORAGE_POINTERS

说明:
	是否在任务控制块中分配一个线程本地存储指着数组;	
赋值:
	configNUM_THREAD_LOCAL_STORAGE_POINTERS > 0 时,为线程本地存储指针数组的元素个数;
	configNUM_THREAD_LOCAL_STORAGE_POINTERS = 0 时,禁用线程本地存储指针数组。
默认值:
	#define configNUM_THREAD_LOCAL_STORAGE_POINTERS	0

21、configSUPPORT_STATIC_ALLOCATION

说明:
	是否支持使用静态方式管理内存;	
赋值:
	configSUPPORT_STATIC_ALLOCATION = 1 时,支持使用静态方式管理内存,同时用户需要自己提供vApplicationGetIdleTaskMemory()vApplicationGetTimerTaskMemory()两个回调函数;
	configSUPPORT_STATIC_ALLOCATION = 0 时,禁用使用静态方式管理内存。
默认值:
	#define configSUPPORT_STATIC_ALLOCATION			0

22、configSUPPORT_DYNAMIC_ALLOCATION

说明:
	是否支持使用动态方式管理内存;	
赋值:
	configSUPPORT_DYNAMIC_ALLOCATION = 1 时,支持使用动态方式管理内存;
	configSUPPORT_DYNAMIC_ALLOCATION = 0 时,禁用使用动态方式管理内存。
默认值:
	#define configSUPPORT_DYNAMIC_ALLOCATION		1

23、configTOTAL_HEAP_SIZE

说明:
	设置动态内存管理的内存堆大小,单位为Byte;	
赋值:
	configTOTAL_HEAP_SIZE > 0 ,仅用于动态方式管理内存,必须先配置configSUPPORT_DYNAMIC_ALLOCATION = 1;
默认值:
	#define configTOTAL_HEAP_SIZE		            ( ( size_t ) ( 16 * 1024 ) )

24、configAPPLICATION_ALLOCATED_HEAP

说明:
	用户自己分配动态内存,用于外扩内存(如sram, sdram)时候分配内存空间;	
赋值:
	configAPPLICATION_ALLOCATED_HEAP = 1 时,用户需要自行创建FreeRTOS的内存堆,否则FreeRTOS的内存堆将由编译器进行分配;
	configAPPLICATION_ALLOCATED_HEAP = 0 时,禁用使用自定义动态分配内存。
默认值:
	#define configAPPLICATION_ALLOCATED_HEAP		0

25、configSTACK_ALLOCATION_FROM_SEPARATE_HEAP

说明:
	用于自定义动态创建和删除任务时,任务栈内存的申请与释放函数开启;	
赋值:
	configSTACK_ALLOCATION_FROM_SEPARATE_HEAP = 1 时,用户需要用户需提供 pvPortMallocStack()vPortFreeStack()函数;
	configSTACK_ALLOCATION_FROM_SEPARATE_HEAP = 0 时,禁用开启自定义任务栈内存的申请与释放。
默认值:
	#define configSTACK_ALLOCATION_FROM_SEPARATE_HEAP	0

26、configUSE_IDLE_HOOK

说明:
	是否使用空闲任务钩子函数;	
赋值:
	configUSE_IDLE_HOOK = 1 时,使能使用空闲任务钩子函数,且需自定义相关钩子函数;
	configUSE_IDLE_HOOK = 0 时,禁用使用空闲任务钩子函数。
默认值:
	#define configUSE_IDLE_HOOK 					0

27、configUSE_TICK_HOOK

说明:
	是否使用系统时钟节拍中断钩子函数;	
赋值:
	configUSE_TICK_HOOK = 1 时,使能使用系统时钟节拍中断钩子函数,且需自定义相关钩子函数;
	configUSE_TICK_HOOK = 0 时,禁用使用系统时钟节拍中断钩子函数。
默认值:
	#define configUSE_TICK_HOOK						0

28、configCHECK_FOR_STACK_OVERFLOW

说明:
	是否使能栈溢出检测;	
赋值:
	configCHECK_FOR_STACK_OVERFLOW = 1 时,使用栈溢出检测方法1;
	configCHECK_FOR_STACK_OVERFLOW = 2 时,使用栈溢出检测方法2;
	configCHECK_FOR_STACK_OVERFLOW = 0 时,禁用使用栈溢出检测方法。
默认值:
	#define configCHECK_FOR_STACK_OVERFLOW			0

29、configUSE_MALLOC_FAILED_HOOK

说明:
	是否使用动态内存分配失败钩子函数;	
赋值:
	configUSE_MALLOC_FAILED_HOOK = 1 时,使能使用动态内存分配失败钩子函数,且需自定义相关钩子函数;
	configUSE_MALLOC_FAILED_HOOK = 0 时,禁用使用动态内存分配失败钩子函数。
默认值:
	#define configUSE_MALLOC_FAILED_HOOK			0

30、configUSE_DAEMON_TASK_STARTUP_HOOK

说明:
	是否使用定时器服务任务首次执行前的钩子函数;	
赋值:
	configUSE_DEAMON_TASK_STARTUP_HOOK = 1 时,使能使用定时器服务任务首次执行前的钩子函数,且需自定义相关钩子函数;
	configUSE_DEAMON_TASK_STARTUP_HOOK = 0 时,禁用使用定时器服务任务首次执行前的钩子函数。
默认值:
	#define configUSE_DEAMON_TASK_STARTUP_HOOK		0

31、configGENERATE_RUN_TIME_STATS

说明:
	是否使能任务运行时间统计功能;	
赋值:
	configGENERATE_RUN_TIME_STATS = 1 时,使能使能任务运行时间统计功能,且需自定义两个函数:
		portCONFIGURE_TIMER_FOR_RUN_TIME_STATS(),一般是完成定时器的初始化,来配置任务运行时间统计功能;
		portGET_RUN_TIME_COUNTER_VALUE(),用于获取定时器的计时值。
	configGENERATE_RUN_TIME_STATS = 0 时,禁用使能任务运行时间统计功能。
默认值:
	#define configGENERATE_RUN_TIME_STATS			0

32、configUSE_TRACE_FACILITY

说明:
	是否使能可视化跟踪调试;	
赋值:
	configUSE_TRACE_FACILITY = 1 时,使能使能可视化跟踪调试;
	configUSE_TRACE_FACILITY = 0 时,禁用使能可视化跟踪调试。
默认值:
	#define configUSE_TRACE_FACILITY				0

33、configUSE_STATS_FORMATTING_FUNCTIONS

说明:
	是否使能可视化跟踪调试;	
赋值:
	configUSE_STATS_FORMATTING_FUNCTIONS = 1 时,必须configUSE_TRACE_FACILITY = 1,则可以开启vTaskList()vTaskGetRunTimeStats()函数,使能可视化跟踪调试;
	configUSE_STATS_FORMATTING_FUNCTIONS = 0 时,禁用使能可视化跟踪调试。
默认值:
	#define configUSE_STATS_FORMATTING_FUNCTIONS	0

34、configUSE_TIMERS

说明:
	是否启用软件定时器功能;	
赋值:
	configUSE_TIMERS = 1 时,启用软件定时器功能;
	configUSE_TIMERS = 0 时,不启用软件定时器功能。
默认值:
	#define configUSE_TIMERS						0

35、configTIMER_TASK_PRIORITY

说明:
	设置软件定时器处理任务的优先级;	
赋值:
	configTIMER_TASK_PRIORITY > 0 时,必须configUSE_TIMERS = 1,才可以配置软件定时器优先级;
默认值:
	#define configTIMER_TASK_PRIORITY		        (configMAX_PRIORITIES-1)

36、configTIMER_QUEUE_LENGTH

说明:
	设置软件定时器队列的长度,软件定时器的开启、停止与销毁等操作都是通过队列实现的;	
赋值:
	configTIMER_QUEUE_LENGTH > 0 时,必须configUSE_TIMERS = 1,才可以配置软件定时器队列长度;
默认值:
	#define configTIMER_QUEUE_LENGTH		        5

37、configTIMER_TASK_STACK_DEPTH

说明:
	设置软件定时器处理任务的栈空间大小;	
赋值:
	configTIMER_TASK_STACK_DEPTH > 0 时,必须configUSE_TIMERS = 1,才可以配置软件定时器处理任务的栈空间大小;
默认值:
	#define configTIMER_TASK_STACK_DEPTH	        (configMINIMAL_STACK_SIZE*2)

38、定义中断相关配置

#ifdef __NVIC_PRIO_BITS
	#define configPRIO_BITS       		        		__NVIC_PRIO_BITS
#else
	#define configPRIO_BITS       		        		4                  
#endif
#define configLIBRARY_LOWEST_INTERRUPT_PRIORITY			15                      //中断最低优先级
#define configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY	5                       //系统可管理的最高中断优先级
#define configKERNEL_INTERRUPT_PRIORITY 				( configLIBRARY_LOWEST_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )
#define configMAX_SYSCALL_INTERRUPT_PRIORITY 			( configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )

39、断言

vAssertCalled(char, int):辅助配置宏 configASSERT( x )以通过串口打印相关信息;
configASSERT( x ):是FreeRTOS 操作系统的断言,会对表达式x进行判断:当x为假时,断言失败,表明程序出错,于是使用宏 vAssertCalled(char, int)通过串口打印相关的错误信息。

二、“INCLUDE”配置项

说明:
	“INCLUDE”配置项被定义为1时,其对应的API函数则会加入编译;为0时,API函数就不会加入编译,以减少不必要的系统开销;	
	
默认值:
	#define INCLUDE_vTaskPrioritySet	 		1	//设置任务优先级
	#define	INCLUDE_uxTaskPriorityGet 			1	//获取任务优先级
	#define INCLUDE_vTaskDelete 				1	//删除任务
	#define INCLUDE_vTaskSuspend 				1	//挂起任务
	#define INCLUDE_xResumeFromISR 				0	//恢复在中断中挂起的任务
	#define INCLUDE_vTaskDelayUntil 			1	//任务绝对延时
	#define INCLUDE_vTaskDelay 					1	//任务延时
	#define INCLUDE_xTaskGetSchedulerState 		0	//获取任务调度器状态
	#define INCLUDE_xTaskGetCurrentTaskHandle 	0	//获取当前任务的任务句柄
	#define INCLUDE_uxTaskGetStackHighWaterMark 0	//获取任务堆栈历史剩余最小值
	#define INCLUDE_xTaskGetIdleTaskHandle 		0	//获取空闲任务的任务句柄
	#define INCLUDE_eTaskGetState 				1	//获取任务状态
	#define INCLUDE_xEventGroupSetBitFromISR 	0	//在中断中设置事件标志位
	#define INCLUDE_xTimerPendFunctionCall 		1	//将函数的执行挂到定时器服务任务
	#define INCLUDE_xTaskAbortDelay 			0	//中断任务延时
	#define INCLUDE_xTaskGetHandle 				0	//通过任务名获取任务句柄
	#define INCLUDE_xTaskResumeFromISR 			0	//恢复在中断中挂起的任务

三、其他配置项

说明:有三个中断函数已经在FreeRTOS中已经实现,需要重新定义成他们函数!
#define vPortSVCHandler SVC_Handler
#define xPortPendSVHandler PendSV_Handler
#define xPortSysTickHandler SysTick_Handler
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值