2011-07-08 07:13:20 +00:00
|
|
|
/***************************************************************************//**
|
2011-12-16 01:05:50 +00:00
|
|
|
* @file rtconfig.h
|
|
|
|
* @brief RT-Thread config file
|
2011-02-17 03:33:15 +00:00
|
|
|
* COPYRIGHT (C) 2009, RT-Thread Development Team
|
2011-12-16 01:05:50 +00:00
|
|
|
* @author
|
2011-07-08 07:13:20 +00:00
|
|
|
* @version 0.4 beta
|
|
|
|
*******************************************************************************
|
2011-02-17 03:33:15 +00:00
|
|
|
* @section License
|
2011-12-16 01:05:50 +00:00
|
|
|
* The license and distribution terms for this file may be found in the file
|
2011-07-08 07:13:20 +00:00
|
|
|
* LICENSE in this distribution or at http://www.rt-thread.org/license/LICENSE
|
|
|
|
******************************************************************************/
|
2011-02-17 03:33:15 +00:00
|
|
|
#ifndef __RTTHREAD_CFG_H__
|
|
|
|
#define __RTTHREAD_CFG_H__
|
|
|
|
|
2011-07-08 07:13:20 +00:00
|
|
|
/* Includes ------------------------------------------------------------------*/
|
|
|
|
/* Exported types ------------------------------------------------------------*/
|
|
|
|
/* Exported constants --------------------------------------------------------*/
|
|
|
|
/* Exported macro ------------------------------------------------------------*/
|
2011-02-17 03:33:15 +00:00
|
|
|
/* RT_NAME_MAX*/
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_NAME_MAX (8)
|
2011-02-17 03:33:15 +00:00
|
|
|
|
|
|
|
/* RT_ALIGN_SIZE*/
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_ALIGN_SIZE (4)
|
2011-02-17 03:33:15 +00:00
|
|
|
|
|
|
|
/* PRIORITY_MAX */
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_THREAD_PRIORITY_MAX (32)
|
2011-02-17 03:33:15 +00:00
|
|
|
|
|
|
|
/* Tick per Second */
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_TICK_PER_SECOND (100)
|
2011-02-17 03:33:15 +00:00
|
|
|
|
|
|
|
/* SECTION: RT_DEBUG */
|
|
|
|
#define RT_DEBUG
|
2011-07-11 06:16:26 +00:00
|
|
|
//#define RT_DEBUG_MEM (1)
|
2011-07-08 07:13:20 +00:00
|
|
|
//#define RT_DEBUG_SCHEDULER (1)
|
2011-07-29 02:47:37 +00:00
|
|
|
//#define RT_DEBUG_IPC (1)
|
2011-02-17 03:33:15 +00:00
|
|
|
//#define THREAD_DEBUG
|
|
|
|
//#define IRQ_DEBUG
|
2011-03-29 09:41:22 +00:00
|
|
|
#define RT_USING_OVERFLOW_CHECK
|
2011-07-08 07:13:20 +00:00
|
|
|
//#define DFS_DEBUG
|
|
|
|
#define RT_LWIP_DEBUG
|
2011-03-29 09:41:22 +00:00
|
|
|
|
2011-02-17 03:33:15 +00:00
|
|
|
//#define RT_IRQHDL_DEBUG
|
2011-07-08 07:13:20 +00:00
|
|
|
//#define RT_USART_DEBUG
|
2011-12-16 01:05:50 +00:00
|
|
|
//#define RT_LEUART_DEBUG
|
2011-06-20 01:56:28 +00:00
|
|
|
//#define RT_IIC_DEBUG
|
|
|
|
//#define RT_MISC_DEBUG
|
2011-02-28 04:47:50 +00:00
|
|
|
//#define RT_ADC_DEBUG
|
2011-03-29 09:41:22 +00:00
|
|
|
//#define RT_ACMP_DEBUG
|
|
|
|
//#define RT_TIMER_DEBUG
|
2011-06-20 01:56:28 +00:00
|
|
|
//#define RT_RTC_DEBUG
|
|
|
|
|
2011-07-29 02:47:37 +00:00
|
|
|
#define EFM32_DEBUG
|
2011-08-23 00:59:24 +00:00
|
|
|
#define EFM32_ACCEL_DEBUG
|
2011-06-20 01:56:28 +00:00
|
|
|
#define EFM32_SFLASH_DEBUG
|
|
|
|
//#define EFM32_SDCARD_DEBUG
|
2011-07-29 02:47:37 +00:00
|
|
|
//#define EFM32_ETHERNET_DEBUG
|
2011-07-08 07:13:20 +00:00
|
|
|
|
2011-02-17 03:33:15 +00:00
|
|
|
|
|
|
|
/* Using Hook */
|
2011-03-29 09:41:22 +00:00
|
|
|
//#define RT_USING_HOOK
|
2011-02-17 03:33:15 +00:00
|
|
|
|
|
|
|
/* Using Software Timer */
|
|
|
|
/* #define RT_USING_TIMER_SOFT */
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_TIMER_THREAD_PRIO (4)
|
|
|
|
#define RT_TIMER_THREAD_STACK_SIZE (512)
|
|
|
|
#define RT_TIMER_TICK_PER_SECOND (10)
|
2011-02-17 03:33:15 +00:00
|
|
|
|
|
|
|
/* SECTION: IPC */
|
|
|
|
/* Using Semaphore*/
|
2011-12-16 01:05:50 +00:00
|
|
|
#define RT_USING_SEMAPHORE /* Using by DFS and lwIP */
|
2011-02-17 03:33:15 +00:00
|
|
|
/* Using Mutex */
|
2011-12-16 01:05:50 +00:00
|
|
|
#define RT_USING_MUTEX /* Using by DFS */
|
2011-02-17 03:33:15 +00:00
|
|
|
/* Using Event */
|
2011-03-29 09:41:22 +00:00
|
|
|
//#define RT_USING_EVENT
|
2011-02-17 03:33:15 +00:00
|
|
|
/* Using MailBox */
|
2011-12-16 01:05:50 +00:00
|
|
|
#define RT_USING_MAILBOX /* Using by lwIP */
|
2011-02-17 03:33:15 +00:00
|
|
|
/* Using Message Queue */
|
2011-03-29 09:41:22 +00:00
|
|
|
//#define RT_USING_MESSAGEQUEUE
|
2011-02-17 03:33:15 +00:00
|
|
|
/* SECTION: Memory Management */
|
|
|
|
/* Using Memory Pool Management*/
|
2011-03-29 09:41:22 +00:00
|
|
|
//#define RT_USING_MEMPOOL
|
2011-02-17 03:33:15 +00:00
|
|
|
|
|
|
|
/* Using Dynamic Heap Management */
|
|
|
|
#define RT_USING_HEAP
|
|
|
|
|
|
|
|
/* Using Small MM */
|
|
|
|
#define RT_USING_SMALL_MEM
|
|
|
|
|
|
|
|
/* SECTION: Device System */
|
|
|
|
/* Using Device System */
|
|
|
|
#define RT_USING_DEVICE
|
|
|
|
|
2011-12-16 01:05:50 +00:00
|
|
|
/* USART/UART/LEUART Device for Console */
|
|
|
|
#if defined(EFM32_G8XX_STK)
|
|
|
|
#define RT_USING_USART1 (0x1UL)
|
|
|
|
#define RT_USART1_NAME "debug"
|
|
|
|
//#define RT_USART1_USING_DMA (0x0UL)
|
|
|
|
#elif defined(EFM32_GXXX_DK)
|
|
|
|
#define RT_USING_USART1 (0x0UL)
|
|
|
|
#define RT_USART1_NAME "debug"
|
|
|
|
//#define RT_USART1_USING_DMA (0x0UL)
|
|
|
|
#elif defined(EFM32GG_DK3750)
|
|
|
|
#define EFM32GG_DK3750_USING_LEUART1
|
|
|
|
#if defined(EFM32GG_DK3750_USING_LEUART1)
|
|
|
|
#define RT_USING_LEUART1 (0x0UL)
|
|
|
|
#define RT_LEUART1_NAME "debug0"
|
|
|
|
//#define RT_LEUART1_USING_DMA (0x0UL)
|
|
|
|
#else
|
|
|
|
#define RT_USING_UART1 (0x2UL)
|
|
|
|
#define RT_UART1_NAME "debug"
|
|
|
|
//#define RT_UART1_USING_DMA (0x0UL)
|
|
|
|
#endif
|
2011-02-17 03:33:15 +00:00
|
|
|
#endif
|
|
|
|
|
2011-05-12 07:19:37 +00:00
|
|
|
/* SECTION: SPI options */
|
2011-12-16 01:05:50 +00:00
|
|
|
#if defined(EFM32_G8XX_STK)
|
2011-07-08 07:13:20 +00:00
|
|
|
//#define RT_USING_USART0 (0x0UL)
|
|
|
|
//#define RT_USART0_SYNC_MODE (0x1UL) /* Master */
|
|
|
|
//#define RT_USART0_NAME "spi0"
|
|
|
|
//#define RT_USART0_USING_DMA (0x1UL)
|
2011-12-16 01:05:50 +00:00
|
|
|
#elif defined(EFM32_GXXX_DK)
|
|
|
|
#define RT_USING_USART0 (0x2UL)
|
|
|
|
#define RT_USART0_SYNC_MODE (0x1UL) /* Master */
|
|
|
|
#define RT_USART0_NAME "spi0"
|
|
|
|
#define RT_USART0_USING_DMA (0x1UL)
|
|
|
|
|
|
|
|
#define RT_USING_USART2 (0x1UL)
|
|
|
|
#define RT_USART2_SYNC_MODE (0x1UL) /* Master */
|
|
|
|
#define RT_USART2_NAME "spi2"
|
|
|
|
#define RT_USART2_USING_DMA (0x2UL)
|
|
|
|
|
|
|
|
#elif defined(EFM32GG_DK3750)
|
|
|
|
#define RT_USING_USART0 (0x1UL)
|
|
|
|
#define RT_USART0_SYNC_MODE (0x1UL) /* Master */
|
|
|
|
#define RT_USART0_NAME "spi0"
|
|
|
|
#define RT_USART0_USING_DMA (0x1UL)
|
|
|
|
|
|
|
|
#define RT_USING_USART1 (0x1UL)
|
|
|
|
#define RT_USART1_SYNC_MODE (0x1UL) /* Master */
|
|
|
|
#define RT_USART1_NAME "spi1"
|
|
|
|
#define RT_USART1_USING_DMA (0x2UL)
|
|
|
|
|
2011-05-12 07:19:37 +00:00
|
|
|
#endif
|
|
|
|
|
2011-06-20 01:56:28 +00:00
|
|
|
/* SECTION: IIC options */
|
2011-08-23 04:36:33 +00:00
|
|
|
//#define RT_USING_IIC0 0x3UL
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_IIC0_NAME "iic0"
|
2011-02-28 04:47:50 +00:00
|
|
|
|
2011-06-20 01:56:28 +00:00
|
|
|
/* SECTION: ACMP options */
|
|
|
|
//#define RT_USING_ACMP0
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_ACMP0_NAME "acmp0"
|
2011-02-28 04:47:50 +00:00
|
|
|
|
|
|
|
/* SECTION: ADC options */
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_USING_ADC0
|
2011-07-29 02:47:37 +00:00
|
|
|
#define RT_ADC0_NAME "adc0"
|
|
|
|
#if defined(RT_USING_ADC0)
|
|
|
|
#define RT_USING_MISC
|
|
|
|
#endif
|
2011-02-28 04:47:50 +00:00
|
|
|
|
2011-06-20 01:56:28 +00:00
|
|
|
/* SECTION: TIMER options */
|
2011-07-08 07:13:20 +00:00
|
|
|
//#define RT_USING_TIMER2 (0x00) /* Continuous mode */
|
|
|
|
#define RT_TIMER2_NAME "tmr2"
|
2011-06-20 01:56:28 +00:00
|
|
|
|
|
|
|
/* SECTION: RTC options */
|
2011-12-16 01:05:50 +00:00
|
|
|
#if (defined(EFM32_G8XX_STK) || defined(EFM32_GXXX_DK) || defined(EFM32GG_DK3750))
|
|
|
|
#define RT_USING_RTC
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_RTC_NAME "rtc"
|
2011-06-20 01:56:28 +00:00
|
|
|
#endif
|
|
|
|
|
2011-02-17 03:33:15 +00:00
|
|
|
/* SECTION: Serial options */
|
2011-12-16 01:05:50 +00:00
|
|
|
#define EFM_USART0 (0x00UL)
|
|
|
|
#define EFM_USART1 (0x01UL)
|
|
|
|
#define EFM_USART2 (0x02UL)
|
|
|
|
#define EFM_UART0 (0x10UL)
|
|
|
|
#define EFM_UART1 (0x11UL)
|
|
|
|
#define EFM_LEUART0 (0x20UL)
|
|
|
|
#define EFM_LEUART1 (0x21UL)
|
|
|
|
|
|
|
|
#if defined(EFM32_G8XX_STK)
|
|
|
|
#define RT_CONSOLE_DEVICE (EFM_USART1)
|
|
|
|
#elif defined(EFM32_GXXX_DK)
|
|
|
|
#define RT_CONSOLE_DEVICE (EFM_USART1)
|
|
|
|
#elif defined(EFM32GG_DK3750)
|
|
|
|
#if defined(EFM32GG_DK3750_USING_LEUART1)
|
|
|
|
#define RT_CONSOLE_DEVICE (EFM_LEUART1)
|
|
|
|
#else
|
|
|
|
#define RT_CONSOLE_DEVICE (EFM_UART1)
|
|
|
|
#endif
|
2011-02-17 03:33:15 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* SECTION: Console options */
|
2011-03-29 09:41:22 +00:00
|
|
|
#define RT_USING_CONSOLE
|
2011-02-17 03:33:15 +00:00
|
|
|
/* the buffer size of console*/
|
2011-07-08 07:13:20 +00:00
|
|
|
#define RT_CONSOLEBUF_SIZE (128)
|
2011-02-17 03:33:15 +00:00
|
|
|
|
|
|
|
/* SECTION: finsh, a C-Express shell */
|
|
|
|
#define RT_USING_FINSH
|
|
|
|
/* Using symbol table */
|
|
|
|
#define FINSH_USING_SYMTAB
|
|
|
|
#define FINSH_USING_DESCRIPTION
|
|
|
|
|
2011-07-29 02:47:37 +00:00
|
|
|
/* SECTION: Peripheral devices */
|
2011-08-23 00:59:24 +00:00
|
|
|
#define EFM32_INTERFACE_ADC (0)
|
|
|
|
#define EFM32_INTERFACE_IIC (1)
|
|
|
|
#define EFM32_INTERFACE_SPI (2)
|
2011-12-16 01:05:50 +00:00
|
|
|
#if (defined(EFM32_GXXX_DK) || defined(EFM32GG_DK3750))
|
2011-08-23 04:36:33 +00:00
|
|
|
//#define EFM32_USING_ACCEL EFM32_INTERFACE_IIC /* Three axis accelerometer */
|
2011-08-23 00:59:24 +00:00
|
|
|
//#define EFM32_USING_SFLASH /* SPI Flash */
|
2011-12-16 01:05:50 +00:00
|
|
|
#define EFM32_USING_SPISD /* MicroSD card */
|
|
|
|
//#define EFM32_USING_ETHERNET /* Ethernet controller */
|
2011-07-29 02:47:37 +00:00
|
|
|
#endif
|
2011-08-23 00:59:24 +00:00
|
|
|
|
2011-07-29 02:47:37 +00:00
|
|
|
#if defined(EFM32_USING_ACCEL)
|
2011-08-23 00:59:24 +00:00
|
|
|
#if (EFM32_USING_ACCEL == EFM32_INTERFACE_ADC)
|
2011-07-29 02:47:37 +00:00
|
|
|
#define ACCEL_USING_DEVICE_NAME RT_ADC0_NAME
|
2011-08-23 00:59:24 +00:00
|
|
|
#define ACCEL_USING_DMA (0x3UL) /* For multiple channels scan mode */
|
|
|
|
#elif (EFM32_USING_ACCEL == EFM32_INTERFACE_IIC)
|
|
|
|
#define ACCEL_USING_DEVICE_NAME RT_IIC0_NAME
|
|
|
|
#endif
|
2011-06-20 01:56:28 +00:00
|
|
|
#endif
|
2011-08-23 00:59:24 +00:00
|
|
|
|
2011-06-20 01:56:28 +00:00
|
|
|
#if defined(EFM32_USING_SFLASH)
|
|
|
|
#define SFLASH_USING_DEVICE_NAME RT_USART0_NAME
|
|
|
|
#endif
|
2011-08-23 00:59:24 +00:00
|
|
|
|
2011-06-20 01:56:28 +00:00
|
|
|
#if defined(EFM32_USING_SPISD)
|
|
|
|
#define SPISD_USING_DEVICE_NAME RT_USART0_NAME
|
|
|
|
#define SPISD_DEVICE_NAME "spiSd"
|
|
|
|
#endif
|
2011-08-23 00:59:24 +00:00
|
|
|
|
2011-07-08 07:13:20 +00:00
|
|
|
#if defined(EFM32_USING_ETHERNET)
|
2011-12-16 01:05:50 +00:00
|
|
|
#if defined(EFM32_GXXX_DK)
|
|
|
|
#define ETH_USING_DEVICE_NAME RT_USART2_NAME
|
|
|
|
#elif defined(EFM32GG_DK3750)
|
|
|
|
#define ETH_USING_DEVICE_NAME RT_USART1_NAME
|
|
|
|
#endif
|
2011-07-08 07:13:20 +00:00
|
|
|
#define ETH_DEVICE_NAME "spiEth"
|
2011-07-29 02:47:37 +00:00
|
|
|
#define ETH_ADDR_DEFAULT {0x00, 0x01, 0x02, 0x03, 0x04, 0x05}
|
2011-07-08 07:13:20 +00:00
|
|
|
#endif
|
2011-06-20 01:56:28 +00:00
|
|
|
|
|
|
|
/* SECTION: device filesystem */
|
2011-07-08 07:13:20 +00:00
|
|
|
#if defined(EFM32_USING_SPISD)
|
2011-12-16 01:05:50 +00:00
|
|
|
#define RT_USING_DFS
|
|
|
|
#define RT_USING_DFS_ELMFAT
|
2011-06-20 01:56:28 +00:00
|
|
|
#define DFS_ELMFAT_INTERFACE_EFM
|
|
|
|
/* the max number of mounted filesystem */
|
2011-12-16 01:05:50 +00:00
|
|
|
#define DFS_FILESYSTEMS_MAX (2)
|
2011-06-20 01:56:28 +00:00
|
|
|
/* the max number of opened files */
|
2011-12-16 01:05:50 +00:00
|
|
|
#define DFS_FD_MAX (4)
|
2011-06-20 01:56:28 +00:00
|
|
|
/* the max number of cached sector */
|
2011-12-16 01:05:50 +00:00
|
|
|
#define DFS_CACHE_MAX_NUM (4)
|
2011-07-29 02:47:37 +00:00
|
|
|
#endif /* defined(EFM32_USING_SPISD) */
|
2011-07-08 07:13:20 +00:00
|
|
|
|
|
|
|
/* SECTION: lwip, a lighwight TCP/IP protocol stack */
|
|
|
|
#if defined(EFM32_USING_ETHERNET)
|
2011-07-29 02:47:37 +00:00
|
|
|
#define EFM32_USING_ETH_HTTPD
|
|
|
|
//#define EFM32_USING_ETH_UTILS
|
|
|
|
//#define hostName "onelife.dyndns.org"
|
|
|
|
//#define userPwdB64 "dXNlcjpwYXNzd2Q="
|
|
|
|
|
2011-12-16 01:05:50 +00:00
|
|
|
//#define RT_USING_LWIP
|
2011-07-08 08:24:33 +00:00
|
|
|
//#define RT_USING_NETUTILS
|
2011-07-08 07:13:20 +00:00
|
|
|
/* LwIP uses RT-Thread Memory Management */
|
|
|
|
#define RT_LWIP_USING_RT_MEM
|
|
|
|
/* Enable ICMP protocol*/
|
|
|
|
#define RT_LWIP_ICMP
|
2011-07-29 02:47:37 +00:00
|
|
|
/* Enable ICMP protocol*/
|
|
|
|
//#define RT_LWIP_IGMP
|
2011-07-08 07:13:20 +00:00
|
|
|
/* Enable UDP protocol*/
|
|
|
|
#define RT_LWIP_UDP
|
|
|
|
/* Enable TCP protocol*/
|
|
|
|
#define RT_LWIP_TCP
|
2011-07-29 02:47:37 +00:00
|
|
|
/* Enable DHCP */
|
|
|
|
//#define RT_LWIP_DHCP
|
2011-07-08 07:13:20 +00:00
|
|
|
/* Enable DNS */
|
|
|
|
//#define RT_LWIP_DNS
|
|
|
|
|
|
|
|
/* the number of simulatenously active TCP connections*/
|
|
|
|
#define RT_LWIP_TCP_PCB_NUM (2)
|
|
|
|
|
|
|
|
/* ip address of target*/
|
|
|
|
#define RT_LWIP_IPADDR0 (192)
|
|
|
|
#define RT_LWIP_IPADDR1 (168)
|
|
|
|
#define RT_LWIP_IPADDR2 (1)
|
|
|
|
#define RT_LWIP_IPADDR3 (118)
|
|
|
|
|
|
|
|
/* gateway address of target*/
|
|
|
|
#define RT_LWIP_GWADDR0 (192)
|
|
|
|
#define RT_LWIP_GWADDR1 (168)
|
|
|
|
#define RT_LWIP_GWADDR2 (1)
|
|
|
|
#define RT_LWIP_GWADDR3 (1)
|
|
|
|
|
|
|
|
/* mask address of target*/
|
|
|
|
#define RT_LWIP_MSKADDR0 (255)
|
|
|
|
#define RT_LWIP_MSKADDR1 (255)
|
|
|
|
#define RT_LWIP_MSKADDR2 (255)
|
|
|
|
#define RT_LWIP_MSKADDR3 (0)
|
|
|
|
|
|
|
|
/* tcp thread options */
|
|
|
|
#define RT_LWIP_TCPTHREAD_PRIORITY (12)
|
|
|
|
#define RT_LWIP_TCPTHREAD_MBOX_SIZE (4)
|
2011-07-29 02:47:37 +00:00
|
|
|
#define RT_LWIP_TCPTHREAD_STACKSIZE (1024)
|
2011-07-08 07:13:20 +00:00
|
|
|
|
|
|
|
/* ethernet if thread options */
|
|
|
|
#define RT_LWIP_ETHTHREAD_PRIORITY (15)
|
|
|
|
#define RT_LWIP_ETHTHREAD_MBOX_SIZE (4)
|
|
|
|
#define RT_LWIP_ETHTHREAD_STACKSIZE (512)
|
2011-07-29 02:47:37 +00:00
|
|
|
#endif /* defined(EFM32_USING_ETHERNET) */
|
2011-06-20 01:56:28 +00:00
|
|
|
|
2011-07-08 07:13:20 +00:00
|
|
|
/* Exported functions ------------------------------------------------------- */
|
2011-02-17 03:33:15 +00:00
|
|
|
|
2011-05-12 07:19:37 +00:00
|
|
|
#endif /* __RTTHREAD_CFG_H__ */
|