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 3.9 kB

5 years ago
5 years ago
5 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. set(PROTO_LIST
  2. "${METADEF_DIR}/proto/om.proto"
  3. "${METADEF_DIR}/proto/ge_ir.proto"
  4. "${METADEF_DIR}/proto/insert_op.proto"
  5. "${METADEF_DIR}/proto/task.proto"
  6. )
  7. protobuf_generate(ge PROTO_SRCS PROTO_HDRS ${PROTO_LIST})
  8. set(SRC_LIST
  9. "main.cc"
  10. "single_op_parser.cc"
  11. "keep_dtype_option.cc"
  12. "../session/omg.cc"
  13. "../ir_build/atc_ir_common.cc"
  14. )
  15. ############ atc_atc.bin ############
  16. add_executable(atc_atc.bin ${SRC_LIST} ${PROTO_HDRS})
  17. target_compile_options(atc_atc.bin PRIVATE
  18. -Werror
  19. -O2
  20. -Wno-deprecated-declarations
  21. -fno-common
  22. -fvisibility=hidden
  23. )
  24. target_compile_definitions(atc_atc.bin PRIVATE
  25. PROTOBUF_INLINE_NOT_IN_HEADERS=0
  26. COMPILE_OMG_PACKAGE
  27. google=ascend_private
  28. LOG_CPP
  29. FUNC_VISIBILITY
  30. )
  31. target_include_directories(atc_atc.bin PRIVATE
  32. ${CMAKE_CURRENT_LIST_DIR}
  33. ${GE_CODE_DIR}
  34. ${GE_CODE_DIR}/ge
  35. ${GE_CODE_DIR}/inc/external
  36. ${GE_CODE_DIR}/common/inc/external
  37. ${GE_CODE_DIR}/common/inc/external/graph
  38. ${GE_CODE_DIR}/inc
  39. ${GE_CODE_DIR}/inc/framework
  40. ${METADEF_DIR}/inc
  41. ${METADEF_DIR}/inc/graph
  42. ${METADEF_DIR}/inc/register
  43. ${METADEF_DIR}/inc/external
  44. ${METADEF_DIR}/inc/external/graph
  45. ${METADEF_DIR}/inc/external/register
  46. ${PARSER_DIR}
  47. ${CMAKE_BINARY_DIR}
  48. ${CMAKE_BINARY_DIR}/proto/ge
  49. #### yellow zone ####
  50. ${GE_CODE_DIR}/../inc
  51. ${GE_CODE_DIR}/../inc/common
  52. #### blue zone ####
  53. ${GE_CODE_DIR}/third_party/fwkacllib/inc
  54. ${GE_CODE_DIR}/third_party/fwkacllib/inc/toolchain
  55. )
  56. target_link_options(atc_atc.bin PRIVATE
  57. -Wl,-Bsymbolic
  58. )
  59. target_link_libraries(atc_atc.bin PRIVATE
  60. $<BUILD_INTERFACE:intf_pub>
  61. ascend_protobuf
  62. ge_common
  63. register
  64. c_sec
  65. graph
  66. error_manager
  67. ge_compiler
  68. parser_common
  69. gflags
  70. json
  71. runtime_compile
  72. slog
  73. static_mmpa
  74. -lrt
  75. -ldl
  76. )
  77. set_target_properties(atc_atc.bin PROPERTIES
  78. OUTPUT_NAME atc.bin
  79. RUNTIME_OUTPUT_DIRECTORY atclib
  80. )
  81. ############ fwk_atc.bin ############
  82. add_executable(fwk_atc.bin ${SRC_LIST} ${PROTO_HDRS})
  83. target_compile_options(fwk_atc.bin PRIVATE
  84. -Werror
  85. -O2
  86. -Wno-deprecated-declarations
  87. -fno-common
  88. -fvisibility=hidden
  89. )
  90. target_compile_definitions(fwk_atc.bin PRIVATE
  91. PROTOBUF_INLINE_NOT_IN_HEADERS=0
  92. COMPILE_OMG_PACKAGE
  93. google=ascend_private
  94. LOG_CPP
  95. FUNC_VISIBILITY
  96. )
  97. target_include_directories(fwk_atc.bin PRIVATE
  98. ${CMAKE_CURRENT_LIST_DIR}
  99. ${GE_CODE_DIR}
  100. ${GE_CODE_DIR}/ge
  101. ${GE_CODE_DIR}/inc/external
  102. ${GE_CODE_DIR}/common/inc/external
  103. ${GE_CODE_DIR}/common/inc/external/graph
  104. ${GE_CODE_DIR}/inc
  105. ${GE_CODE_DIR}/inc/framework
  106. ${METADEF_DIR}/inc
  107. ${METADEF_DIR}/inc/graph
  108. ${METADEF_DIR}/inc/register
  109. ${METADEF_DIR}/inc/external
  110. ${METADEF_DIR}/inc/external/graph
  111. ${METADEF_DIR}/inc/external/register
  112. ${PARSER_DIR}
  113. ${CMAKE_BINARY_DIR}
  114. ${CMAKE_BINARY_DIR}/proto/ge
  115. #### yellow zone ####
  116. ${GE_CODE_DIR}/../inc
  117. ${GE_CODE_DIR}/../inc/common
  118. #### blue zone ####
  119. ${GE_CODE_DIR}/third_party/fwkacllib/inc
  120. ${GE_CODE_DIR}/third_party/fwkacllib/inc/toolchain
  121. )
  122. target_link_options(fwk_atc.bin PRIVATE
  123. -Wl,-Bsymbolic
  124. )
  125. target_link_libraries(fwk_atc.bin PRIVATE
  126. $<BUILD_INTERFACE:intf_pub>
  127. ascend_protobuf
  128. ge_common
  129. register
  130. c_sec
  131. graph
  132. error_manager
  133. ge_runner
  134. parser_common
  135. gflags
  136. json
  137. runtime
  138. slog
  139. static_mmpa
  140. -lrt
  141. -ldl
  142. )
  143. set_target_properties(fwk_atc.bin PROPERTIES
  144. OUTPUT_NAME atc.bin
  145. RUNTIME_OUTPUT_DIRECTORY fwkacl
  146. )
  147. ############ install ############
  148. set(INSTALL_BASE_DIR "")
  149. set(INSTALL_LIBRARY_DIR lib)
  150. install(TARGETS atc_atc.bin OPTIONAL
  151. RUNTIME DESTINATION ${INSTALL_LIBRARY_DIR}/atclib
  152. )
  153. install(TARGETS fwk_atc.bin OPTIONAL
  154. RUNTIME DESTINATION ${INSTALL_LIBRARY_DIR}/fwkacl
  155. )

图引擎模块(GE)是MindSpore的一个子模块,其代码由C++实现,位于前端模块ME和底层硬件之间,起到承接作用。图引擎模块以ME下发的图作为输入,然后进行一系列的深度图优化操作,最后输出一张可以在底层硬件上高效运行的图。GE针对昇腾AI处理器的硬件结构特点,做了特定的优化工作,以此来充分发挥出昇腾AI处理器的强大算力。在进行模型训练/推理时,GE会被自动调用而用户并不感知。GE主要由GE API和GE Core两部分组成,详细的架构图如下所示