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

4 years ago
4 years ago
4 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  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. set(protobuf_CXXFLAGS "-Wno-maybe-uninitialized -Wno-unused-parameter -fPIC -fstack-protector-all -D_FORTIFY_SOURCE=2 -D_GLIBCXX_USE_CXX11_ABI=0 -O2")
  13. set(protobuf_LDFLAGS "-Wl,-z,relro,-z,now,-z,noexecstack")
  14. ExternalProject_Add(protoc_build
  15. URL https://github.com/protocolbuffers/protobuf/archive/v3.8.0.tar.gz
  16. #URL /home/txd/workspace/linux_cmake/pkg/protobuf-3.8.0.tar.gz
  17. SOURCE_DIR ${GE_CODE_DIR}/../third_party/protobuf/src/protobuf-3.8.0
  18. 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
  19. BUILD_COMMAND $(MAKE)
  20. INSTALL_COMMAND $(MAKE) install
  21. EXCLUDE_FROM_ALL TRUE
  22. )
  23. set(PROTOC_PKG_DIR ${CMAKE_INSTALL_PREFIX}/protoc)
  24. set(protoc_EXECUTABLE ${PROTOC_PKG_DIR}/${CMAKE_INSTALL_BINDIR}/protoc)
  25. function(protobuf_generate comp c_var h_var)
  26. if(NOT ARGN)
  27. message(SEND_ERROR "Error: protobuf_generate() called without any proto files")
  28. return()
  29. endif()
  30. set(${c_var})
  31. set(${h_var})
  32. foreach(file ${ARGN})
  33. get_filename_component(abs_file ${file} ABSOLUTE)
  34. get_filename_component(file_name ${file} NAME_WE)
  35. get_filename_component(file_dir ${abs_file} PATH)
  36. get_filename_component(parent_subdir ${file_dir} NAME)
  37. if("${parent_subdir}" STREQUAL "proto")
  38. set(proto_output_path ${CMAKE_BINARY_DIR}/proto/${comp}/proto)
  39. else()
  40. set(proto_output_path ${CMAKE_BINARY_DIR}/proto/${comp}/proto/${parent_subdir})
  41. endif()
  42. list(APPEND ${c_var} "${proto_output_path}/${file_name}.pb.cc")
  43. list(APPEND ${h_var} "${proto_output_path}/${file_name}.pb.h")
  44. add_custom_command(
  45. OUTPUT "${proto_output_path}/${file_name}.pb.cc" "${proto_output_path}/${file_name}.pb.h"
  46. WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
  47. COMMAND ${CMAKE_COMMAND} -E make_directory "${proto_output_path}"
  48. COMMAND ${protoc_EXECUTABLE} -I${file_dir} --cpp_out=${proto_output_path} ${abs_file}
  49. DEPENDS protoc_build ${abs_file}
  50. COMMENT "Running C++ protocol buffer compiler on ${file}" VERBATIM )
  51. endforeach()
  52. set_source_files_properties(${${c_var}} ${${h_var}} PROPERTIES GENERATED TRUE)
  53. set(${c_var} ${${c_var}} PARENT_SCOPE)
  54. set(${h_var} ${${h_var}} PARENT_SCOPE)
  55. endfunction()
  56. function(protobuf_generate_py comp py_var)
  57. if(NOT ARGN)
  58. message(SEND_ERROR "Error: protobuf_generate_py() called without any proto files")
  59. return()
  60. endif()
  61. set(${py_var})
  62. foreach(file ${ARGN})
  63. get_filename_component(abs_file ${file} ABSOLUTE)
  64. get_filename_component(file_name ${file} NAME_WE)
  65. get_filename_component(file_dir ${abs_file} PATH)
  66. get_filename_component(parent_subdir ${file_dir} NAME)
  67. if("${parent_subdir}" STREQUAL "proto")
  68. set(proto_output_path ${CMAKE_BINARY_DIR}/proto/${comp}/proto)
  69. else()
  70. set(proto_output_path ${CMAKE_BINARY_DIR}/proto/${comp}/proto/${parent_subdir})
  71. endif()
  72. list(APPEND ${py_var} "${proto_output_path}/${file_name}_pb2.py")
  73. add_custom_command(
  74. OUTPUT "${proto_output_path}/${file_name}_pb2.py"
  75. WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
  76. COMMAND ${CMAKE_COMMAND} -E make_directory "${proto_output_path}"
  77. COMMAND ${protoc_EXECUTABLE} -I${file_dir} --python_out=${proto_output_path} ${abs_file}
  78. DEPENDS protoc_build ${abs_file}
  79. COMMENT "Running PYTHON protocol buffer compiler on ${file}" VERBATIM )
  80. endforeach()
  81. set_source_files_properties(${${py_var}} PROPERTIES GENERATED TRUE)
  82. set(${py_var} ${${py_var}} PARENT_SCOPE)
  83. endfunction()
  84. #set(HAVE_PROTOC TRUE CACHE BOOL "protoc build add")
  85. set(HAVE_PROTOC TRUE)

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