phytium_pi_rtsmart.h 13 KB

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