You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

CMakeLists.txt 16 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428
  1. cmake_minimum_required(VERSION 3.9.0)
  2. project(MegEngine)
  3. set(CMAKE_CXX_STANDARD 14)
  4. set(CMAKE_CXX_STANDARD_REQUIRED ON)
  5. set(CMAKE_CXX_EXTENSIONS OFF)
  6. set(CMAKE_POSITION_INDEPENDENT_CODE ON)
  7. set(CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/cmake/Modules)
  8. if(NOT MSVC)
  9. set(CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Dqc <TARGET> <LINK_FLAGS> <OBJECTS>")
  10. set(CMAKE_CXX_ARCHIVE_APPEND "<CMAKE_AR> Dq <TARGET> <LINK_FLAGS> <OBJECTS>")
  11. set(CMAKE_CXX_ARCHIVE_FINISH "<CMAKE_RANLIB> -D <TARGET>")
  12. endif()
  13. include(CheckCXXCompilerFlag)
  14. CHECK_CXX_COMPILER_FLAG(-Wclass-memaccess CXX_SUPPORT_WCLASS_MEMACCESS)
  15. set(MGE_ARCH AUTO CACHE STRING "Architecture on which MegEngine to be built.")
  16. set_property(CACHE MGE_ARCH PROPERTY STRINGS AUTO
  17. x86_64 i386
  18. naive fallback
  19. )
  20. if(${MGE_ARCH} STREQUAL "AUTO")
  21. if(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "x86_64")
  22. set(MGE_ARCH "x86_64")
  23. elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "i386" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "i686")
  24. set(MGE_ARCH "i386")
  25. else()
  26. message(FATAL "Unknown machine architecture for MegEngine.")
  27. endif()
  28. endif()
  29. CHECK_CXX_COMPILER_FLAG(-fuse-ld=gold CXX_SUPPORT_GOLD)
  30. if(CXX_SUPPORT_GOLD)
  31. message("-- Using GNU gold linker.")
  32. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fuse-ld=gold")
  33. set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fuse-ld=gold")
  34. endif()
  35. option(MGE_WITH_JIT "Build MegEngine with JIT." ON)
  36. option(MGE_WITH_HALIDE "Build MegEngine with Halide JIT" ON)
  37. option(MGE_DISABLE_FLOAT16 "Disable MegEngine float16 support." OFF)
  38. option(MGE_WITH_CUDA "Enable MegEngine CUDA support." ON)
  39. option(MGE_CUDA_USE_STATIC "Enable MegEngine CUDA static linking." ON)
  40. option(MGE_WITH_TRT "Build MegEngine with TensorRT." ON)
  41. option(MGE_USE_SYSTEM_LIB "Build MegEngine with system libraries." OFF)
  42. option(MGB_WITH_FLATBUFFERS "Build MegBrain with FlatBuffers serialization support." ON)
  43. if(NOT MGE_WITH_JIT)
  44. if(MGE_WITH_HALIDE)
  45. message(WARNING "MGE_WITH_HALIDE is set to OFF with MGE_WITH_JIT disabled")
  46. set(MGE_WITH_HALIDE OFF)
  47. endif()
  48. endif()
  49. if(MGE_WITH_CUDA)
  50. include(CheckLanguage)
  51. check_language(CUDA)
  52. if(NOT CMAKE_CUDA_COMPILER)
  53. message(FATAL_ERROR "CUDA compiler not found in PATH")
  54. endif()
  55. enable_language(CUDA)
  56. set(CMAKE_CUDA_STANDARD 14)
  57. set(CMAKE_CUDA_STANDARD_REQUIRED ON)
  58. endif()
  59. if(NOT MGE_WITH_CUDA)
  60. message("-- Disable JIT support, as CUDA is not enabled.")
  61. set(MGE_WITH_JIT OFF)
  62. set(MGE_WITH_HALIDE OFF)
  63. message("-- Disable TensorRT support, as CUDA is not enabled.")
  64. set(MGE_WITH_TRT OFF)
  65. endif()
  66. find_package(PythonInterp 3 REQUIRED)
  67. set(THREADS_PREFER_PTHREAD_FLAG ON)
  68. find_package(Threads)
  69. if(${CMAKE_THREAD_LIBS_INIT} STREQUAL "-pthread" AND MGE_WITH_CUDA)
  70. set_property(TARGET Threads::Threads
  71. PROPERTY INTERFACE_COMPILE_OPTIONS "$<$<COMPILE_LANGUAGE:CUDA>:-Xcompiler=-pthread>"
  72. "$<$<NOT:$<COMPILE_LANGUAGE:CUDA>>:-pthread>")
  73. endif()
  74. set(MGE_BLAS MKL CACHE STRING "BLAS implementaion used by MegEngine.")
  75. set_property(CACHE MGE_BLAS PROPERTY STRINGS MKL OpenBLAS)
  76. set(MGE_CUDA_GENCODE "" CACHE STRING "Overwrite -gencode specifications for CUDA")
  77. if(NOT CMAKE_CUDA_HOST_COMPILER)
  78. set(CMAKE_CUDA_HOST_COMPILER $(CMAKE_CXX_COMPILER))
  79. endif()
  80. option(MGE_ENABLE_RTTI "Build with RTTI" ON)
  81. option(MGE_ENABLE_LOGGING "Build with logging" ON)
  82. option(MGE_DEBUG_UTIL "Enable debug utility" ON)
  83. if(NOT CMAKE_CONFIGURATION_TYPES AND NOT CMAKE_BUILD_TYPE)
  84. message(STATUS "Setting build type to 'RelWithDebInfo' as none was specified.")
  85. set(CMAKE_BUILD_TYPE RelWithDebInfo)
  86. endif()
  87. if(NOT MGE_ENABLE_RTTI)
  88. set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-rtti")
  89. endif()
  90. option(MGE_ENABLE_EXCEPTIONS "Build with exceptions" ON)
  91. if(NOT MGE_ENABLE_EXCEPTIONS)
  92. set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-exception")
  93. endif()
  94. option(MGE_WITH_TEST "Enable test for MegEngine." OFF)
  95. if(MGE_WITH_TEST)
  96. include(cmake/gtest.cmake)
  97. endif()
  98. option(MGE_WITH_DISTRIBUTED "Build with distributed support" ON)
  99. if(NOT MGE_WITH_CUDA)
  100. message("-- Disable distributed support, as CUDA is not enabled.")
  101. set(MGE_WITH_DISTRIBUTED OFF)
  102. endif()
  103. option(MGE_INFERENCE_ONLY "Build inference only library." OFF)
  104. option(MGE_WITH_PYTHON_MODULE "Build MegEngine Python Module." ON)
  105. if(MGE_INFERENCE_ONLY)
  106. message("-- Disable distributed support for inference only build.")
  107. set(MGE_WITH_DISTRIBUTED OFF)
  108. message("-- Disable python module for inference only build.")
  109. set(MGE_WITH_PYTHON_MODULE OFF)
  110. message("-- Disable tests for inference only build.")
  111. set(MGE_WITH_TEST OFF)
  112. endif()
  113. if(MGE_WITH_DISTRIBUTED)
  114. include(cmake/protobuf.cmake)
  115. include(cmake/zmq.cmake)
  116. endif()
  117. if(MGB_WITH_FLATBUFFERS)
  118. include(cmake/flatbuffers.cmake)
  119. endif()
  120. if(MSVC)
  121. add_compile_definitions(NOMINMAX=1 _USE_MATH_DEFINES=1 WIN32=1)
  122. else()
  123. set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wextra")
  124. set(CMAKE_CXX_FLAGS_DEBUG "-O0 -g")
  125. set(CMAKE_CXX_FLAGS_RELEASE "-O2 -DNDEBUG")
  126. endif()
  127. if(MGE_WITH_CUDA)
  128. include_directories(${CMAKE_CUDA_TOOLKIT_INCLUDE_DIRECTORIES})
  129. foreach(path ${CMAKE_CUDA_HOST_IMPLICIT_LINK_DIRECTORIES})
  130. get_filename_component(_NAME ${path} NAME)
  131. if(NOT ${_NAME} STREQUAL "stubs")
  132. list(APPEND CUDA_LINK_DIRECTORIES ${path})
  133. endif()
  134. endforeach()
  135. link_directories(${CUDA_LINK_DIRECTORIES})
  136. set(CMAKE_CUDA_FLAGS_DEBUG "-O0 -g")
  137. set(CMAKE_CUDA_FLAGS_RELEASE "-O3")
  138. set(CMAKE_CUDA_FLAGS_RELWITHDEBINFO "-O3 -g")
  139. set(CMAKE_CUDA_FLAGS_MINSIZEREL "-Os")
  140. set(CMAKE_CUDA_FLAGS "-Xcompiler -Wall,-Wextra -Xfatbin -compress-all")
  141. if(NOT MGE_ENABLE_RTTI)
  142. set(CMAKE_CUDA_FLAGS "${CMAKE_CUDA_FLAGS} -Xcompiler -fno-rtti")
  143. endif()
  144. if(NOT MGE_ENABLE_EXCEPTIONS)
  145. set(CMAKE_CUDA_FLAGS "${CMAKE_CUDA_FLAGS} -Xcompiler -fno-exception")
  146. endif()
  147. if(NOT MGE_CUDA_GENCODE)
  148. if(${MGE_ARCH} STREQUAL "x86_64" OR ${MGE_ARCH} STREQUAL "i386")
  149. set(CMAKE_CUDA_FLAGS "${CMAKE_CUDA_FLAGS} -DMEGDNN_THREADS_512=0")
  150. if(${CMAKE_CUDA_COMPILER_VERSION} VERSION_GREATER "10.0.0" OR ${CMAKE_CUDA_COMPILER_VERSION} VERSION_EQUAL "10.0.0")
  151. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_52,code=sm_52")
  152. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_60,code=sm_60")
  153. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_61,code=sm_61")
  154. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_70,code=sm_70")
  155. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_75,code=sm_75")
  156. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_75,code=compute_75")
  157. elseif(${CMAKE_CUDA_COMPILER_VERSION} VERSION_GREATER "9.0.0" OR ${CMAKE_CUDA_COMPILER_VERSION} VERSION_EQUAL "9.0.0")
  158. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_52,code=sm_52")
  159. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_60,code=sm_60")
  160. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_61,code=sm_61")
  161. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_70,code=sm_70")
  162. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_70,code=compute_70")
  163. else()
  164. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_35,code=sm_35")
  165. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_52,code=sm_52")
  166. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_60,code=sm_60")
  167. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_61,code=sm_61")
  168. set(MGE_CUDA_GENCODE "${MGE_CUDA_GENCODE} -gencode arch=compute_61,code=compute_61")
  169. endif()
  170. else()
  171. message(FATAL_ERROR "Unsupported CUDA host arch.")
  172. endif()
  173. else()
  174. set(CMAKE_CUDA_FLAGS "${CMAKE_CUDA_FLAGS} -DMEGDNN_THREADS_512=1")
  175. endif()
  176. set(CMAKE_CUDA_FLAGS "${CMAKE_CUDA_FLAGS} ${MGE_CUDA_GENCODE}")
  177. include(cmake/cudnn.cmake)
  178. if(MGE_WITH_TRT)
  179. include(cmake/tensorrt.cmake)
  180. endif()
  181. if(MGE_CUDA_USE_STATIC)
  182. if(MGE_WITH_TRT)
  183. list(APPEND MGE_CUDA_LIBS -Wl,--whole-archive libnvinfer libcudnn -Wl,--no-whole-archive)
  184. else()
  185. list(APPEND MGE_CUDA_LIBS -Wl,--whole-archive libcudnn -Wl,--no-whole-archive)
  186. endif()
  187. list(APPEND MGE_CUDA_LIBS cusolver_static cublas_static curand_static culibos cudart_static cusparse_static)
  188. if(${CMAKE_CUDA_COMPILER_VERSION} VERSION_GREATER "10.1.0" OR ${CMAKE_CUDA_COMPILER_VERSION} VERSION_EQUAL "10.1.0")
  189. list(APPEND MGE_CUDA_LIBS cublasLt_static)
  190. endif()
  191. if(${CMAKE_CUDA_COMPILER_VERSION} VERSION_GREATER "10.0.0" OR ${CMAKE_CUDA_COMPILER_VERSION} VERSION_EQUAL "10.0.0")
  192. # mark all symbols from liblapack_static.a as weak to avoid
  193. # duplicated definition with mkl
  194. find_library(
  195. LAPACK_STATIC_PATH lapack_static
  196. HINTS ${CMAKE_CUDA_HOST_IMPLICIT_LINK_DIRECTORIES})
  197. if(NOT LAPACK_STATIC_PATH)
  198. message(FATAL_ERROR "liblapack_static.a not found")
  199. endif()
  200. set(LAPACK_STATIC_COPY_PATH ${CMAKE_CURRENT_BINARY_DIR}/liblapack_static_copy.a)
  201. # add a target that run objcopy
  202. add_custom_command(
  203. OUTPUT ${LAPACK_STATIC_COPY_PATH}
  204. COMMAND ${CMAKE_OBJCOPY} -w -W* ${LAPACK_STATIC_PATH} ${LAPACK_STATIC_COPY_PATH}
  205. VERBATIM)
  206. add_custom_target(lapack_static_weak_target DEPENDS ${LAPACK_STATIC_COPY_PATH})
  207. # create a library named "lapack_static_weak"
  208. add_library(lapack_static_weak STATIC IMPORTED GLOBAL)
  209. add_dependencies(lapack_static_weak lapack_static_weak_target)
  210. set_target_properties(
  211. lapack_static_weak PROPERTIES
  212. IMPORTED_LOCATION ${LAPACK_STATIC_COPY_PATH})
  213. list(APPEND MGE_CUDA_LIBS lapack_static_weak ${LAPACK_STATIC_COPY_PATH})
  214. endif()
  215. else()
  216. if(MGE_WITH_TRT)
  217. list(APPEND MGE_CUDA_LIBS libnvinfer)
  218. endif()
  219. list(APPEND MGE_CUDA_LIBS libcudnn)
  220. if(${CMAKE_CUDA_COMPILER_VERSION} VERSION_GREATER "10.1.0" OR ${CMAKE_CUDA_COMPILER_VERSION} VERSION_EQUAL "10.1.0")
  221. list(APPEND MGE_CUDA_LIBS cublasLt cusolver cublas curand)
  222. endif()
  223. endif()
  224. add_subdirectory(dnn/cuda-stub)
  225. list(APPEND MGE_CUDA_LIBS nvrtc cuda-stub nvToolsExt)
  226. set(MGE_CUDA_LIBS "${MGE_CUDA_LIBS}")
  227. endif()
  228. find_program(CCACHE_BIN ccache)
  229. if(CCACHE_BIN)
  230. set(CMAKE_CXX_COMPILER_LAUNCHER ${CCACHE_BIN})
  231. if(MGE_WITH_CUDA AND NOT ${CMAKE_VERSION} VERSION_LESS "3.10.0")
  232. message("-- Using ccache as CMAKE_CUDA_COMPILER_LAUNCHER")
  233. set(CMAKE_CUDA_COMPILER_LAUNCHER ${CCACHE_BIN})
  234. endif()
  235. endif()
  236. if(${MGE_ARCH} STREQUAL "x86_64" OR ${MGE_ARCH} STREQUAL "i386")
  237. if(${MGE_BLAS} STREQUAL "MKL")
  238. include(cmake/mkl.cmake)
  239. set(MGE_BLAS_LIBS libmkl)
  240. elseif(${MGE_BLAS} STREQUAL "OpenBLAS")
  241. include(cmake/OpenBLAS.cmake)
  242. set(MGE_BLAS_LIBS libopenblas)
  243. else()
  244. message(FATAL_ERROR "Unknown BLAS implementation ${MGE_BLAS}")
  245. endif()
  246. endif()
  247. option(MGE_WITH_MKLDNN "Enable Intel MKL_DNN support," ON)
  248. # MKLDNN build
  249. if(MGE_WITH_MKLDNN AND ${MGE_ARCH} STREQUAL "x86_64")
  250. add_definitions(-DMEGDNN_X86_WITH_MKL_DNN)
  251. include(cmake/MKL_DNN.cmake)
  252. endif()
  253. # RTTI
  254. if(MGE_ENABLE_RTTI)
  255. add_definitions(-DMEGDNN_ENABLE_MANGLING=0 -DMEGDNN_ENABLE_RTTI=1)
  256. else()
  257. add_definitions(-DMEGDNN_ENABLE_MANGLING=1 -DMEGDNN_ENABLE_RTTI=0)
  258. endif()
  259. set(MGB_VERBOSE_TYPEINFO_NAME ${MGE_ENABLE_RTTI})
  260. # Logging
  261. if(MGE_ENABLE_LOGGING)
  262. add_definitions(-DMEGDNN_ENABLE_LOGGING=1)
  263. else()
  264. add_definitions(-DMEGDNN_ENABLE_LOGGING=0)
  265. endif()
  266. set(MGB_ENABLE_LOGGING ${MGE_ENABLE_LOGGING})
  267. set(MGB_ENABLE_JSON ${MGE_ENABLE_LOGGING})
  268. # Exception
  269. if(MGE_ENABLE_EXCEPTIONS)
  270. add_definitions(-DMEGDNN_ENABLE_EXCEPTIONS=1)
  271. else()
  272. message(STATUS "Exceptions disabled; MegEngine would kill itself when it is supposed to throw an exception.")
  273. add_definitions(-DMEGDNN_ENABLE_EXCEPTIONS=0)
  274. endif()
  275. set(MGB_ENABLE_EXCEPTION ${MGE_ENABLE_EXCEPTIONS})
  276. # JIT
  277. if(MGE_WITH_JIT AND MGE_WITH_HALIDE)
  278. set(HALIDE_SHARED_LIBRARY OFF CACHE BOOL "Build as a shared library")
  279. include(cmake/Halide.cmake)
  280. endif()
  281. set(MGB_JIT ${MGE_WITH_JIT})
  282. set(MGB_JIT_HALIDE ${MGE_WITH_HALIDE})
  283. # Thread
  284. if(CMAKE_THREAD_LIBS_INIT)
  285. set(MGB_HAVE_THREAD 1)
  286. endif()
  287. # CUDA
  288. set(MGB_CUDA ${MGE_WITH_CUDA})
  289. # Debug info
  290. if(${CMAKE_BUILD_TYPE} STREQUAL "Debug" OR ${CMAKE_BUILD_TYPE} STREQUAL "RelWithDebInfo")
  291. set(MGB_ASSERT_LOC 1)
  292. set(MGB_ENABLE_DEBUG_UTIL 1)
  293. else()
  294. set(MGB_ASSERT_LOC 0)
  295. set(MGB_ENABLE_DEBUG_UTIL 0)
  296. endif()
  297. # TensorRT
  298. set(MGB_ENABLE_TENSOR_RT ${MGE_WITH_TRT})
  299. # Inference only
  300. if(MGE_INFERENCE_ONLY)
  301. set(MGB_ENABLE_GRAD 0)
  302. set(MGB_BUILD_SLIM_SERVING 1)
  303. else()
  304. set(MGB_ENABLE_GRAD 1)
  305. set(MGB_BUILD_SLIM_SERVING 0)
  306. endif()
  307. # Distributed communication
  308. set(MGB_ENABLE_OPR_MM ${MGE_WITH_DISTRIBUTED})
  309. # Write out megbrain_build_config.h
  310. configure_file(src/core/include/megbrain_build_config.h.in ${CMAKE_CURRENT_BINARY_DIR}/genfiles/megbrain_build_config.h)
  311. install(FILES ${CMAKE_CURRENT_BINARY_DIR}/genfiles/megbrain_build_config.h DESTINATION include)
  312. add_subdirectory(dnn)
  313. list(APPEND MGB_OPR_PARAM_DEFS_SRCS ${CMAKE_CURRENT_SOURCE_DIR}/tools/param_defs/mgb_opr_param_defs.py)
  314. set(MGB_OPR_PARAM_DEFS_SCRIPT ${CMAKE_CURRENT_SOURCE_DIR}/dnn/scripts/gen_param_defs.py)
  315. set(MGB_OPR_PARAM_DEFS_OUT_DIR ${CMAKE_CURRENT_BINARY_DIR}/src/opr/include/)
  316. file(MAKE_DIRECTORY ${MGB_OPR_PARAM_DEFS_OUT_DIR}/megbrain/opr)
  317. add_custom_command(
  318. OUTPUT
  319. ${MGB_OPR_PARAM_DEFS_OUT_DIR}/megbrain/opr/param_defs.h
  320. COMMAND ${PYTHON_EXECUTABLE} ${MGB_OPR_PARAM_DEFS_SCRIPT} ${MGB_OPR_PARAM_DEFS_SRCS}
  321. ${MGB_OPR_PARAM_DEFS_OUT_DIR}/megbrain/opr/param_defs.h
  322. DEPENDS ${MGB_OPR_PARAM_DEFS_SRCS} ${MGB_OPR_PARAM_DEFS_SCRIPT}
  323. VERBATIM
  324. )
  325. list(APPEND MGB_OPR_PARAM_DEFS_OUTS
  326. ${MGB_OPR_PARAM_DEFS_OUT_DIR}/megbrain/opr/param_defs.h
  327. )
  328. install(FILES ${MGB_OPR_PARAM_DEFS_OUTS} DESTINATION include/megbrain/opr/)
  329. list(APPEND MGB_OPR_PARAM_DEFS_INC ${MGB_OPR_PARAM_DEFS_OUT_DIR})
  330. add_custom_target(_mgb_opr_param_defs DEPENDS ${MGB_OPR_PARAM_DEFS_OUTS})
  331. add_library(mgb_opr_param_defs INTERFACE)
  332. target_include_directories(mgb_opr_param_defs INTERFACE ${MGB_OPR_PARAM_DEFS_INC})
  333. add_dependencies(mgb_opr_param_defs _mgb_opr_param_defs)
  334. if(MGE_WITH_DISTRIBUTED)
  335. add_subdirectory(${PROJECT_SOURCE_DIR}/third_party/MegRay)
  336. endif()
  337. add_subdirectory(src)
  338. add_subdirectory(sdk/load-and-run)
  339. if(MGE_WITH_PYTHON_MODULE)
  340. add_subdirectory(python_module)
  341. endif()
  342. if(MGE_WITH_TEST AND MGE_ENABLE_RTTI)
  343. add_subdirectory(test)
  344. endif()
  345. if(TARGET _mgb)
  346. add_custom_target(
  347. develop
  348. COMMAND ${CMAKE_COMMAND} -E create_symlink
  349. ${CMAKE_CURRENT_BINARY_DIR}/python_module/megengine/_internal/$<TARGET_FILE_NAME:_mgb>
  350. ${CMAKE_CURRENT_SOURCE_DIR}/python_module/megengine/_internal/$<TARGET_FILE_NAME:_mgb>
  351. COMMAND ${CMAKE_COMMAND} -E create_symlink
  352. ${CMAKE_CURRENT_BINARY_DIR}/python_module/megengine/_internal/mgb.py
  353. ${CMAKE_CURRENT_SOURCE_DIR}/python_module/megengine/_internal/mgb.py
  354. COMMAND ${CMAKE_COMMAND} -E create_symlink
  355. ${CMAKE_CURRENT_BINARY_DIR}/python_module/megengine/_internal/opr.py
  356. ${CMAKE_CURRENT_SOURCE_DIR}/python_module/megengine/_internal/opr.py
  357. COMMAND ${CMAKE_COMMAND} -E create_symlink
  358. ${CMAKE_CURRENT_BINARY_DIR}/python_module/megengine/_internal/opr_param_defs.py
  359. ${CMAKE_CURRENT_SOURCE_DIR}/python_module/megengine/_internal/opr_param_defs.py
  360. COMMAND ${CMAKE_COMMAND} -E create_symlink
  361. ${CMAKE_CURRENT_BINARY_DIR}/python_module/megengine/_internal/include
  362. ${CMAKE_CURRENT_SOURCE_DIR}/python_module/megengine/_internal/include
  363. DEPENDS _mgb
  364. VERBATIM
  365. )
  366. endif()

MegEngine 安装包中集成了使用 GPU 运行代码所需的 CUDA 环境,不用区分 CPU 和 GPU 版。 如果想要运行 GPU 程序,请确保机器本身配有 GPU 硬件设备并安装好驱动。 如果你想体验在云端 GPU 算力平台进行深度学习开发的感觉,欢迎访问 MegStudio 平台