]> begriffs open source - cmsis-freertos/blob - Demo/CORTEX_A2F200_SoftConsole/FreeRTOSConfig.h
Update cmsis_os2.c
[cmsis-freertos] / Demo / CORTEX_A2F200_SoftConsole / FreeRTOSConfig.h
1 /*
2     FreeRTOS V9.0.0 - Copyright (C) 2016 Real Time Engineers Ltd.
3     All rights reserved
4
5     VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.
6
7     This file is part of the FreeRTOS distribution.
8
9     FreeRTOS is free software; you can redistribute it and/or modify it under
10     the terms of the GNU General Public License (version 2) as published by the
11     Free Software Foundation >>>> AND MODIFIED BY <<<< the FreeRTOS exception.
12
13     ***************************************************************************
14     >>!   NOTE: The modification to the GPL is included to allow you to     !<<
15     >>!   distribute a combined work that includes FreeRTOS without being   !<<
16     >>!   obliged to provide the source code for proprietary components     !<<
17     >>!   outside of the FreeRTOS kernel.                                   !<<
18     ***************************************************************************
19
20     FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY
21     WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
22     FOR A PARTICULAR PURPOSE.  Full license text is available on the following
23     link: http://www.freertos.org/a00114.html
24
25     ***************************************************************************
26      *                                                                       *
27      *    FreeRTOS provides completely free yet professionally developed,    *
28      *    robust, strictly quality controlled, supported, and cross          *
29      *    platform software that is more than just the market leader, it     *
30      *    is the industry's de facto standard.                               *
31      *                                                                       *
32      *    Help yourself get started quickly while simultaneously helping     *
33      *    to support the FreeRTOS project by purchasing a FreeRTOS           *
34      *    tutorial book, reference manual, or both:                          *
35      *    http://www.FreeRTOS.org/Documentation                              *
36      *                                                                       *
37     ***************************************************************************
38
39     http://www.FreeRTOS.org/FAQHelp.html - Having a problem?  Start by reading
40     the FAQ page "My application does not run, what could be wrong?".  Have you
41     defined configASSERT()?
42
43     http://www.FreeRTOS.org/support - In return for receiving this top quality
44     embedded software for free we request you assist our global community by
45     participating in the support forum.
46
47     http://www.FreeRTOS.org/training - Investing in training allows your team to
48     be as productive as possible as early as possible.  Now you can receive
49     FreeRTOS training directly from Richard Barry, CEO of Real Time Engineers
50     Ltd, and the world's leading authority on the world's leading RTOS.
51
52     http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,
53     including FreeRTOS+Trace - an indispensable productivity tool, a DOS
54     compatible FAT file system, and our tiny thread aware UDP/IP stack.
55
56     http://www.FreeRTOS.org/labs - Where new FreeRTOS products go to incubate.
57     Come and try FreeRTOS+TCP, our new open source TCP/IP stack for FreeRTOS.
58
59     http://www.OpenRTOS.com - Real Time Engineers ltd. license FreeRTOS to High
60     Integrity Systems ltd. to sell under the OpenRTOS brand.  Low cost OpenRTOS
61     licenses offer ticketed support, indemnification and commercial middleware.
62
63     http://www.SafeRTOS.com - High Integrity Systems also provide a safety
64     engineered and independently SIL3 certified version for use in safety and
65     mission critical applications that require provable dependability.
66
67     1 tab == 4 spaces!
68 */
69
70
71 /* 
72  * The following #error directive is to remind users that a batch file must be
73  * executed prior to this project being built.  The batch file *cannot* be 
74  * executed from within the IDE!  Once it has been executed, re-open or refresh 
75  * the Eclipse project and remove the #error line below.
76  */
77 #error Ensure CreateProjectDirectoryStructure.bat has been executed before building.  See comment immediately above.
78
79
80 #ifndef FREERTOS_CONFIG_H
81 #define FREERTOS_CONFIG_H
82
83 #include <stdint.h>
84 #include <stddef.h>
85
86 /*-----------------------------------------------------------
87  * Application specific definitions.
88  *
89  * These definitions should be adjusted for your particular hardware and
90  * application requirements.
91  *
92  * THESE PARAMETERS ARE DESCRIBED WITHIN THE 'CONFIGURATION' SECTION OF THE
93  * FreeRTOS API DOCUMENTATION AVAILABLE ON THE FreeRTOS.org WEB SITE.
94  *
95  * See http://www.freertos.org/a00110.html.
96  *----------------------------------------------------------*/
97
98 extern uint32_t SystemFrequency;
99
100 #define configUSE_PREEMPTION                    1
101 #define configUSE_IDLE_HOOK                             1
102 #define configUSE_TICK_HOOK                             0
103 #define configCPU_CLOCK_HZ                              ( SystemFrequency )
104 #define configTICK_RATE_HZ                              ( ( TickType_t ) 1000 )
105 #define configMAX_PRIORITIES                    ( 5 )
106 #define configMINIMAL_STACK_SIZE                ( ( unsigned short ) 90 )
107 #define configTOTAL_HEAP_SIZE                   ( ( size_t ) ( 30 * 1024 ) )
108 #define configMAX_TASK_NAME_LEN                 ( 10 )
109 #define configUSE_TRACE_FACILITY                1
110 #define configUSE_16_BIT_TICKS                  0
111 #define configIDLE_SHOULD_YIELD                 1
112 #define configUSE_MUTEXES                               1
113 #define configQUEUE_REGISTRY_SIZE               0
114 #define configGENERATE_RUN_TIME_STATS   1
115 #define configCHECK_FOR_STACK_OVERFLOW  2
116 #define configUSE_RECURSIVE_MUTEXES             1
117 #define configUSE_MALLOC_FAILED_HOOK    1
118 #define configUSE_APPLICATION_TASK_TAG  0
119 #define configUSE_COUNTING_SEMAPHORES   0
120
121 /* Co-routine definitions. */
122 #define configUSE_CO_ROUTINES           0
123 #define configMAX_CO_ROUTINE_PRIORITIES ( 2 )
124
125 /* Software timer definitions. */
126 #define configUSE_TIMERS                                1
127 #define configTIMER_TASK_PRIORITY               ( 2 )
128 #define configTIMER_QUEUE_LENGTH                10
129 #define configTIMER_TASK_STACK_DEPTH    ( configMINIMAL_STACK_SIZE * 2 )
130
131 /* Set the following definitions to 1 to include the API function, or zero
132 to exclude the API function. */
133 #define INCLUDE_vTaskPrioritySet                1
134 #define INCLUDE_uxTaskPriorityGet               1
135 #define INCLUDE_vTaskDelete                             1
136 #define INCLUDE_vTaskCleanUpResources   1
137 #define INCLUDE_vTaskSuspend                    1
138 #define INCLUDE_vTaskDelayUntil                 1
139 #define INCLUDE_vTaskDelay                              1
140
141 /* This demo makes use of one or more example stats formatting functions.  These
142 format the raw data provided by the uxTaskGetSystemState() function in to human
143 readable ASCII form.  See the notes in the implementation of vTaskList() within 
144 FreeRTOS/Source/tasks.c for limitations. */
145 #define configUSE_STATS_FORMATTING_FUNCTIONS    1
146
147 void vMainConfigureTimerForRunTimeStats( void );
148 unsigned long ulGetRunTimeCounterValue( void );
149 #define portCONFIGURE_TIMER_FOR_RUN_TIME_STATS() vMainConfigureTimerForRunTimeStats()
150 #define portGET_RUN_TIME_COUNTER_VALUE() ulGetRunTimeCounterValue()
151
152 /* Use the system definition, if there is one */
153 #ifdef __NVIC_PRIO_BITS
154         #define configPRIO_BITS       __NVIC_PRIO_BITS
155 #else
156         #define configPRIO_BITS       5        /* 15 priority levels */
157 #endif
158
159 #define configLIBRARY_LOWEST_INTERRUPT_PRIORITY                 0x1f
160 #define configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY    5
161
162 /* The lowest priority. */
163 #define configKERNEL_INTERRUPT_PRIORITY         ( configLIBRARY_LOWEST_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )
164 /* Priority 5, or 160 as only the top three bits are implemented. */
165 /* !!!! configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to zero !!!!
166 See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html. */
167 #define configMAX_SYSCALL_INTERRUPT_PRIORITY    ( configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )
168         
169 #define configASSERT( x ) if( ( x ) == 0 ) { taskDISABLE_INTERRUPTS(); for( ;; ); }     
170         
171 #define vPortSVCHandler SVC_Handler
172 #define xPortPendSVHandler PendSV_Handler
173 #define vPortSVCHandler SVC_Handler
174 #define xPortSysTickHandler SysTick_Handler
175
176 /* MAC address configuration. */
177 #define configMAC_ADDR0 0x00
178 #define configMAC_ADDR1 0x12
179 #define configMAC_ADDR2 0x13
180 #define configMAC_ADDR3 0x10
181 #define configMAC_ADDR4 0x15
182 #define configMAC_ADDR5 0x11
183
184 /* IP address configuration. */
185 #define configIP_ADDR0          192
186 #define configIP_ADDR1          168
187 #define configIP_ADDR2          0
188 #define configIP_ADDR3          200
189
190 /* Netmask configuration. */
191 #define configNET_MASK0         255
192 #define configNET_MASK1         255
193 #define configNET_MASK2         255
194 #define configNET_MASK3         0
195
196 #endif /* FREERTOS_CONFIG_H */
197