123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- #ifndef FREERTOS_CONFIG_H
- #define FREERTOS_CONFIG_H
- //#include "main.h"
- /*-----------------------------------------------------------
- * Application specific definitions.
- *
- * These definitions should be adjusted for your particular hardware and
- * application requirements.
- *
- * THESE PARAMETERS ARE DESCRIBED WITHIN THE 'CONFIGURATION' SECTION OF THE
- * FreeRTOS API DOCUMENTATION AVAILABLE ON THE FreeRTOS.org WEB SITE.
- *
- * See http://www.freertos.org/a00110.html.
- *----------------------------------------------------------*/
- /* Ensure stdint is only used by the compiler, and not the assembler. */
- #if defined(__ICCARM__) || defined(__CC_ARM) || defined(__GNUC__)
- #include <stdint.h>
- extern uint32_t SystemCoreClock;
- #endif
- #define configUSE_PREEMPTION 1 //1使用抢占式内核,0使用协程
- #define configUSE_TIME_SLICING 1 //1使能时间片调度(默认式使能的)
-
- #define configUSE_PORT_OPTIMISED_TASK_SELECTION 1 //1启用特殊方法来选择下一个要运行的任务
- //一般是硬件计算前导零指令,如果所使用的
- //MCU没有这些硬件指令的话此宏应该设置为0!
- #define configUSE_TICKLESS_IDLE 1 //1启用低功耗tickless模式
- #define configUSE_QUEUE_SETS 1 //为1时启用队列
- #define configUSE_IDLE_HOOK 0 //1,使用空闲钩子;0,不使用
- #define configUSE_TICK_HOOK 0 //1,使用时间片钩子;0,不使用
- #define configCPU_CLOCK_HZ ( SystemCoreClock ) //CPU频率
- #define configTICK_RATE_HZ ( ( TickType_t ) 1000 ) //时钟节拍频率,这里设置为1000,周期就是1ms
- #define configMAX_PRIORITIES ( 32 ) //可使用的最大优先级
- #define configMINIMAL_STACK_SIZE ( ( unsigned short ) 128 ) //空闲任务使用的堆栈大小
- #define configTOTAL_HEAP_SIZE ( ( size_t ) ( 30 * 1024 ) ) //系统所有总的堆大小
- #define configMAX_TASK_NAME_LEN ( 16 ) //任务名字字符串长度
- #define configUSE_16_BIT_TICKS 0 //系统节拍计数器变量数据类型,
- //1表示为16位无符号整形,0表示为32位无符号整形
- #define INCLUDE_xTaskGetHandle 1
- #define configIDLE_SHOULD_YIELD 1 //为1时空闲任务放弃CPU使用权给其他同优先级的用户任务
- #define configUSE_TASK_NOTIFICATIONS 1 //为1时开启任务通知功能,默认开启
- #define configUSE_MUTEXES 1 //为1时使用互斥信号量
- #define configQUEUE_REGISTRY_SIZE 10 //不为0时表示启用队列记录,具体的值是可以
- //记录的队列和信号量最大数目。
- #define configCHECK_FOR_STACK_OVERFLOW 0 //大于0时启用堆栈溢出检测功能,如果使用此功能
- //用户必须提供一个栈溢出钩子函数,如果使用的话
- #define configUSE_RECURSIVE_MUTEXES 1 //为1时使用递归互斥信号量
- #define configUSE_MALLOC_FAILED_HOOK 0 //1使用内存申请失败钩子函数
- #define configUSE_APPLICATION_TASK_TAG 0
- #define configUSE_COUNTING_SEMAPHORES 1 //为1时使用计数信号量
- #define configSUPPORT_DYNAMIC_ALLOCATION 1 //支持动态内存申请
- #define configUSE_TRACE_FACILITY 1 //为1启用可视化跟踪调试
- #define configGENERATE_RUN_TIME_STATS 0 //为1时启用运行时间统计功能
- #define configUSE_STATS_FORMATTING_FUNCTIONS 1 //与宏configUSE_TRACE_FACILITY同时为1时会编译下面3个函数
- //prvWriteNameToBuffer(),vTaskList(),
- //vTaskGetRunTimeStats()
- #define INCLUDE_uxTaskGetStackHighWaterMark 1
- /* Co-routine definitions. */
- #define configUSE_CO_ROUTINES 0 //为1时启用协程,启用协程以后必须添加文件croutine.c
- #define configMAX_CO_ROUTINE_PRIORITIES ( 2 ) //协程的有效优先级数目
- /* Software timer definitions. */
- #define configUSE_TIMERS 1 //为1时启用软件定时器
- #define configTIMER_TASK_PRIORITY ( 2 ) //软件定时器优先级
- #define configTIMER_QUEUE_LENGTH 10 //软件定时器队列长度
- #define configTIMER_TASK_STACK_DEPTH ( configMINIMAL_STACK_SIZE * 2 ) //软件定时器任务堆栈大小
- /* Set the following definitions to 1 to include the API function, or zero
- to exclude the API function. */
- #define INCLUDE_vTaskPrioritySet 1
- #define INCLUDE_uxTaskPriorityGet 1
- #define INCLUDE_vTaskDelete 1
- #define INCLUDE_vTaskCleanUpResources 1
- #define INCLUDE_vTaskSuspend 1
- #define INCLUDE_vTaskDelayUntil 1
- #define INCLUDE_vTaskDelay 1
- /* Cortex-M specific definitions. */
- #ifdef __NVIC_PRIO_BITS
- /* __BVIC_PRIO_BITS will be specified when CMSIS is being used. */
- #define configPRIO_BITS __NVIC_PRIO_BITS
- #else
- #define configPRIO_BITS 4 /* 15 priority levels */
- #endif
- /* The lowest interrupt priority that can be used in a call to a "set priority"
- function. */
- #define configLIBRARY_LOWEST_INTERRUPT_PRIORITY 0xf //中断最低优先级
- /* The highest interrupt priority that can be used by any interrupt service
- routine that makes calls to interrupt safe FreeRTOS API functions. DO NOT CALL
- INTERRUPT SAFE FREERTOS API FUNCTIONS FROM ANY INTERRUPT THAT HAS A HIGHER
- PRIORITY THAN THIS! (higher priorities are lower numeric values. */
- #define configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY 5 //系统可管理的最高中断优先级
- /* Interrupt priorities used by the kernel port layer itself. These are generic
- to all Cortex-M ports, and do not rely on any particular library functions. */
- #define configKERNEL_INTERRUPT_PRIORITY ( configLIBRARY_LOWEST_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )
- /* !!!! configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to zero !!!!
- See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html. */
- #define configMAX_SYSCALL_INTERRUPT_PRIORITY ( configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )
-
- /* Normal assert() semantics without relying on the provision of an assert.h
- header file. */
- #define configASSERT( x ) if( ( x ) == 0 ) { taskDISABLE_INTERRUPTS(); for( ;; ); }
-
- /* Definitions that map the FreeRTOS port interrupt handlers to their CMSIS
- standard names. */
- #define vPortSVCHandler SVC_Handler
- #define xPortPendSVHandler PendSV_Handler
- #define xPortSysTickHandler SysTick_Handler
- #endif /* FREERTOS_CONFIG_H */
|