| 
									
										
										
										
											2013-04-25 15:43:33 +07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |     FreeRTOS V7.1.0 - Copyright (C) 2011 Real Time Engineers Ltd. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     *************************************************************************** | 
					
						
							|  |  |  |      *                                                                       * | 
					
						
							|  |  |  |      *    FreeRTOS tutorial books are available in pdf and paperback.        * | 
					
						
							|  |  |  |      *    Complete, revised, and edited pdf reference manuals are also       * | 
					
						
							|  |  |  |      *    available.                                                         * | 
					
						
							|  |  |  |      *                                                                       * | 
					
						
							|  |  |  |      *    Purchasing FreeRTOS documentation will not only help you, by       * | 
					
						
							|  |  |  |      *    ensuring you get running as quickly as possible and with an        * | 
					
						
							|  |  |  |      *    in-depth knowledge of how to use FreeRTOS, it will also help       * | 
					
						
							|  |  |  |      *    the FreeRTOS project to continue with its mission of providing     * | 
					
						
							|  |  |  |      *    professional grade, cross platform, de facto standard solutions    * | 
					
						
							|  |  |  |      *    for microcontrollers - completely free of charge!                  * | 
					
						
							|  |  |  |      *                                                                       * | 
					
						
							|  |  |  |      *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *
 | 
					
						
							|  |  |  |      *                                                                       * | 
					
						
							|  |  |  |      *    Thank you for using FreeRTOS, and thank you for your support!      * | 
					
						
							|  |  |  |      *                                                                       * | 
					
						
							|  |  |  |     *************************************************************************** | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     This file is part of the FreeRTOS distribution. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     FreeRTOS is free software; you can redistribute it and/or modify it under | 
					
						
							|  |  |  |     the terms of the GNU General Public License (version 2) as published by the | 
					
						
							|  |  |  |     Free Software Foundation AND MODIFIED BY the FreeRTOS exception. | 
					
						
							|  |  |  |     >>>NOTE<<< The modification to the GPL is included to allow you to | 
					
						
							|  |  |  |     distribute a combined work that includes FreeRTOS without being obliged to | 
					
						
							|  |  |  |     provide the source code for proprietary components outside of the FreeRTOS | 
					
						
							|  |  |  |     kernel.  FreeRTOS is distributed in the hope that it will be useful, but | 
					
						
							|  |  |  |     WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY | 
					
						
							|  |  |  |     or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for | 
					
						
							|  |  |  |     more details. You should have received a copy of the GNU General Public | 
					
						
							|  |  |  |     License and the FreeRTOS license exception along with FreeRTOS; if not it | 
					
						
							|  |  |  |     can be viewed here: http://www.freertos.org/a00114.html and also obtained
 | 
					
						
							|  |  |  |     by writing to Richard Barry, contact details for whom are available on the | 
					
						
							|  |  |  |     FreeRTOS WEB site. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     1 tab == 4 spaces! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     http://www.FreeRTOS.org - Documentation, latest information, license and
 | 
					
						
							|  |  |  |     contact details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     http://www.SafeRTOS.com - A version that is certified for use in safety
 | 
					
						
							|  |  |  |     critical systems. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     http://www.OpenRTOS.com - Commercial support, development, porting,
 | 
					
						
							|  |  |  |     licensing and training services. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef FREERTOS_CONFIG_H
 | 
					
						
							|  |  |  | #define FREERTOS_CONFIG_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef __IASMARM__
 | 
					
						
							|  |  |  | /* For SystemCoreClock */ | 
					
						
							|  |  |  | #include "board.h"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*-----------------------------------------------------------
 | 
					
						
							|  |  |  |  * 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.
 | 
					
						
							|  |  |  |  *----------------------------------------------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define configUSE_PREEMPTION			1
 | 
					
						
							|  |  |  | #define configUSE_IDLE_HOOK				1
 | 
					
						
							|  |  |  | #define configUSE_TICK_HOOK				0
 | 
					
						
							|  |  |  | #define configCPU_CLOCK_HZ				( SystemCoreClock )
 | 
					
						
							|  |  |  | #define configTICK_RATE_HZ				( ( portTickType ) 1000 )
 | 
					
						
							|  |  |  | #define configMAX_PRIORITIES			( ( unsigned portBASE_TYPE ) 8 )
 | 
					
						
							|  |  |  | #define configMINIMAL_STACK_SIZE		( ( unsigned short ) 128 )
 | 
					
						
							|  |  |  | #define configTOTAL_HEAP_SIZE			( ( size_t ) ( 0 ) )
 | 
					
						
							|  |  |  | #define configMAX_TASK_NAME_LEN			( 10 )
 | 
					
						
							|  |  |  | #define configUSE_TRACE_FACILITY		1
 | 
					
						
							|  |  |  | #define configUSE_16_BIT_TICKS			0
 | 
					
						
							|  |  |  | #define configIDLE_SHOULD_YIELD			1
 | 
					
						
							|  |  |  | #define configUSE_MUTEXES				1
 | 
					
						
							|  |  |  | #define configQUEUE_REGISTRY_SIZE		8
 | 
					
						
							|  |  |  | #define configCHECK_FOR_STACK_OVERFLOW	2
 | 
					
						
							|  |  |  | #define configUSE_RECURSIVE_MUTEXES		1
 | 
					
						
							|  |  |  | #define configUSE_MALLOC_FAILED_HOOK	1
 | 
					
						
							|  |  |  | #define configUSE_APPLICATION_TASK_TAG	0
 | 
					
						
							|  |  |  | #define configUSE_COUNTING_SEMAPHORES	1
 | 
					
						
							|  |  |  | #define configGENERATE_RUN_TIME_STATS	0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Co-routine definitions. */ | 
					
						
							|  |  |  | #define configUSE_CO_ROUTINES 		0
 | 
					
						
							|  |  |  | #define configMAX_CO_ROUTINE_PRIORITIES ( 2 )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Software timer definitions.  This example uses I2C to write to the LEDs.  As
 | 
					
						
							|  |  |  | this takes a finite time, and because a timer callback writes to an LED, the | 
					
						
							|  |  |  | priority of the timer task is kept to a minimum to ensure it does not disrupt | 
					
						
							|  |  |  | test tasks that check their own execution times. */ | 
					
						
							|  |  |  | #define configUSE_TIMERS				0
 | 
					
						
							|  |  |  | #define configTIMER_TASK_PRIORITY		( 0 )
 | 
					
						
							|  |  |  | #define configTIMER_QUEUE_LENGTH		5
 | 
					
						
							|  |  |  | #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. */ | 
					
						
							| 
									
										
										
										
											2013-09-18 20:56:29 +07:00
										 |  |  | #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
 | 
					
						
							| 
									
										
										
										
											2013-04-25 15:43:33 +07:00
										 |  |  | #define INCLUDE_xTaskGetCurrentTaskHandle 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       		5        /* 32 priority levels */
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* The lowest interrupt priority that can be used in a call to a "set priority"
 | 
					
						
							|  |  |  | function. */ | 
					
						
							|  |  |  | #define configLIBRARY_LOWEST_INTERRUPT_PRIORITY			0x1f
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 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) )
 | 
					
						
							|  |  |  | #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. */ | 
					
						
							| 
									
										
										
										
											2013-09-18 20:56:29 +07:00
										 |  |  | #define configASSERT( x ) if( ( x ) == 0 ) { taskDISABLE_INTERRUPTS(); hal_debugger_breakpoint(); }
 | 
					
						
							| 
									
										
										
										
											2013-04-25 15:43:33 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define configUSE_CUSTOM_TICK 1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define vPortSVCHandler       SVC_Handler
 | 
					
						
							|  |  |  | #define xPortPendSVHandler    PendSV_Handler
 | 
					
						
							|  |  |  | #define xPortSysTickHandler   RIT_IRQHandler
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* FREERTOS_CONFIG_H */
 | 
					
						
							|  |  |  | 
 |