/* | |
FreeRTOS V7.4.1 - Copyright (C) 2013 Real Time Engineers Ltd. | |
FEATURES AND PORTS ARE ADDED TO FREERTOS ALL THE TIME. PLEASE VISIT | |
http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION. | |
*************************************************************************** | |
* * | |
* 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 Real Time Engineers Ltd., contact details for whom are available | |
on the FreeRTOS WEB site. | |
1 tab == 4 spaces! | |
*************************************************************************** | |
* * | |
* Having a problem? Start by reading the FAQ "My application does * | |
* not run, what could be wrong?" * | |
* * | |
* http://www.FreeRTOS.org/FAQHelp.html * | |
* * | |
*************************************************************************** | |
http://www.FreeRTOS.org - Documentation, books, training, latest versions, | |
license and Real Time Engineers Ltd. contact details. | |
http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products, | |
including FreeRTOS+Trace - an indispensable productivity tool, and our new | |
fully thread aware and reentrant UDP/IP stack. | |
http://www.OpenRTOS.com - Real Time Engineers ltd license FreeRTOS to High | |
Integrity Systems, who sell the code with commercial support, | |
indemnification and middleware, under the OpenRTOS brand. | |
http://www.SafeRTOS.com - High Integrity Systems also provide a safety | |
engineered and independently SIL3 certified version for use in safety and | |
mission critical applications that require provable dependability. | |
*/ | |
/* The following #error directive is to remind users that a batch file must be | |
* executed prior to this project being built. The batch file *cannot* be | |
* executed from within older versions of Eclipse, but probably can be executed | |
* from within the Xilinx SDK. Once it has been executed, re-open or refresh | |
* the Eclipse project and remove the #error line below. | |
*/ | |
#error Ensure CreateProjectDirectoryStructure.bat has been executed before building. See comment immediately above. | |
#ifndef FREERTOS_CONFIG_H | |
#define FREERTOS_CONFIG_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. | |
*----------------------------------------------------------*/ | |
#define configUSE_PREEMPTION 1 | |
#define configUSE_IDLE_HOOK 1 | |
#define configUSE_TICK_HOOK 0 | |
#define configCPU_CLOCK_HZ ( XPAR_MICROBLAZE_CORE_CLOCK_FREQ_HZ ) /* Not actually used in this demo as the timer is set up in main() and uses the peripheral clock, not the CPU clock. */ | |
#define configTICK_RATE_HZ ( ( portTickType ) 1000 ) | |
#define configMAX_PRIORITIES ( 7 ) | |
#define configTOTAL_HEAP_SIZE ( ( size_t ) ( 64 * 1024 ) ) | |
#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 10 | |
#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 configMINIMAL_STACK_SIZE ( ( unsigned short ) 200 ) | |
#define configINTERRUPT_STACK_SIZE configMINIMAL_STACK_SIZE | |
/* If configINSTALL_EXCEPTION_HANDLERS is set to 1, then the kernel will | |
automatically install its own exception handlers before the kernel is started, | |
if the application writer has not already caused them to be installed using the | |
vPortExceptionsInstallHandlers() API function. See the documentation page for | |
this demo on the FreeRTOS.org web site for more information. */ | |
#define configINSTALL_EXCEPTION_HANDLERS 1 | |
/* configINTERRUPT_CONTROLLER_TO_USE must be set to the ID of the interrupt | |
controller that is going to be used directly by FreeRTOS itself. Most hardware | |
designs will only include on interrupt controller. */ | |
#define configINTERRUPT_CONTROLLER_TO_USE XPAR_INTC_SINGLE_DEVICE_ID | |
/* Co-routine definitions. */ | |
#define configUSE_CO_ROUTINES 0 | |
#define configMAX_CO_ROUTINE_PRIORITIES ( 2 ) | |
/* Software timer definitions. */ | |
#define configUSE_TIMERS 1 | |
#define configTIMER_TASK_PRIORITY ( configMAX_PRIORITIES - 4 ) | |
#define configTIMER_QUEUE_LENGTH 10 | |
#define configTIMER_TASK_STACK_DEPTH ( configMINIMAL_STACK_SIZE ) | |
/* 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 0 | |
#define INCLUDE_vTaskSuspend 1 | |
#define INCLUDE_vTaskDelayUntil 1 | |
#define INCLUDE_vTaskDelay 1 | |
#define INCLUDE_pcTaskGetTaskName 1 | |
#define INCLUDE_pcTaskGetTaskName 1 | |
#define configASSERT( x ) if( ( x ) == 0 ) { portDISABLE_INTERRUPTS(); for( ;; ); } | |
/* Run time stats gathering definitions. The conditional compilation is to | |
prevent the C syntax being included in assembly files. */ | |
#ifndef __ASSEMBLER__ | |
unsigned long ulMainGetRunTimeCounterValue( void ); | |
void vMainConfigureTimerForRunTimeStats( void ); | |
#endif | |
#define configGENERATE_RUN_TIME_STATS 1 | |
#define portCONFIGURE_TIMER_FOR_RUN_TIME_STATS() vMainConfigureTimerForRunTimeStats() | |
#define portGET_RUN_TIME_COUNTER_VALUE() ulMainGetRunTimeCounterValue() | |
/* Networking configuration follows. */ | |
#define configLWIP_TASK_PRIORITY ( configMAX_PRIORITIES - 4 ) | |
/* MAC address configuration. */ | |
#define configMAC_ADDR0 0x00 | |
#define configMAC_ADDR1 0x12 | |
#define configMAC_ADDR2 0x13 | |
#define configMAC_ADDR3 0x10 | |
#define configMAC_ADDR4 0x15 | |
#define configMAC_ADDR5 0x11 | |
/* IP address configuration. */ | |
#define configIP_ADDR0 192 | |
#define configIP_ADDR1 168 | |
#define configIP_ADDR2 0 | |
#define configIP_ADDR3 200 | |
/* Gateway IP address configuration. */ | |
#define configGW_IP_ADDR0 192 | |
#define configGW_IP_ADDR1 168 | |
#define configGW_IP_ADDR2 0 | |
#define configGW_IP_ADDR3 3 | |
/* Netmask configuration. */ | |
#define configNET_MASK0 255 | |
#define configNET_MASK1 255 | |
#define configNET_MASK2 255 | |
#define configNET_MASK3 0 | |
#endif /* FREERTOS_CONFIG_H */ | |