config.h 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498
  1. /*
  2. * Copyright (C) 2019 Intel Corporation. All rights reserved.
  3. * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. */
  5. #ifndef _CONFIG_H_
  6. #define _CONFIG_H_
  7. /* clang-format off */
  8. #if !defined(BUILD_TARGET_X86_64) \
  9. && !defined(BUILD_TARGET_AMD_64) \
  10. && !defined(BUILD_TARGET_AARCH64) \
  11. && !defined(BUILD_TARGET_X86_32) \
  12. && !defined(BUILD_TARGET_ARM) \
  13. && !defined(BUILD_TARGET_ARM_VFP) \
  14. && !defined(BUILD_TARGET_THUMB) \
  15. && !defined(BUILD_TARGET_THUMB_VFP) \
  16. && !defined(BUILD_TARGET_MIPS) \
  17. && !defined(BUILD_TARGET_XTENSA) \
  18. && !defined(BUILD_TARGET_RISCV64_LP64D) \
  19. && !defined(BUILD_TARGET_RISCV64_LP64) \
  20. && !defined(BUILD_TARGET_RISCV32_ILP32D) \
  21. && !defined(BUILD_TARGET_RISCV32_ILP32) \
  22. && !defined(BUILD_TARGET_ARC)
  23. /* clang-format on */
  24. #if defined(__x86_64__) || defined(__x86_64)
  25. #define BUILD_TARGET_X86_64
  26. #elif defined(__amd64__) || defined(__amd64)
  27. #define BUILD_TARGET_AMD_64
  28. #elif defined(__aarch64__)
  29. #define BUILD_TARGET_AARCH64
  30. #elif defined(__i386__) || defined(__i386) || defined(i386)
  31. #define BUILD_TARGET_X86_32
  32. #elif defined(__thumb__)
  33. #define BUILD_TARGET_THUMB
  34. #define BUILD_TARGET "THUMBV4T"
  35. #elif defined(__arm__)
  36. #define BUILD_TARGET_ARM
  37. #define BUILD_TARGET "ARMV4T"
  38. #elif defined(__mips__) || defined(__mips) || defined(mips)
  39. #define BUILD_TARGET_MIPS
  40. #elif defined(__XTENSA__)
  41. #define BUILD_TARGET_XTENSA
  42. #elif defined(__riscv) && (__riscv_xlen == 64)
  43. #define BUILD_TARGET_RISCV64_LP64D
  44. #elif defined(__riscv) && (__riscv_xlen == 32)
  45. #define BUILD_TARGET_RISCV32_ILP32D
  46. #elif defined(__arc__)
  47. #define BUILD_TARGET_ARC
  48. #else
  49. #error "Build target isn't set"
  50. #endif
  51. #endif
  52. #ifndef BH_DEBUG
  53. #define BH_DEBUG 0
  54. #endif
  55. #define MEM_ALLOCATOR_EMS 0
  56. #define MEM_ALLOCATOR_TLSF 1
  57. /* Default memory allocator */
  58. #define DEFAULT_MEM_ALLOCATOR MEM_ALLOCATOR_EMS
  59. #ifndef WASM_ENABLE_INTERP
  60. #define WASM_ENABLE_INTERP 0
  61. #endif
  62. #ifndef WASM_ENABLE_AOT
  63. #define WASM_ENABLE_AOT 0
  64. #endif
  65. #ifndef WASM_ENABLE_WORD_ALIGN_READ
  66. #define WASM_ENABLE_WORD_ALIGN_READ 0
  67. #endif
  68. #define AOT_MAGIC_NUMBER 0x746f6100
  69. #define AOT_CURRENT_VERSION 3
  70. #ifndef WASM_ENABLE_JIT
  71. #define WASM_ENABLE_JIT 0
  72. #endif
  73. #ifndef WASM_ENABLE_LAZY_JIT
  74. #define WASM_ENABLE_LAZY_JIT 0
  75. #endif
  76. #ifndef WASM_ORC_JIT_BACKEND_THREAD_NUM
  77. /* The number of backend threads created by runtime */
  78. #define WASM_ORC_JIT_BACKEND_THREAD_NUM 4
  79. #endif
  80. #if WASM_ORC_JIT_BACKEND_THREAD_NUM < 1
  81. #error "WASM_ORC_JIT_BACKEND_THREAD_NUM must be greater than 0"
  82. #endif
  83. #ifndef WASM_ORC_JIT_COMPILE_THREAD_NUM
  84. /* The number of compilation threads created by LLVM JIT */
  85. #define WASM_ORC_JIT_COMPILE_THREAD_NUM 4
  86. #endif
  87. #if WASM_ORC_JIT_COMPILE_THREAD_NUM < 1
  88. #error "WASM_ORC_JIT_COMPILE_THREAD_NUM must be greater than 0"
  89. #endif
  90. #if (WASM_ENABLE_AOT == 0) && (WASM_ENABLE_JIT != 0)
  91. /* LLVM JIT can only be enabled when AOT is enabled */
  92. #undef WASM_ENABLE_JIT
  93. #define WASM_ENABLE_JIT 0
  94. #undef WASM_ENABLE_LAZY_JIT
  95. #define WASM_ENABLE_LAZY_JIT 0
  96. #endif
  97. #ifndef WASM_ENABLE_FAST_JIT
  98. #define WASM_ENABLE_FAST_JIT 0
  99. #endif
  100. #ifndef WASM_ENABLE_FAST_JIT_DUMP
  101. #define WASM_ENABLE_FAST_JIT_DUMP 0
  102. #endif
  103. #ifndef FAST_JIT_DEFAULT_CODE_CACHE_SIZE
  104. #define FAST_JIT_DEFAULT_CODE_CACHE_SIZE 10 * 1024 * 1024
  105. #endif
  106. #ifndef WASM_ENABLE_WAMR_COMPILER
  107. #define WASM_ENABLE_WAMR_COMPILER 0
  108. #endif
  109. #ifndef WASM_ENABLE_LIBC_BUILTIN
  110. #define WASM_ENABLE_LIBC_BUILTIN 0
  111. #endif
  112. #ifndef WASM_ENABLE_LIBC_WASI
  113. #define WASM_ENABLE_LIBC_WASI 0
  114. #endif
  115. #ifndef WASM_ENABLE_UVWASI
  116. #define WASM_ENABLE_UVWASI 0
  117. #endif
  118. #ifndef WASM_ENABLE_WASI_NN
  119. #define WASM_ENABLE_WASI_NN 0
  120. #endif
  121. #ifndef WASM_ENABLE_WASI_NN_GPU
  122. #define WASM_ENABLE_WASI_NN_GPU 0
  123. #endif
  124. #ifndef WASM_ENABLE_WASI_NN_EXTERNAL_DELEGATE
  125. #define WASM_ENABLE_WASI_NN_EXTERNAL_DELEGATE 0
  126. #endif
  127. /* Default disable libc emcc */
  128. #ifndef WASM_ENABLE_LIBC_EMCC
  129. #define WASM_ENABLE_LIBC_EMCC 0
  130. #endif
  131. #ifndef WASM_ENABLE_LIB_RATS
  132. #define WASM_ENABLE_LIB_RATS 0
  133. #endif
  134. #ifndef WASM_ENABLE_LIB_PTHREAD
  135. #define WASM_ENABLE_LIB_PTHREAD 0
  136. #endif
  137. #ifndef WASM_ENABLE_LIB_PTHREAD_SEMAPHORE
  138. #define WASM_ENABLE_LIB_PTHREAD_SEMAPHORE 0
  139. #endif
  140. #ifndef WASM_ENABLE_LIB_WASI_THREADS
  141. #define WASM_ENABLE_LIB_WASI_THREADS 0
  142. #endif
  143. #ifndef WASM_ENABLE_HEAP_AUX_STACK_ALLOCATION
  144. #define WASM_ENABLE_HEAP_AUX_STACK_ALLOCATION WASM_ENABLE_LIB_WASI_THREADS
  145. #elif WASM_ENABLE_HEAP_AUX_STACK_ALLOCATION == 0 \
  146. && WASM_ENABLE_LIB_WASI_THREADS == 1
  147. #error "Heap aux stack allocation must be enabled for WASI threads"
  148. #endif
  149. #ifndef WASM_ENABLE_BASE_LIB
  150. #define WASM_ENABLE_BASE_LIB 0
  151. #endif
  152. #ifndef WASM_ENABLE_APP_FRAMEWORK
  153. #define WASM_ENABLE_APP_FRAMEWORK 0
  154. #endif
  155. /* Bulk memory operation */
  156. #ifndef WASM_ENABLE_BULK_MEMORY
  157. #define WASM_ENABLE_BULK_MEMORY 0
  158. #endif
  159. /* Shared memory */
  160. #ifndef WASM_ENABLE_SHARED_MEMORY
  161. #define WASM_ENABLE_SHARED_MEMORY 0
  162. #endif
  163. /* Thread manager */
  164. #ifndef WASM_ENABLE_THREAD_MGR
  165. #define WASM_ENABLE_THREAD_MGR 0
  166. #endif
  167. /* Source debugging */
  168. #ifndef WASM_ENABLE_DEBUG_INTERP
  169. #define WASM_ENABLE_DEBUG_INTERP 0
  170. #endif
  171. #if WASM_ENABLE_DEBUG_INTERP != 0
  172. #ifndef DEBUG_EXECUTION_MEMORY_SIZE
  173. /* 0x85000 is the size required by lldb, if this is changed to a smaller value,
  174. * then the debugger will not be able to evaluate user expressions, other
  175. * functionality such as breakpoint and stepping are not influenced by this */
  176. #define DEBUG_EXECUTION_MEMORY_SIZE 0x85000
  177. #endif
  178. #endif /* end of WASM_ENABLE_DEBUG_INTERP != 0 */
  179. #ifndef WASM_ENABLE_DEBUG_AOT
  180. #define WASM_ENABLE_DEBUG_AOT 0
  181. #endif
  182. /* Custom sections */
  183. #ifndef WASM_ENABLE_LOAD_CUSTOM_SECTION
  184. #define WASM_ENABLE_LOAD_CUSTOM_SECTION 0
  185. #endif
  186. /* WASM log system */
  187. #ifndef WASM_ENABLE_LOG
  188. #define WASM_ENABLE_LOG 1
  189. #endif
  190. #ifndef WASM_CPU_SUPPORTS_UNALIGNED_ADDR_ACCESS
  191. #if defined(BUILD_TARGET_X86_32) || defined(BUILD_TARGET_X86_64) \
  192. || defined(BUILD_TARGET_AARCH64)
  193. #define WASM_CPU_SUPPORTS_UNALIGNED_ADDR_ACCESS 1
  194. #else
  195. #define WASM_CPU_SUPPORTS_UNALIGNED_ADDR_ACCESS 0
  196. #endif
  197. #endif
  198. /* WASM Interpreter labels-as-values feature */
  199. #ifndef WASM_ENABLE_LABELS_AS_VALUES
  200. #ifdef __GNUC__
  201. #define WASM_ENABLE_LABELS_AS_VALUES 1
  202. #else
  203. #define WASM_ENABLE_LABELS_AS_VALUES 0
  204. #endif
  205. #endif
  206. /* Enable fast interpreter or not */
  207. #ifndef WASM_ENABLE_FAST_INTERP
  208. #define WASM_ENABLE_FAST_INTERP 0
  209. #endif
  210. #if WASM_ENABLE_FAST_INTERP != 0
  211. #define WASM_DEBUG_PREPROCESSOR 0
  212. #endif
  213. /* Enable opcode counter or not */
  214. #ifndef WASM_ENABLE_OPCODE_COUNTER
  215. #define WASM_ENABLE_OPCODE_COUNTER 0
  216. #endif
  217. /* Support a module with dependency, other modules */
  218. #ifndef WASM_ENABLE_MULTI_MODULE
  219. #define WASM_ENABLE_MULTI_MODULE 0
  220. #endif
  221. /* Enable wasm mini loader or not */
  222. #ifndef WASM_ENABLE_MINI_LOADER
  223. #define WASM_ENABLE_MINI_LOADER 0
  224. #endif
  225. /* Disable boundary check with hardware trap or not,
  226. * enable it by default if it is supported */
  227. #ifndef WASM_DISABLE_HW_BOUND_CHECK
  228. #define WASM_DISABLE_HW_BOUND_CHECK 0
  229. #endif
  230. /* Disable native stack access boundary check with hardware
  231. * trap or not, enable it by default if it is supported */
  232. #ifndef WASM_DISABLE_STACK_HW_BOUND_CHECK
  233. #define WASM_DISABLE_STACK_HW_BOUND_CHECK 0
  234. #endif
  235. /* Disable SIMD unless it is manualy enabled somewhere */
  236. #ifndef WASM_ENABLE_SIMD
  237. #define WASM_ENABLE_SIMD 0
  238. #endif
  239. /* Memory profiling */
  240. #ifndef WASM_ENABLE_MEMORY_PROFILING
  241. #define WASM_ENABLE_MEMORY_PROFILING 0
  242. #endif
  243. /* Memory tracing */
  244. #ifndef WASM_ENABLE_MEMORY_TRACING
  245. #define WASM_ENABLE_MEMORY_TRACING 0
  246. #endif
  247. /* Performance profiling */
  248. #ifndef WASM_ENABLE_PERF_PROFILING
  249. #define WASM_ENABLE_PERF_PROFILING 0
  250. #endif
  251. /* Dump call stack */
  252. #ifndef WASM_ENABLE_DUMP_CALL_STACK
  253. #define WASM_ENABLE_DUMP_CALL_STACK 0
  254. #endif
  255. /* Heap verification */
  256. #ifndef BH_ENABLE_GC_VERIFY
  257. #define BH_ENABLE_GC_VERIFY 0
  258. #endif
  259. /* Heap corruption check, enabled by default */
  260. #ifndef BH_ENABLE_GC_CORRUPTION_CHECK
  261. #define BH_ENABLE_GC_CORRUPTION_CHECK 1
  262. #endif
  263. /* Enable global heap pool if heap verification is enabled */
  264. #if BH_ENABLE_GC_VERIFY != 0
  265. #define WASM_ENABLE_GLOBAL_HEAP_POOL 1
  266. #endif
  267. /* Global heap pool */
  268. #ifndef WASM_ENABLE_GLOBAL_HEAP_POOL
  269. #define WASM_ENABLE_GLOBAL_HEAP_POOL 0
  270. #endif
  271. #ifndef WASM_ENABLE_SPEC_TEST
  272. #define WASM_ENABLE_SPEC_TEST 0
  273. #endif
  274. /* Global heap pool size in bytes */
  275. #ifndef WASM_GLOBAL_HEAP_SIZE
  276. #define WASM_GLOBAL_HEAP_SIZE (10 * 1024 * 1024)
  277. #endif
  278. /* Max app number of all modules */
  279. #define MAX_APP_INSTALLATIONS 3
  280. /* Default timer number in one app */
  281. #define DEFAULT_TIMERS_PER_APP 20
  282. /* Max timer number in one app */
  283. #define MAX_TIMERS_PER_APP 30
  284. /* Max connection number in one app */
  285. #define MAX_CONNECTION_PER_APP 20
  286. /* Max resource registration number in one app */
  287. #define RESOURCE_REGISTRATION_NUM_MAX 16
  288. /* Max length of resource/event url */
  289. #define RESOUCE_EVENT_URL_LEN_MAX 256
  290. /* Default length of queue */
  291. #define DEFAULT_QUEUE_LENGTH 50
  292. /* Default watchdog interval in ms */
  293. #define DEFAULT_WATCHDOG_INTERVAL (3 * 60 * 1000)
  294. /* The max percentage of global heap that app memory space can grow */
  295. #define APP_MEMORY_MAX_GLOBAL_HEAP_PERCENT 1 / 3
  296. /* Default min/max heap size of each app */
  297. #ifndef APP_HEAP_SIZE_DEFAULT
  298. #define APP_HEAP_SIZE_DEFAULT (8 * 1024)
  299. #endif
  300. #define APP_HEAP_SIZE_MIN (256)
  301. #define APP_HEAP_SIZE_MAX (512 * 1024 * 1024)
  302. /* Default wasm stack size of each app */
  303. #if defined(BUILD_TARGET_X86_64) || defined(BUILD_TARGET_AMD_64)
  304. #define DEFAULT_WASM_STACK_SIZE (16 * 1024)
  305. #else
  306. #define DEFAULT_WASM_STACK_SIZE (12 * 1024)
  307. #endif
  308. /* Min auxilliary stack size of each wasm thread */
  309. #define WASM_THREAD_AUX_STACK_SIZE_MIN (256)
  310. /* Default/min native stack size of each app thread */
  311. #if !(defined(APP_THREAD_STACK_SIZE_DEFAULT) \
  312. && defined(APP_THREAD_STACK_SIZE_MIN))
  313. #if defined(BH_PLATFORM_ZEPHYR) || defined(BH_PLATFORM_ALIOS_THINGS) \
  314. || defined(BH_PLATFORM_ESP_IDF) || defined(BH_PLATFORM_OPENRTOS)
  315. #define APP_THREAD_STACK_SIZE_DEFAULT (6 * 1024)
  316. #define APP_THREAD_STACK_SIZE_MIN (4 * 1024)
  317. #elif defined(PTHREAD_STACK_DEFAULT) && defined(PTHREAD_STACK_MIN)
  318. #define APP_THREAD_STACK_SIZE_DEFAULT PTHREAD_STACK_DEFAULT
  319. #define APP_THREAD_STACK_SIZE_MIN PTHREAD_STACK_MIN
  320. #elif WASM_ENABLE_UVWASI != 0
  321. /* UVWASI requires larger native stack */
  322. #define APP_THREAD_STACK_SIZE_DEFAULT (64 * 1024)
  323. #define APP_THREAD_STACK_SIZE_MIN (48 * 1024)
  324. #else
  325. #define APP_THREAD_STACK_SIZE_DEFAULT (64 * 1024)
  326. #define APP_THREAD_STACK_SIZE_MIN (24 * 1024)
  327. #endif
  328. #endif /* end of !(defined(APP_THREAD_STACK_SIZE_DEFAULT) \
  329. && defined(APP_THREAD_STACK_SIZE_MIN)) */
  330. /* Max native stack size of each app thread */
  331. #if !defined(APP_THREAD_STACK_SIZE_MAX)
  332. #define APP_THREAD_STACK_SIZE_MAX (8 * 1024 * 1024)
  333. #endif
  334. /* Reserved bytes to the native thread stack boundary, throw native
  335. stack overflow exception if the guard boudary is reached */
  336. #ifndef WASM_STACK_GUARD_SIZE
  337. #if WASM_ENABLE_UVWASI != 0
  338. /* UVWASI requires larger native stack */
  339. #define WASM_STACK_GUARD_SIZE (4096 * 6)
  340. #else
  341. #define WASM_STACK_GUARD_SIZE (1024)
  342. #endif
  343. #endif
  344. /* Guard page count for stack overflow check with hardware trap */
  345. #ifndef STACK_OVERFLOW_CHECK_GUARD_PAGE_COUNT
  346. #define STACK_OVERFLOW_CHECK_GUARD_PAGE_COUNT 3
  347. #endif
  348. /* Default wasm block address cache size and conflict list size */
  349. #ifndef BLOCK_ADDR_CACHE_SIZE
  350. #define BLOCK_ADDR_CACHE_SIZE 64
  351. #endif
  352. #define BLOCK_ADDR_CONFLICT_SIZE 2
  353. /* Default max thread num per cluster. Can be overwrite by
  354. wasm_runtime_set_max_thread_num */
  355. #define CLUSTER_MAX_THREAD_NUM 4
  356. #ifndef WASM_ENABLE_TAIL_CALL
  357. #define WASM_ENABLE_TAIL_CALL 0
  358. #endif
  359. #ifndef WASM_ENABLE_CUSTOM_NAME_SECTION
  360. #define WASM_ENABLE_CUSTOM_NAME_SECTION 0
  361. #endif
  362. #ifndef WASM_ENABLE_REF_TYPES
  363. #define WASM_ENABLE_REF_TYPES 0
  364. #endif
  365. #ifndef WASM_ENABLE_SGX_IPFS
  366. #define WASM_ENABLE_SGX_IPFS 0
  367. #endif
  368. #ifndef WASM_MEM_ALLOC_WITH_USER_DATA
  369. #define WASM_MEM_ALLOC_WITH_USER_DATA 0
  370. #endif
  371. #ifndef WASM_ENABLE_WASM_CACHE
  372. #define WASM_ENABLE_WASM_CACHE 0
  373. #endif
  374. #ifndef WASM_ENABLE_STATIC_PGO
  375. #define WASM_ENABLE_STATIC_PGO 0
  376. #endif
  377. /* Disable writing linear memory base address to GS segment register,
  378. by default only in linux x86-64, linear memory base addr is written
  379. to GS segment register before calling wasm/aot function. */
  380. #ifndef WASM_DISABLE_WRITE_GS_BASE
  381. #define WASM_DISABLE_WRITE_GS_BASE 0
  382. #endif
  383. /* Configurable bounds checks */
  384. #ifndef WASM_CONFIGURABLE_BOUNDS_CHECKS
  385. #define WASM_CONFIGURABLE_BOUNDS_CHECKS 0
  386. #endif
  387. /* Some chip cannot support external ram with rwx attr at the same time,
  388. it has to map it into 2 spaces of idbus and dbus, code in dbus can be
  389. read/written and read/executed in ibus. so there are 2 steps to execute
  390. the code, first, copy & do relocation in dbus space, and second execute
  391. it in ibus space, since in the 2 spaces the contents are the same,
  392. so we call it bus mirror.
  393. */
  394. #ifndef WASM_MEM_DUAL_BUS_MIRROR
  395. #define WASM_MEM_DUAL_BUS_MIRROR 0
  396. #endif
  397. /* The max number of module instance contexts. */
  398. #ifndef WASM_MAX_INSTANCE_CONTEXTS
  399. #define WASM_MAX_INSTANCE_CONTEXTS 8
  400. #endif
  401. /* linux perf support */
  402. #ifndef WASM_ENABLE_LINUX_PERF
  403. #define WASM_ENABLE_LINUX_PERF 0
  404. #endif
  405. #endif /* end of _CONFIG_H_ */