phytium_pi_rtthread.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541
  1. #ifndef RT_CONFIG_H__
  2. #define RT_CONFIG_H__
  3. /* RT-Thread Kernel */
  4. #define RT_NAME_MAX 16
  5. #define RT_USING_SMP
  6. #define RT_CPUS_NR 4
  7. #define RT_ALIGN_SIZE 4
  8. #define RT_THREAD_PRIORITY_32
  9. #define RT_THREAD_PRIORITY_MAX 32
  10. #define RT_TICK_PER_SECOND 1000
  11. #define RT_USING_HOOK
  12. #define RT_HOOK_USING_FUNC_PTR
  13. #define RT_USING_IDLE_HOOK
  14. #define RT_IDLE_HOOK_LIST_SIZE 4
  15. #define IDLE_THREAD_STACK_SIZE 8192
  16. #define SYSTEM_THREAD_STACK_SIZE 8192
  17. #define RT_USING_TIMER_SOFT
  18. #define RT_TIMER_THREAD_PRIO 4
  19. #define RT_TIMER_THREAD_STACK_SIZE 8192
  20. /* kservice optimization */
  21. /* end of kservice optimization */
  22. /* klibc optimization */
  23. #define RT_KLIBC_USING_VSNPRINTF_LONGLONG
  24. /* end of klibc optimization */
  25. #define RT_USING_DEBUG
  26. #define RT_DEBUGING_ASSERT
  27. #define RT_DEBUGING_COLOR
  28. #define RT_DEBUGING_CONTEXT
  29. #define RT_USING_OVERFLOW_CHECK
  30. /* Inter-Thread communication */
  31. #define RT_USING_SEMAPHORE
  32. #define RT_USING_MUTEX
  33. #define RT_USING_EVENT
  34. #define RT_USING_MAILBOX
  35. #define RT_USING_MESSAGEQUEUE
  36. /* end of Inter-Thread communication */
  37. /* Memory Management */
  38. #define RT_PAGE_MAX_ORDER 16
  39. #define RT_USING_SLAB
  40. #define RT_USING_MEMHEAP
  41. #define RT_MEMHEAP_FAST_MODE
  42. #define RT_USING_SLAB_AS_HEAP
  43. #define RT_USING_HEAP_ISR
  44. #define RT_USING_HEAP
  45. /* end of Memory Management */
  46. #define RT_USING_DEVICE
  47. #define RT_USING_SCHED_THREAD_CTX
  48. #define RT_USING_CONSOLE
  49. #define RT_CONSOLEBUF_SIZE 128
  50. #define RT_CONSOLE_DEVICE_NAME "uart1"
  51. #define RT_VER_NUM 0x50200
  52. #define RT_BACKTRACE_LEVEL_MAX_NR 32
  53. /* end of RT-Thread Kernel */
  54. /* AArch64 Architecture Configuration */
  55. #define ARCH_TEXT_OFFSET 0x80000
  56. #define ARCH_RAM_OFFSET 0x80000000
  57. #define ARCH_SECONDARY_CPU_STACK_SIZE 4096
  58. #define ARCH_HAVE_EFFICIENT_UNALIGNED_ACCESS
  59. #define ARCH_HEAP_SIZE 0x4000000
  60. #define ARCH_INIT_PAGE_SIZE 0x200000
  61. /* end of AArch64 Architecture Configuration */
  62. #define ARCH_CPU_64BIT
  63. #define RT_USING_CACHE
  64. #define RT_USING_HW_ATOMIC
  65. #define ARCH_ARM_BOOTWITH_FLUSH_CACHE
  66. #define RT_USING_CPU_FFS
  67. #define ARCH_MM_MMU
  68. #define ARCH_ARM
  69. #define ARCH_ARM_MMU
  70. #define ARCH_ARMV8
  71. /* RT-Thread Components */
  72. #define RT_USING_COMPONENTS_INIT
  73. #define RT_USING_USER_MAIN
  74. #define RT_MAIN_THREAD_STACK_SIZE 8192
  75. #define RT_MAIN_THREAD_PRIORITY 10
  76. #define RT_USING_MSH
  77. #define RT_USING_FINSH
  78. #define FINSH_USING_MSH
  79. #define FINSH_THREAD_NAME "tshell"
  80. #define FINSH_THREAD_PRIORITY 20
  81. #define FINSH_THREAD_STACK_SIZE 4096
  82. #define FINSH_USING_HISTORY
  83. #define FINSH_HISTORY_LINES 5
  84. #define FINSH_USING_SYMTAB
  85. #define FINSH_CMD_SIZE 80
  86. #define MSH_USING_BUILT_IN_COMMANDS
  87. #define FINSH_USING_DESCRIPTION
  88. #define FINSH_ARG_MAX 10
  89. #define FINSH_USING_OPTION_COMPLETION
  90. /* DFS: device virtual file system */
  91. #define RT_USING_DFS
  92. #define DFS_USING_POSIX
  93. #define DFS_USING_WORKDIR
  94. #define DFS_FD_MAX 16
  95. #define RT_USING_DFS_V1
  96. #define DFS_FILESYSTEMS_MAX 4
  97. #define DFS_FILESYSTEM_TYPES_MAX 4
  98. #define RT_USING_DFS_ELMFAT
  99. /* elm-chan's FatFs, Generic FAT Filesystem Module */
  100. #define RT_DFS_ELM_CODE_PAGE 437
  101. #define RT_DFS_ELM_WORD_ACCESS
  102. #define RT_DFS_ELM_USE_LFN_3
  103. #define RT_DFS_ELM_USE_LFN 3
  104. #define RT_DFS_ELM_LFN_UNICODE_0
  105. #define RT_DFS_ELM_LFN_UNICODE 0
  106. #define RT_DFS_ELM_MAX_LFN 255
  107. #define RT_DFS_ELM_DRIVES 2
  108. #define RT_DFS_ELM_MAX_SECTOR_SIZE 512
  109. #define RT_DFS_ELM_REENTRANT
  110. #define RT_DFS_ELM_MUTEX_TIMEOUT 3000
  111. /* end of elm-chan's FatFs, Generic FAT Filesystem Module */
  112. #define RT_USING_DFS_DEVFS
  113. #define RT_USING_DFS_RAMFS
  114. /* end of DFS: device virtual file system */
  115. /* Device Drivers */
  116. #define RT_USING_DEV_BUS
  117. #define RT_USING_DEVICE_IPC
  118. #define RT_UNAMED_PIPE_NUMBER 64
  119. #define RT_USING_SYSTEM_WORKQUEUE
  120. #define RT_SYSTEM_WORKQUEUE_STACKSIZE 8192
  121. #define RT_SYSTEM_WORKQUEUE_PRIORITY 23
  122. #define RT_USING_SERIAL
  123. #define RT_USING_SERIAL_V1
  124. #define RT_SERIAL_USING_DMA
  125. #define RT_SERIAL_RB_BUFSZ 64
  126. #define RT_USING_CAN
  127. #define RT_CAN_USING_CANFD
  128. #define RT_USING_I2C
  129. #define RT_USING_I2C_BITOPS
  130. #define RT_USING_NULL
  131. #define RT_USING_ZERO
  132. #define RT_USING_RANDOM
  133. #define RT_USING_PWM
  134. #define RT_USING_RTC
  135. #define RT_USING_SDIO
  136. #define RT_SDIO_STACK_SIZE 8192
  137. #define RT_SDIO_THREAD_PRIORITY 15
  138. #define RT_MMCSD_STACK_SIZE 8192
  139. #define RT_MMCSD_THREAD_PRIORITY 22
  140. #define RT_MMCSD_MAX_PARTITION 16
  141. #define RT_USING_SPI
  142. #define RT_USING_QSPI
  143. #define RT_USING_PIN
  144. #define RT_USING_KTIME
  145. #define RT_USING_CHERRYUSB
  146. #define RT_CHERRYUSB_HOST
  147. #define RT_CHERRYUSB_HOST_XHCI
  148. #define RT_CHERRYUSB_HOST_HID
  149. #define RT_CHERRYUSB_HOST_MSC
  150. #define RT_LWIP_PBUF_POOL_BUFSIZE 1700
  151. /* end of Device Drivers */
  152. /* C/C++ and POSIX layer */
  153. /* ISO-ANSI C layer */
  154. /* Timezone and Daylight Saving Time */
  155. #define RT_LIBC_USING_LIGHT_TZ_DST
  156. #define RT_LIBC_TZ_DEFAULT_HOUR 8
  157. #define RT_LIBC_TZ_DEFAULT_MIN 0
  158. #define RT_LIBC_TZ_DEFAULT_SEC 0
  159. /* end of Timezone and Daylight Saving Time */
  160. /* end of ISO-ANSI C layer */
  161. /* POSIX (Portable Operating System Interface) layer */
  162. #define RT_USING_POSIX_FS
  163. #define RT_USING_POSIX_DEVIO
  164. #define RT_USING_POSIX_STDIO
  165. #define RT_USING_POSIX_TERMIOS
  166. #define RT_USING_POSIX_DELAY
  167. #define RT_USING_POSIX_CLOCK
  168. #define RT_USING_POSIX_TIMER
  169. /* Interprocess Communication (IPC) */
  170. /* Socket is in the 'Network' category */
  171. /* end of Interprocess Communication (IPC) */
  172. /* end of POSIX (Portable Operating System Interface) layer */
  173. /* end of C/C++ and POSIX layer */
  174. /* Network */
  175. #define RT_USING_SAL
  176. #define SAL_INTERNET_CHECK
  177. /* Docking with protocol stacks */
  178. #define SAL_USING_LWIP
  179. /* end of Docking with protocol stacks */
  180. #define SAL_USING_POSIX
  181. #define RT_USING_NETDEV
  182. #define NETDEV_USING_IFCONFIG
  183. #define NETDEV_USING_PING
  184. #define NETDEV_USING_NETSTAT
  185. #define NETDEV_USING_AUTO_DEFAULT
  186. #define NETDEV_IPV4 1
  187. #define NETDEV_IPV6 0
  188. #define RT_USING_LWIP
  189. #define RT_USING_LWIP212
  190. #define RT_USING_LWIP_VER_NUM 0x20102
  191. #define RT_LWIP_MEM_ALIGNMENT 64
  192. #define RT_LWIP_IGMP
  193. #define RT_LWIP_ICMP
  194. #define RT_LWIP_DNS
  195. /* Static IPv4 Address */
  196. #define RT_LWIP_IPADDR "192.168.4.10"
  197. #define RT_LWIP_GWADDR "192.168.4.1"
  198. #define RT_LWIP_MSKADDR "255.255.255.0"
  199. /* end of Static IPv4 Address */
  200. #define RT_LWIP_UDP
  201. #define RT_LWIP_TCP
  202. #define RT_LWIP_RAW
  203. #define RT_MEMP_NUM_NETCONN 8
  204. #define RT_LWIP_PBUF_NUM 512
  205. #define RT_LWIP_RAW_PCB_NUM 4
  206. #define RT_LWIP_UDP_PCB_NUM 4
  207. #define RT_LWIP_TCP_PCB_NUM 4
  208. #define RT_LWIP_TCP_SEG_NUM 40
  209. #define RT_LWIP_TCP_SND_BUF 8196
  210. #define RT_LWIP_TCP_WND 8196
  211. #define RT_LWIP_TCPTHREAD_PRIORITY 16
  212. #define RT_LWIP_TCPTHREAD_MBOX_SIZE 8
  213. #define RT_LWIP_TCPTHREAD_STACKSIZE 16184
  214. #define RT_LWIP_ETHTHREAD_PRIORITY 12
  215. #define RT_LWIP_ETHTHREAD_STACKSIZE 8192
  216. #define RT_LWIP_ETHTHREAD_MBOX_SIZE 8
  217. #define RT_LWIP_REASSEMBLY_FRAG
  218. #define LWIP_NETIF_STATUS_CALLBACK 1
  219. #define LWIP_NETIF_LINK_CALLBACK 1
  220. #define RT_LWIP_NETIF_NAMESIZE 6
  221. #define SO_REUSE 1
  222. #define LWIP_SO_RCVTIMEO 1
  223. #define LWIP_SO_SNDTIMEO 1
  224. #define LWIP_SO_RCVBUF 1
  225. #define LWIP_SO_LINGER 0
  226. #define LWIP_NETIF_LOOPBACK 0
  227. #define RT_LWIP_USING_PING
  228. /* end of Network */
  229. /* Memory protection */
  230. /* end of Memory protection */
  231. /* Utilities */
  232. #define RT_USING_RYM
  233. #define YMODEM_USING_FILE_TRANSFER
  234. #define RT_USING_RESOURCE_ID
  235. #define RT_USING_ADT
  236. #define RT_USING_ADT_AVL
  237. #define RT_USING_ADT_BITMAP
  238. #define RT_USING_ADT_HASHMAP
  239. #define RT_USING_ADT_REF
  240. /* end of Utilities */
  241. /* Using USB legacy version */
  242. /* end of Using USB legacy version */
  243. /* end of RT-Thread Components */
  244. /* RT-Thread Utestcases */
  245. /* end of RT-Thread Utestcases */
  246. /* RT-Thread online packages */
  247. /* IoT - internet of things */
  248. /* Wi-Fi */
  249. /* Marvell WiFi */
  250. /* end of Marvell WiFi */
  251. /* Wiced WiFi */
  252. /* end of Wiced WiFi */
  253. /* CYW43012 WiFi */
  254. /* end of CYW43012 WiFi */
  255. /* BL808 WiFi */
  256. /* end of BL808 WiFi */
  257. /* CYW43439 WiFi */
  258. /* end of CYW43439 WiFi */
  259. /* end of Wi-Fi */
  260. /* IoT Cloud */
  261. /* end of IoT Cloud */
  262. /* end of IoT - internet of things */
  263. /* security packages */
  264. /* end of security packages */
  265. /* language packages */
  266. /* JSON: JavaScript Object Notation, a lightweight data-interchange format */
  267. /* end of JSON: JavaScript Object Notation, a lightweight data-interchange format */
  268. /* XML: Extensible Markup Language */
  269. /* end of XML: Extensible Markup Language */
  270. /* end of language packages */
  271. /* multimedia packages */
  272. /* LVGL: powerful and easy-to-use embedded GUI library */
  273. /* end of LVGL: powerful and easy-to-use embedded GUI library */
  274. /* u8g2: a monochrome graphic library */
  275. /* end of u8g2: a monochrome graphic library */
  276. /* end of multimedia packages */
  277. /* tools packages */
  278. /* end of tools packages */
  279. /* system packages */
  280. /* enhanced kernel services */
  281. /* end of enhanced kernel services */
  282. /* acceleration: Assembly language or algorithmic acceleration packages */
  283. /* end of acceleration: Assembly language or algorithmic acceleration packages */
  284. /* CMSIS: ARM Cortex-M Microcontroller Software Interface Standard */
  285. /* end of CMSIS: ARM Cortex-M Microcontroller Software Interface Standard */
  286. /* Micrium: Micrium software products porting for RT-Thread */
  287. /* end of Micrium: Micrium software products porting for RT-Thread */
  288. /* end of system packages */
  289. /* peripheral libraries and drivers */
  290. /* HAL & SDK Drivers */
  291. /* STM32 HAL & SDK Drivers */
  292. /* end of STM32 HAL & SDK Drivers */
  293. /* Kendryte SDK */
  294. /* end of Kendryte SDK */
  295. /* end of HAL & SDK Drivers */
  296. /* sensors drivers */
  297. /* end of sensors drivers */
  298. /* touch drivers */
  299. /* end of touch drivers */
  300. /* end of peripheral libraries and drivers */
  301. /* AI packages */
  302. /* end of AI packages */
  303. /* Signal Processing and Control Algorithm Packages */
  304. /* end of Signal Processing and Control Algorithm Packages */
  305. /* miscellaneous packages */
  306. /* project laboratory */
  307. /* end of project laboratory */
  308. /* samples: kernel and components samples */
  309. #define PKG_USING_KERNEL_SAMPLES
  310. #define PKG_USING_KERNEL_SAMPLES_LATEST_VERSION
  311. #define PKG_USING_KERNEL_SAMPLES_EN
  312. /* end of samples: kernel and components samples */
  313. /* entertainment: terminal games and other interesting software packages */
  314. /* end of entertainment: terminal games and other interesting software packages */
  315. /* end of miscellaneous packages */
  316. /* Arduino libraries */
  317. /* Projects and Demos */
  318. /* end of Projects and Demos */
  319. /* Sensors */
  320. /* end of Sensors */
  321. /* Display */
  322. /* end of Display */
  323. /* Timing */
  324. /* end of Timing */
  325. /* Data Processing */
  326. /* end of Data Processing */
  327. /* Data Storage */
  328. /* Communication */
  329. /* end of Communication */
  330. /* Device Control */
  331. /* end of Device Control */
  332. /* Other */
  333. /* end of Other */
  334. /* Signal IO */
  335. /* end of Signal IO */
  336. /* Uncategorized */
  337. /* end of Arduino libraries */
  338. /* end of RT-Thread online packages */
  339. /* Hardware Drivers */
  340. /* On-chip Peripheral Drivers */
  341. #define BSP_USING_IOPAD
  342. #define BSP_USING_UART
  343. #define RT_USING_UART0
  344. #define RT_USING_UART1
  345. #define BSP_USING_SPI
  346. #define RT_USING_SPIM0
  347. #define BSP_USING_GPIO
  348. #define BSP_USING_QSPI
  349. #define RT_USING_QSPI0
  350. #define USING_QSPI_CHANNEL0
  351. #define BSP_USING_ETH
  352. #define BSP_USING_PWM
  353. #define BSP_USING_I2C
  354. #define I2C_USE_MIO
  355. #define RT_USING_MIO0
  356. #define RT_USING_MIO1
  357. #define RT_USING_MIO2
  358. #define RT_USING_MIO10
  359. #define BSP_USING_SDIF
  360. #define BSP_USING_SDCARD_FATFS
  361. #define USING_SDIF1
  362. #define USE_SDIF1_TF
  363. #define BSP_USING_DC
  364. #define RT_USING_DC_CHANNEL0
  365. #define RT_USING_DC_CHANNEL1
  366. /* end of On-chip Peripheral Drivers */
  367. /* Board extended module Drivers */
  368. /* end of Hardware Drivers */
  369. #define BSP_USING_GIC
  370. #define BSP_USING_GICV3
  371. #define PHYTIUM_ARCH_AARCH64
  372. #define ARM_SPI_BIND_CPU_ID 2
  373. /* Standalone Setting */
  374. #define TARGET_ARMV8_AARCH64
  375. /* Soc configuration */
  376. #define TARGET_PHYTIUMPI
  377. #define SOC_NAME "phytiumpi"
  378. #define SOC_CORE_NUM 4
  379. #define F32BIT_MEMORY_ADDRESS 0x80000000
  380. #define F32BIT_MEMORY_LENGTH 0x80000000
  381. #define F64BIT_MEMORY_ADDRESS 0x2000000000
  382. #define F64BIT_MEMORY_LENGTH 0x800000000
  383. #define TARGET_E2000
  384. #define DEFAULT_DEBUG_PRINT_UART1
  385. /* end of Soc configuration */
  386. /* Board Configuration */
  387. #define BOARD_NAME "firefly"
  388. #define FIREFLY_DEMO_BOARD
  389. /* IO mux configuration when board start up */
  390. /* end of IO mux configuration when board start up */
  391. /* end of Board Configuration */
  392. /* Sdk common configuration */
  393. #define ELOG_LINE_BUF_SIZE 0x100
  394. #define LOG_DEBUG
  395. /* end of Sdk common configuration */
  396. /* end of Standalone Setting */
  397. #endif