FreeRTOSConfig.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. #ifndef __FREERTOS_CONFIG__H
  2. #define __FREERTOS_CONFIG__H
  3. //--------------------------------------------------------------------+
  4. // See http://www.freertos.org/a00110.html.
  5. //--------------------------------------------------------------------+
  6. //#include "bsp/board.h"
  7. #include "nrf.h"
  8. #if 0
  9. #if CFG_TUSB_MCU == OPT_MCU_LPC43XX
  10. // TODO remove
  11. #include "lpc43xx_cgu.h"
  12. #define configCPU_CLOCK_HZ CGU_GetPCLKFrequency(CGU_PERIPHERAL_M4CORE)
  13. #endif
  14. #endif
  15. #define configCPU_CLOCK_HZ SystemCoreClock
  16. #define configUSE_PREEMPTION 1
  17. #define configUSE_PORT_OPTIMISED_TASK_SELECTION 0
  18. #define configTICK_RATE_HZ ( 1000 )
  19. #define configMAX_PRIORITIES (5)
  20. #define configMINIMAL_STACK_SIZE (128 )
  21. #define configTOTAL_HEAP_SIZE ( ( size_t ) ( 16*1024 ) )
  22. #define configMAX_TASK_NAME_LEN 32
  23. #define configUSE_16_BIT_TICKS 0
  24. #define configIDLE_SHOULD_YIELD 1
  25. #define configUSE_MUTEXES 1
  26. #define configUSE_RECURSIVE_MUTEXES 0
  27. #define configUSE_COUNTING_SEMAPHORES 1
  28. #define configQUEUE_REGISTRY_SIZE 10 // used to name queue/semaphore with debugger
  29. #define configUSE_QUEUE_SETS 0
  30. #define configUSE_TIME_SLICING 0
  31. #define configUSE_NEWLIB_REENTRANT 0
  32. #define configENABLE_BACKWARD_COMPATIBILITY 1
  33. #define configSUPPORT_STATIC_ALLOCATION 1
  34. #define configSUPPORT_DYNAMIC_ALLOCATION 1
  35. /* Hook function related definitions. */
  36. #define configUSE_IDLE_HOOK 0
  37. #define configUSE_TICK_HOOK 0
  38. #define configUSE_MALLOC_FAILED_HOOK 1
  39. #define configCHECK_FOR_STACK_OVERFLOW 2
  40. /* Run time and task stats gathering related definitions. */
  41. #define configGENERATE_RUN_TIME_STATS 0
  42. #define configUSE_TRACE_FACILITY 1 // legacy trace
  43. #define configUSE_STATS_FORMATTING_FUNCTIONS 0
  44. /* Co-routine definitions. */
  45. #define configUSE_CO_ROUTINES 0
  46. #define configMAX_CO_ROUTINE_PRIORITIES 2
  47. /* Software timer related definitions. */
  48. #define configUSE_TIMERS 1
  49. #define configTIMER_TASK_PRIORITY ( configMAX_PRIORITIES - 3 )
  50. #define configTIMER_QUEUE_LENGTH 10
  51. #define configTIMER_TASK_STACK_DEPTH configMINIMAL_STACK_SIZE
  52. /* Optional functions - most linkers will remove unused functions anyway. */
  53. #define INCLUDE_vTaskPrioritySet 0
  54. #define INCLUDE_uxTaskPriorityGet 0
  55. #define INCLUDE_vTaskDelete 0
  56. #define INCLUDE_vTaskSuspend 1 // required for queue, semaphore, mutex to be blocked indefinitely with portMAX_DELAY
  57. #define INCLUDE_xResumeFromISR 0
  58. #define INCLUDE_vTaskDelayUntil 1
  59. #define INCLUDE_vTaskDelay 1
  60. #define INCLUDE_xTaskGetSchedulerState 0
  61. #define INCLUDE_xTaskGetCurrentTaskHandle 0
  62. #define INCLUDE_uxTaskGetStackHighWaterMark 0
  63. #define INCLUDE_xTaskGetIdleTaskHandle 0
  64. #define INCLUDE_xTimerGetTimerDaemonTaskHandle 0
  65. #define INCLUDE_pcTaskGetTaskName 0
  66. #define INCLUDE_eTaskGetState 0
  67. #define INCLUDE_xEventGroupSetBitFromISR 0
  68. #define INCLUDE_xTimerPendFunctionCall 0
  69. /* Define to trap errors during development. */
  70. // Halt CPU (breakpoint) when hitting error, only apply for Cortex M3, M4, M7
  71. #if defined(__ARM_ARCH_7M__) || defined (__ARM_ARCH_7EM__)
  72. static inline void configASSERT_breakpoint(void)
  73. {
  74. // Cortex M CoreDebug->DHCSR
  75. volatile uint32_t* ARM_CM_DHCSR = ((volatile uint32_t*) 0xE000EDF0UL);
  76. // Only halt mcu if debugger is attached
  77. if ( (*ARM_CM_DHCSR) & 1UL ) __asm("BKPT #0\n");
  78. }
  79. #else
  80. #define configASSERT_breakpoint()
  81. #endif
  82. #define configASSERT( x ) if( ( x ) == 0 ) { taskDISABLE_INTERRUPTS(); configASSERT_breakpoint(); }
  83. /* FreeRTOS hooks to NVIC vectors */
  84. #define xPortPendSVHandler PendSV_Handler
  85. #define xPortSysTickHandler SysTick_Handler
  86. #define vPortSVCHandler SVC_Handler
  87. //--------------------------------------------------------------------+
  88. // Interrupt nesting behaviour configuration.
  89. //--------------------------------------------------------------------+
  90. /* Cortex-M specific definitions. __NVIC_PRIO_BITS is defined in core_cmx.h */
  91. #ifdef __NVIC_PRIO_BITS
  92. #define configPRIO_BITS __NVIC_PRIO_BITS
  93. #else
  94. #define configPRIO_BITS 5 // 32 priority levels
  95. #endif
  96. /* The lowest interrupt priority that can be used in a call to a "set priority"
  97. function. */
  98. #define configLIBRARY_LOWEST_INTERRUPT_PRIORITY 0x1f
  99. /* The highest interrupt priority that can be used by any interrupt service
  100. routine that makes calls to interrupt safe FreeRTOS API functions. DO NOT CALL
  101. INTERRUPT SAFE FREERTOS API FUNCTIONS FROM ANY INTERRUPT THAT HAS A HIGHER
  102. PRIORITY THAN THIS! (higher priorities are lower numeric values. */
  103. #define configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY 5
  104. /* Interrupt priorities used by the kernel port layer itself. These are generic
  105. to all Cortex-M ports, and do not rely on any particular library functions. */
  106. #define configKERNEL_INTERRUPT_PRIORITY configLIBRARY_LOWEST_INTERRUPT_PRIORITY // ( configLIBRARY_LOWEST_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )
  107. /* !!!! configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to zero !!!!
  108. See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html. */
  109. #define configMAX_SYSCALL_INTERRUPT_PRIORITY configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY //( configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )
  110. #endif /* __FREERTOS_CONFIG__H */