|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- find_package(Threads REQUIRED)
-
- # This branch assumes that gRPC and all its dependencies are already installed
- # on this system, so they can be located by find_package().
-
- # Find Protobuf installation
- # Looks for protobuf-config.cmake file installed by Protobuf's cmake installation.
-
- #set(protobuf_MODULE_COMPATIBLE TRUE)
- #find_package(Protobuf CONFIG REQUIRED)
- #message(STATUS "Using protobuf ${protobuf_VERSION}")
- add_library(protobuf::libprotobuf ALIAS protobuf::protobuf)
- add_executable(protobuf::libprotoc ALIAS protobuf::protoc)
-
- set(_PROTOBUF_LIBPROTOBUF protobuf::libprotobuf)
- if (CMAKE_CROSSCOMPILING)
- find_program(_PROTOBUF_PROTOC protoc)
- else ()
- set(_PROTOBUF_PROTOC $<TARGET_FILE:protobuf::protoc>)
- endif ()
-
- # Find gRPC installation
- # Looks for gRPCConfig.cmake file installed by gRPC's cmake installation.
- if (EXISTS ${grpc_ROOT}/lib64)
- set(gRPC_DIR "${grpc_ROOT}/lib64/cmake/grpc")
- else ()
- set(gRPC_DIR "${grpc_ROOT}/lib/cmake/grpc")
- endif ()
- message("serving using grpc_DIR : " ${gPRC_DIR})
-
- find_package(gRPC CONFIG REQUIRED)
- message(STATUS "Using gRPC ${gRPC_VERSION}")
-
- set(_GRPC_GRPCPP gRPC::grpc++)
- set(_REFLECTION gRPC::grpc++_reflection)
-
- if (CMAKE_CROSSCOMPILING)
- find_program(_GRPC_CPP_PLUGIN_EXECUTABLE grpc_cpp_plugin)
- find_program(_GRPC_PYTHON_PLUGIN_EXECUTABLE grpc_python_plugin)
- else ()
- set(_GRPC_CPP_PLUGIN_EXECUTABLE $<TARGET_FILE:gRPC::grpc_cpp_plugin>)
- set(_GRPC_PYTHON_PLUGIN_EXECUTABLE $<TARGET_FILE:gRPC::grpc_python_plugin>)
- endif ()
-
- # Proto file
- get_filename_component(hw_proto "ms_service.proto" ABSOLUTE)
- get_filename_component(hw_proto_path "${hw_proto}" PATH)
- # Generated sources
- set(hw_proto_srcs "${CMAKE_CURRENT_BINARY_DIR}/ms_service.pb.cc")
- set(hw_proto_hdrs "${CMAKE_CURRENT_BINARY_DIR}/ms_service.pb.h")
- set(hw_grpc_srcs "${CMAKE_CURRENT_BINARY_DIR}/ms_service.grpc.pb.cc")
- set(hw_grpc_hdrs "${CMAKE_CURRENT_BINARY_DIR}/ms_service.grpc.pb.h")
- set(hw_py_pb2 "${CMAKE_CURRENT_BINARY_DIR}/ms_service_pb2.py")
- set(hw_py_pb2_grpc "${CMAKE_CURRENT_BINARY_DIR}/ms_service_pb2_grpc.py")
- add_custom_command(
- OUTPUT "${hw_proto_srcs}" "${hw_proto_hdrs}" "${hw_grpc_srcs}" "${hw_grpc_hdrs}" "${hw_py_pb2}" "${hw_py_pb2_grpc}"
- COMMAND ${_PROTOBUF_PROTOC}
- ARGS --grpc_out "${CMAKE_CURRENT_BINARY_DIR}"
- --cpp_out "${CMAKE_CURRENT_BINARY_DIR}"
- -I "${hw_proto_path}"
- --plugin=protoc-gen-grpc="${_GRPC_CPP_PLUGIN_EXECUTABLE}"
- "${hw_proto}"
- COMMAND ${_PROTOBUF_PROTOC}
- ARGS --grpc_out "${CMAKE_CURRENT_BINARY_DIR}"
- --python_out "${CMAKE_CURRENT_BINARY_DIR}"
- -I "${hw_proto_path}"
- --plugin=protoc-gen-grpc="${_GRPC_PYTHON_PLUGIN_EXECUTABLE}"
- "${hw_proto}"
- DEPENDS "${hw_proto}")
-
- # Include generated *.pb.h files
- include_directories("${CMAKE_CURRENT_BINARY_DIR}" "${CMAKE_CURRENT_SOURCE_DIR}" "${CMAKE_CURRENT_SOURCE_DIR}/core"
- "${PROJECT_SOURCE_DIR}/mindspore/ccsrc" "${PROJECT_SOURCE_DIR}/mindspore/core")
- file(GLOB_RECURSE CORE_SRC_LIST RELATIVE ${CMAKE_CURRENT_SOURCE_DIR}
- "core/*.cc" "core/util/*.cc" "core/version_control/*.cc")
-
- list(APPEND SERVING_SRC "main.cc" ${hw_proto_srcs} ${hw_grpc_srcs} ${CORE_SRC_LIST})
-
- option(ENABLE_ACL "enable acl" OFF)
-
- if (ENABLE_ACL)
- if (DEFINED ENV{ASCEND_CUSTOM_PATH})
- set(ASCEND_PATH $ENV{ASCEND_CUSTOM_PATH})
- else ()
- set(ASCEND_PATH /usr/local/Ascend)
- endif ()
- set(ACL_LIB_DIR ${ASCEND_PATH}/acllib/)
- MESSAGE("acl lib dir " ${ACL_LIB_DIR})
-
- include_directories(${ACL_LIB_DIR}/include/)
- file(GLOB_RECURSE ACL_SESSION_SRC_LIST RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} "acl/*.cc")
- list(APPEND SERVING_SRC ${ACL_SESSION_SRC_LIST})
- endif ()
-
- include_directories(${CMAKE_BINARY_DIR})
-
- add_executable(ms_serving ${SERVING_SRC})
- #libevent
- target_link_libraries(ms_serving mindspore::event mindspore::event_pthreads)
-
- target_link_libraries(ms_serving ${_REFLECTION} ${_GRPC_GRPCPP} ${_PROTOBUF_LIBPROTOBUF} pthread)
- if (ENABLE_D)
- add_compile_definitions(ENABLE_D)
- target_link_libraries(ms_serving ${RUNTIME_LIB})
- endif ()
-
- if (ENABLE_ACL)
- add_compile_definitions(ENABLE_ACL)
- add_compile_definitions(ENABLE_DVPP_INTERFACE)
- set(ALC_LIB_SO ${ACL_LIB_DIR}/lib64/libruntime.so ${ACL_LIB_DIR}/lib64/libascendcl.so
- ${ACL_LIB_DIR}/lib64/libacl_retr.so ${ACL_LIB_DIR}/lib64/libacl_cblas.so
- ${ACL_LIB_DIR}/lib64/libacl_dvpp.so)
- target_link_libraries(ms_serving ${ALC_LIB_SO})
- target_link_libraries(ms_serving jpeg_turbo::jpeg)
- else ()
- target_link_libraries(ms_serving inference mindspore_gvar)
- endif ()
|