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.

protoc.cmake 5.5 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. if (HAVE_PROTOC)
  2. return()
  3. endif()
  4. include(ExternalProject)
  5. include(GNUInstallDirs)
  6. #set(CMAKE_INSTALL_PREFIX ${GE_CODE_DIR}/output)
  7. if ((${CMAKE_INSTALL_PREFIX} STREQUAL /usr/local) OR
  8. (${CMAKE_INSTALL_PREFIX} STREQUAL "C:/Program Files (x86)/ascend"))
  9. set(CMAKE_INSTALL_PREFIX ${GE_CODE_DIR}/output CACHE STRING "path for install()" FORCE)
  10. message(STATUS "No install prefix selected, default to ${CMAKE_INSTALL_PREFIX}.")
  11. endif()
  12. if(GE_PB_PKG)
  13. set(REQ_URL "${GE_PB_PKG}/libs/protobuf/v3.13.0.tar.gz")
  14. else()
  15. if (ENABLE_GITEE)
  16. set(REQ_URL "https://gitee.com/mirrors/protobuf_source/repository/archive/v3.13.0.tar.gz")
  17. set(MD5 "f4489cb88922ad9c58cbe3308d59cee5")
  18. else()
  19. set(REQ_URL "https://github.com/protocolbuffers/protobuf/archive/v3.13.0.tar.gz")
  20. set(MD5 "1a6274bc4a65b55a6fa70e264d796490")
  21. endif ()
  22. endif()
  23. set(protobuf_CXXFLAGS "-Wno-maybe-uninitialized -Wno-unused-parameter -fPIC -fstack-protector-all -D_FORTIFY_SOURCE=2 -D_GLIBCXX_USE_CXX11_ABI=0 -O2")
  24. set(protobuf_LDFLAGS "-Wl,-z,relro,-z,now,-z,noexecstack")
  25. ExternalProject_Add(protoc_build
  26. URL ${REQ_URL}
  27. TLS_VERIFY OFF
  28. CONFIGURE_COMMAND ${CMAKE_COMMAND} -Dprotobuf_WITH_ZLIB=OFF -Dprotobuf_BUILD_TESTS=OFF -DBUILD_SHARED_LIBS=OFF -DCMAKE_CXX_FLAGS=${protobuf_CXXFLAGS} -DCMAKE_CXX_LDFLAGS=${protobuf_LDFLAGS} -DCMAKE_INSTALL_PREFIX=${CMAKE_INSTALL_PREFIX}/protoc <SOURCE_DIR>/cmake
  29. BUILD_COMMAND $(MAKE)
  30. INSTALL_COMMAND $(MAKE) install
  31. EXCLUDE_FROM_ALL TRUE
  32. )
  33. set(PROTOC_PKG_DIR ${CMAKE_INSTALL_PREFIX}/protoc)
  34. set(protoc_EXECUTABLE ${PROTOC_PKG_DIR}/${CMAKE_INSTALL_BINDIR}/protoc)
  35. function(protobuf_generate comp c_var h_var)
  36. if(NOT ARGN)
  37. message(SEND_ERROR "Error: protobuf_generate() called without any proto files")
  38. return()
  39. endif()
  40. set(${c_var})
  41. set(${h_var})
  42. set(_add_target FALSE)
  43. foreach(file ${ARGN})
  44. if("${file}" STREQUAL "TARGET")
  45. set(_add_target TRUE)
  46. continue()
  47. endif()
  48. get_filename_component(abs_file ${file} ABSOLUTE)
  49. get_filename_component(file_name ${file} NAME_WE)
  50. get_filename_component(file_dir ${abs_file} PATH)
  51. get_filename_component(parent_subdir ${file_dir} NAME)
  52. if("${parent_subdir}" STREQUAL "proto")
  53. set(proto_output_path ${CMAKE_BINARY_DIR}/proto/${comp}/proto)
  54. else()
  55. set(proto_output_path ${CMAKE_BINARY_DIR}/proto/${comp}/proto/${parent_subdir})
  56. endif()
  57. list(APPEND ${c_var} "${proto_output_path}/${file_name}.pb.cc")
  58. list(APPEND ${h_var} "${proto_output_path}/${file_name}.pb.h")
  59. add_custom_command(
  60. OUTPUT "${proto_output_path}/${file_name}.pb.cc" "${proto_output_path}/${file_name}.pb.h"
  61. WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
  62. COMMAND ${CMAKE_COMMAND} -E make_directory "${proto_output_path}"
  63. COMMAND ${CMAKE_COMMAND} -E echo "generate proto cpp_out ${comp} by ${abs_file}"
  64. COMMAND ${protoc_EXECUTABLE} -I${file_dir} --cpp_out=${proto_output_path} ${abs_file}
  65. DEPENDS protoc_build ${abs_file}
  66. COMMENT "Running C++ protocol buffer compiler on ${file}" VERBATIM )
  67. endforeach()
  68. if(_add_target)
  69. add_custom_target(
  70. ${comp} DEPENDS ${${c_var}} ${${h_var}}
  71. )
  72. endif()
  73. set_source_files_properties(${${c_var}} ${${h_var}} PROPERTIES GENERATED TRUE)
  74. set(${c_var} ${${c_var}} PARENT_SCOPE)
  75. set(${h_var} ${${h_var}} PARENT_SCOPE)
  76. endfunction()
  77. function(protobuf_generate_py comp py_var)
  78. if(NOT ARGN)
  79. message(SEND_ERROR "Error: protobuf_generate_py() called without any proto files")
  80. return()
  81. endif()
  82. set(${py_var})
  83. set(_add_target FALSE)
  84. foreach(file ${ARGN})
  85. if("${file}" STREQUAL "TARGET")
  86. set(_add_target TRUE)
  87. continue()
  88. endif()
  89. get_filename_component(abs_file ${file} ABSOLUTE)
  90. get_filename_component(file_name ${file} NAME_WE)
  91. get_filename_component(file_dir ${abs_file} PATH)
  92. get_filename_component(parent_subdir ${file_dir} NAME)
  93. if("${parent_subdir}" STREQUAL "proto")
  94. set(proto_output_path ${CMAKE_BINARY_DIR}/proto/${comp}/proto)
  95. else()
  96. set(proto_output_path ${CMAKE_BINARY_DIR}/proto/${comp}/proto/${parent_subdir})
  97. endif()
  98. list(APPEND ${py_var} "${proto_output_path}/${file_name}_pb2.py")
  99. add_custom_command(
  100. OUTPUT "${proto_output_path}/${file_name}_pb2.py"
  101. WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
  102. COMMAND ${CMAKE_COMMAND} -E make_directory "${proto_output_path}"
  103. COMMAND ${CMAKE_COMMAND} -E echo "generate proto cpp_out ${comp} by ${abs_file}"
  104. COMMAND ${protoc_EXECUTABLE} -I${file_dir} --python_out=${proto_output_path} ${abs_file}
  105. DEPENDS protoc_build ${abs_file}
  106. COMMENT "Running PYTHON protocol buffer compiler on ${file}" VERBATIM )
  107. endforeach()
  108. if(_add_target)
  109. add_custom_target(
  110. ${comp} DEPENDS ${${py_var}}
  111. )
  112. endif()
  113. set_source_files_properties(${${py_var}} PROPERTIES GENERATED TRUE)
  114. set(${py_var} ${${py_var}} PARENT_SCOPE)
  115. endfunction()
  116. #set(HAVE_PROTOC TRUE CACHE BOOL "protoc build add")
  117. set(HAVE_PROTOC TRUE)

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