rtconfig.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. /* RT-Thread config file */
  2. #ifndef __RTTHREAD_CFG_H__
  3. #define __RTTHREAD_CFG_H__
  4. // <RDTConfigurator URL="http://www.rt-thread.com/eclipse">
  5. // <integer name="RT_NAME_MAX" description="Maximal size of kernel object name length" default="6" />
  6. #define RT_NAME_MAX 8
  7. // <integer name="RT_ALIGN_SIZE" description="Alignment size for CPU architecture data access" default="4" />
  8. #define RT_ALIGN_SIZE 4
  9. // <integer name="RT_THREAD_PRIORITY_MAX" description="Maximal level of thread priority" default="32">
  10. // <item description="8">8</item>
  11. // <item description="32">32</item>
  12. // <item description="256">256</item>
  13. // </integer>
  14. #define RT_THREAD_PRIORITY_MAX 32
  15. // <integer name="RT_TICK_PER_SECOND" description="OS tick per second" default="100" />
  16. #define RT_TICK_PER_SECOND 1000
  17. // <integer name="IDLE_THREAD_STACK_SIZE" description="The stack size of idle thread" default="512" />
  18. #define IDLE_THREAD_STACK_SIZE 512
  19. // <bool name="RT_USING_MODULE" description="Using Application Module" default="true" />
  20. //#define RT_USING_MODULE
  21. // <section name="RT_DEBUG" description="Kernel Debug Configuration" default="true" >
  22. #define RT_DEBUG
  23. #define RT_DEBUG_COLOR
  24. // <bool name="RT_DEBUG_INIT" description="debug init enable" default=0 />
  25. #define RT_DEBUG_INIT 0
  26. //#define RT_DEBUG_SCHEDULER 1
  27. // <bool name="RT_THREAD_DEBUG" description="Thread debug enable" default="false" />
  28. // #define RT_THREAD_DEBUG
  29. // <bool name="RT_USING_OVERFLOW_CHECK" description="Thread stack over flow detect" default="true" />
  30. #define RT_USING_OVERFLOW_CHECK
  31. // </section>
  32. // <bool name="RT_USING_HOOK" description="Using hook functions" default="true" />
  33. #define RT_USING_HOOK
  34. // <section name="RT_USING_TIMER_SOFT" description="Using software timer which will start a thread to handle soft-timer" default="true" >
  35. //#define RT_USING_TIMER_SOFT
  36. // <integer name="RT_TIMER_THREAD_PRIO" description="The priority level of timer thread" default="4" />
  37. #define RT_TIMER_THREAD_PRIO 4
  38. // <integer name="RT_TIMER_THREAD_STACK_SIZE" description="The stack size of timer thread" default="512" />
  39. #define RT_TIMER_THREAD_STACK_SIZE 512
  40. // <integer name="RT_TIMER_TICK_PER_SECOND" description="The soft-timer tick per second" default="10" />
  41. #define RT_TIMER_TICK_PER_SECOND 100
  42. // </section>
  43. // <section name="IPC" description="Inter-Thread communication" default="always" >
  44. // <bool name="RT_USING_SEMAPHORE" description="Using semaphore in the system" default="true" />
  45. #define RT_USING_SEMAPHORE
  46. // <bool name="RT_USING_MUTEX" description="Using mutex in the system" default="true" />
  47. #define RT_USING_MUTEX
  48. // <bool name="RT_USING_EVENT" description="Using event group in the system" default="true" />
  49. #define RT_USING_EVENT
  50. // <bool name="RT_USING_MAILBOX" description="Using mailbox in the system" default="true" />
  51. #define RT_USING_MAILBOX
  52. // <bool name="RT_USING_MESSAGEQUEUE" description="Using message queue in the system" default="true" />
  53. #define RT_USING_MESSAGEQUEUE
  54. // </section>
  55. // <section name="MM" description="Memory Management" default="always" >
  56. // <bool name="RT_USING_MEMPOOL" description="Using Memory Pool Management in the system" default="true" />
  57. #define RT_USING_MEMPOOL
  58. // <bool name="RT_USING_MEMHEAP" description="Using Memory Heap Object in the system" default="true" />
  59. #define RT_USING_MEMHEAP
  60. // <bool name="RT_USING_HEAP" description="Using Dynamic Heap Management in the system" default="true" />
  61. #define RT_USING_HEAP
  62. // <bool name="RT_USING_SMALL_MEM" description="Optimizing for small memory" default="false" />
  63. #define RT_USING_SMALL_MEM
  64. // <bool name="RT_USING_SLAB" description="Using SLAB memory management for large memory" default="false" />
  65. // #define RT_USING_SLAB
  66. // </section>
  67. // <section name="RT_USING_DEVICE" description="Using Device Driver Framework" default="true" >
  68. #define RT_USING_DEVICE
  69. // <bool name=RT_USING_DEVICE_IPC description="Using IPC in Device Driver Framework" default="true" />
  70. #define RT_USING_DEVICE_IPC
  71. // <bool name="RT_USING_SERIAL" description="Using Serial Device Driver Framework" default="true" />
  72. #define RT_USING_SERIAL
  73. #define RT_SERIAL_USING_DMA
  74. // <integer name="RT_UART_RX_BUFFER_SIZE" description="The buffer size for UART reception" default="64" />
  75. #define RT_UART_RX_BUFFER_SIZE 256
  76. // <bool name="RT_USING_MTD_NAND" description="Using MTD NAND Framework" default="true" />
  77. //#define RT_USING_MTD_NAND
  78. // <bool name="RT_MTD_NAND_DEBUG" description="Enable MTD NAND Framework Debug" default="true" />
  79. //#define RT_MTD_NAND_DEBUG
  80. // <bool name="RT_USING_NFTL" description="Using NFTL layer" default="true" />
  81. //#define RT_USING_NFTL
  82. // <bool name="RT_USING_SPI" description="Using SPI Device Driver Framework" default="true" />
  83. //#define RT_USING_SPI
  84. // <bool name="RT_USING_I2C" description="Using I2C Device Driver Framework" default="true" />
  85. //#define RT_USING_I2C
  86. // <bool name="RT_USING_RTC" description="Using RTC Device Driver Framework" default="true" />
  87. //#define RT_USING_RTC
  88. // <integer name="RT_MMCSD_THREAD_PREORITY" description="The prority of mmcsd thread" default="15" />
  89. #define RT_MMCSD_THREAD_PREORITY 15
  90. // <section name="RT_USING_CONSOLE" description="Using console" default="true" >
  91. #define RT_USING_CONSOLE
  92. // <integer name="RT_CONSOLEBUF_SIZE" description="The buffer size for console output" default="128" />
  93. #define RT_CONSOLEBUF_SIZE 128
  94. // <string name="RT_CONSOLE_DEVICE_NAME" description="The device name for console" default="uart" />
  95. #define RT_CONSOLE_DEVICE_NAME "uart0"
  96. #define RT_USING_UART0
  97. // </section>
  98. // <bool name="RT_USING_COMPONENTS_INIT" description="Using RT-Thread components initialization" default="true" />
  99. //#define RT_USING_COMPONENTS_INIT
  100. // <section name="RT_USING_FINSH" description="Using finsh as shell, which is a C-Express shell" default="true" >
  101. #define RT_USING_FINSH
  102. // <bool name="FINSH_USING_SYMTAB" description="Using symbol table in finsh shell" default="true" />
  103. #define FINSH_USING_SYMTAB
  104. // <bool name="FINSH_USING_DESCRIPTION" description="Keeping description in symbol table" default="true" />
  105. #define FINSH_USING_DESCRIPTION
  106. // <integer name="FINSH_THREAD_STACK_SIZE" description="The stack size for finsh thread" default="4096" />
  107. #define FINSH_THREAD_STACK_SIZE 4096
  108. // <bool name="FINSH_USING_MSH" description="Using module shell in finsh" default="true" />
  109. //#define FINSH_USING_MSH
  110. // </section>
  111. // <section name="LIBC" description="C Runtime library setting" default="always" >
  112. // <bool name="RT_USING_NEWLIB" description="Using newlib library, only available under GNU GCC" default="true" />
  113. // #define RT_USING_NEWLIB
  114. // <bool name="RT_USING_PTHREADS" description="Using POSIX threads library" default="true" />
  115. //#define RT_USING_PTHREADS
  116. // </section>
  117. // <section name="RT_USING_DFS" description="Device file system" default="true" >
  118. //#define RT_USING_DFS
  119. // <bool name="DFS_USING_WORKDIR" description="Using working directory" default="true" />
  120. //#define DFS_USING_WORKDIR
  121. // <integer name="DFS_FILESYSTEM_TYPES_MAX" description="The maximal number of the supported file system type" default="4" />
  122. #define DFS_FILESYSTEM_TYPES_MAX 4
  123. // <integer name="DFS_FILESYSTEMS_MAX" description="The maximal number of mounted file system" default="4" />
  124. #define DFS_FILESYSTEMS_MAX 4
  125. // <integer name="DFS_FD_MAX" description="The maximal number of opened files" default="4" />
  126. #define DFS_FD_MAX 16
  127. // <bool name="RT_USING_DFS_ELMFAT" description="Using ELM FatFs" default="true" />
  128. #define RT_USING_DFS_ELMFAT
  129. // <integer name="RT_DFS_ELM_DRIVES" description="The maximal number of drives of FatFs" default="4" />
  130. #define RT_DFS_ELM_DRIVES 4
  131. // <bool name="RT_DFS_ELM_REENTRANT" description="Support reentrant" default="true" />
  132. #define RT_DFS_ELM_REENTRANT
  133. // <integer name="RT_DFS_ELM_USE_LFN" description="Support long file name" default="0">
  134. // <item description="LFN with static LFN working buffer">1</item>
  135. // <item description="LFN with dynamic LFN working buffer on the stack">2</item>
  136. // <item description="LFN with dynamic LFN working buffer on the heap">3</item>
  137. // </integer>
  138. #define RT_DFS_ELM_USE_LFN 3
  139. // <integer name="RT_DFS_ELM_CODE_PAGE" description="OEM code page" default="936">
  140. #define RT_DFS_ELM_CODE_PAGE 936
  141. // <bool name="RT_DFS_ELM_CODE_PAGE_FILE" description="Using OEM code page file" default="false" />
  142. #define RT_DFS_ELM_CODE_PAGE_FILE
  143. // <integer name="RT_DFS_ELM_MAX_LFN" description="Maximal size of file name length" default="255" />
  144. #define RT_DFS_ELM_MAX_LFN 255
  145. // <integer name="RT_DFS_ELM_MAX_SECTOR_SIZE" description="Maximal size of sector" default="512" />
  146. #define RT_DFS_ELM_MAX_SECTOR_SIZE 4096
  147. // <bool name="RT_DFS_ELM_USE_ERASE" description="Enable erase feature for flash" default="true" />
  148. #define RT_DFS_ELM_USE_ERASE
  149. // <bool name="RT_USING_DFS_YAFFS2" description="Using YAFFS2" default="false" />
  150. // #define RT_USING_DFS_YAFFS2
  151. // <bool name="RT_USING_DFS_UFFS" description="Using UFFS" default="false" />
  152. // #define RT_USING_DFS_UFFS
  153. // <bool name="RT_USING_DFS_DEVFS" description="Using devfs for device objects" default="true" />
  154. #define RT_USING_DFS_DEVFS
  155. // <bool name="RT_USING_DFS_ROMFS" description="Using ROMFS" default="false" />
  156. //#define RT_USING_DFS_ROMFS
  157. // <bool name="RT_USING_DFS_NFS" description="Using NFS" default="false" />
  158. //#define RT_USING_DFS_NFS
  159. // <string name="RT_NFS_HOST_EXPORT" description="The exported NFS host path" default="192.168.1.10:/" />
  160. #define RT_NFS_HOST_EXPORT "192.168.1.20:/"
  161. // </section>
  162. // <section name="RT_USING_LWIP" description="lwip, a lightweight TCP/IP protocol stack" default="true" >
  163. //#define RT_USING_LWIP
  164. // <bool name="RT_USING_LWIP141" description="Using lwIP 1.4.1 version" default="true" />
  165. #define RT_USING_LWIP141
  166. // <bool name="RT_LWIP_ICMP" description="Enable ICMP protocol" default="true" />
  167. #define RT_LWIP_ICMP
  168. // <bool name="RT_LWIP_IGMP" description="Enable IGMP protocol" default="false" />
  169. // #define RT_LWIP_IGMP
  170. // <bool name="RT_LWIP_UDP" description="Enable UDP protocol" default="true" />
  171. #define RT_LWIP_UDP
  172. // <bool name="RT_LWIP_TCP" description="Enable TCP protocol" default="true" />
  173. #define RT_LWIP_TCP
  174. // <bool name="RT_LWIP_DNS" description="Enable DNS protocol" default="true" />
  175. #define RT_LWIP_DNS
  176. // <integer name="RT_LWIP_PBUF_NUM" description="Maximal number of buffers in the pbuf pool" default="4" />
  177. #define RT_LWIP_PBUF_NUM 4
  178. // <integer name="RT_LWIP_TCP_PCB_NUM" description="Maximal number of simultaneously active TCP connections" default="5" />
  179. #define RT_LWIP_TCP_PCB_NUM 3
  180. // <integer name="RT_LWIP_TCP_SND_BUF" description="TCP sender buffer size" default="8192" />
  181. #define RT_LWIP_TCP_SND_BUF 4086
  182. // <integer name="RT_LWIP_TCP_WND" description="TCP receive window" default="8192" />
  183. #define RT_LWIP_TCP_WND 2048
  184. // <bool name="RT_LWIP_SNMP" description="Enable SNMP protocol" default="false" />
  185. // #define RT_LWIP_SNMP
  186. // <bool name="RT_LWIP_DHCP" description="Enable DHCP client to get IP address" default="false" />
  187. // #define RT_LWIP_DHCP
  188. // <integer name="RT_LWIP_TCP_SEG_NUM" description="the number of simultaneously queued TCP" default="4" />
  189. #define RT_LWIP_TCP_SEG_NUM 8
  190. // <integer name="RT_LWIP_TCPTHREAD_PRIORITY" description="the thread priority of TCP thread" default="128" />
  191. #define RT_LWIP_TCPTHREAD_PRIORITY 12
  192. // <integer name="RT_LWIP_TCPTHREAD_MBOX_SIZE" description="the mail box size of TCP thread to wait for" default="32" />
  193. #define RT_LWIP_TCPTHREAD_MBOX_SIZE 8
  194. // <integer name="RT_LWIP_TCPTHREAD_STACKSIZE" description="the thread stack size of TCP thread" default="4096" />
  195. #define RT_LWIP_TCPTHREAD_STACKSIZE 4096
  196. // <integer name="RT_LWIP_ETHTHREAD_PRIORITY" description="the thread priority of ethnetif thread" default="144" />
  197. #define RT_LWIP_ETHTHREAD_PRIORITY 14
  198. // <integer name="RT_LWIP_ETHTHREAD_MBOX_SIZE" description="the mail box size of ethnetif thread to wait for" default="8" />
  199. #define RT_LWIP_ETHTHREAD_MBOX_SIZE 8
  200. // <integer name="RT_LWIP_ETHTHREAD_STACKSIZE" description="the stack size of ethnetif thread" default="512" />
  201. #define RT_LWIP_ETHTHREAD_STACKSIZE 512
  202. // <ipaddr name="RT_LWIP_IPADDR" description="IP address of device" default="192.168.1.30" />
  203. #define RT_LWIP_IPADDR0 192
  204. #define RT_LWIP_IPADDR1 168
  205. #define RT_LWIP_IPADDR2 1
  206. #define RT_LWIP_IPADDR3 30
  207. // <ipaddr name="RT_LWIP_GWADDR" description="Gateway address of device" default="192.168.1.1" />
  208. #define RT_LWIP_GWADDR0 192
  209. #define RT_LWIP_GWADDR1 168
  210. #define RT_LWIP_GWADDR2 1
  211. #define RT_LWIP_GWADDR3 1
  212. // <ipaddr name="RT_LWIP_MSKADDR" description="Mask address of device" default="255.255.255.0" />
  213. #define RT_LWIP_MSKADDR0 255
  214. #define RT_LWIP_MSKADDR1 255
  215. #define RT_LWIP_MSKADDR2 255
  216. #define RT_LWIP_MSKADDR3 0
  217. // </section>
  218. #define RT_USING_VBUS
  219. // </RDTConfigurator>
  220. #endif