Commit 68ec623d authored by Robert Kimball's avatar Robert Kimball Committed by Scott Cyphers

Revert "Statically link cpu backend into ngraph shared library (#1444)" (#1457)

This reverts commit 5ab5a129.
parent 5ab5a129
...@@ -188,25 +188,24 @@ include_directories("${NGRAPH_INCLUDE_PATH}") ...@@ -188,25 +188,24 @@ include_directories("${NGRAPH_INCLUDE_PATH}")
add_subdirectory(codegen) add_subdirectory(codegen)
add_subdirectory(runtime) add_subdirectory(runtime)
add_library(ngraph_core STATIC ${SRC}) add_library(ngraph SHARED ${SRC})
target_compile_definitions(ngraph_core PRIVATE SHARED_LIB_EXT="${CMAKE_SHARED_LIBRARY_SUFFIX}") target_compile_definitions(ngraph PRIVATE SHARED_LIB_EXT="${CMAKE_SHARED_LIBRARY_SUFFIX}")
set_target_properties(ngraph_core PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION}) set_target_properties(ngraph PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION})
target_link_libraries(ngraph_core PUBLIC libjson) target_link_libraries(ngraph PUBLIC libjson)
target_compile_definitions(ngraph_core PUBLIC NGRAPH_VERSION="${NGRAPH_VERSION}") target_compile_definitions(ngraph PUBLIC NGRAPH_VERSION="${NGRAPH_VERSION}")
target_compile_options(ngraph_core PRIVATE -fPIC)
if (NGRAPH_ONNX_IMPORT_ENABLE) if (NGRAPH_ONNX_IMPORT_ENABLE)
add_dependencies(ngraph_core onnx_import) add_dependencies(ngraph onnx_import)
endif() endif()
if (NOT APPLE) if (NOT APPLE)
set_property(TARGET ngraph_core APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--rpath,$ORIGIN") set_property(TARGET ngraph APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--rpath,$ORIGIN")
# nGraph links against one or more libraries (ex. LLVM) but we don't want to # nGraph links against one or more libraries (ex. LLVM) but we don't want to
# export these symbols as part of the DSO. This is a GNU ld (and derivatives) specific # export these symbols as part of the DSO. This is a GNU ld (and derivatives) specific
# option so making this portable is still an open issue. As a note for the future, # option so making this portable is still an open issue. As a note for the future,
# this is not an issue on Windows and LLVM's lld does support --exclude-libs. # this is not an issue on Windows and LLVM's lld does support --exclude-libs.
set_property(TARGET ngraph_core APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--exclude-libs,ALL") set_property(TARGET ngraph APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--exclude-libs,ALL")
# GCC invokes the linker with --as-needed by default which doesn't work for us # GCC invokes the linker with --as-needed by default which doesn't work for us
# because generated code needs to find symbols in these DSOs at runtime. # because generated code needs to find symbols in these DSOs at runtime.
...@@ -215,35 +214,19 @@ if (NOT APPLE) ...@@ -215,35 +214,19 @@ if (NOT APPLE)
# _do_ need to be linked with --as-needed with a higher priority for the # _do_ need to be linked with --as-needed with a higher priority for the
# Intel OpenMP runtime so we don't mix libgomp and libiomp5 # Intel OpenMP runtime so we don't mix libgomp and libiomp5
if (CMAKE_CXX_COMPILER_ID STREQUAL "GNU") if (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
set_property(TARGET ngraph_core APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--no-as-needed") set_property(TARGET ngraph APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--no-as-needed")
endif() endif()
endif() endif()
# Defines macro in C++ to load backend plugin # Defines macro in C++ to load backend plugin
target_include_directories(ngraph_core PUBLIC "${NGRAPH_INCLUDE_PATH}") target_include_directories(ngraph PUBLIC "${NGRAPH_INCLUDE_PATH}")
if (NOT WIN32) if (NOT WIN32)
target_link_libraries(ngraph_core PUBLIC dl pthread) target_link_libraries(ngraph PUBLIC dl pthread)
endif() endif()
if (NGRAPH_ONNX_IMPORT_ENABLE) if (NGRAPH_ONNX_IMPORT_ENABLE)
target_sources(ngraph_core PRIVATE $<TARGET_OBJECTS:onnx_import_interface>) target_sources(ngraph PRIVATE $<TARGET_OBJECTS:onnx_import_interface>)
target_link_libraries(ngraph_core PRIVATE onnx_import) target_link_libraries(ngraph PRIVATE onnx_import)
endif()
add_library(ngraph SHARED)
set_target_properties(ngraph PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION})
if (APPLE)
target_link_libraries(ngraph PUBLIC -Wl,-force_load ngraph_core)
else()
target_link_libraries(ngraph PUBLIC -Wl,--whole-archive ngraph_core -Wl,--no-whole-archive)
endif()
if (NGRAPH_CPU_ENABLE)
if (APPLE)
target_link_libraries(ngraph PUBLIC -Wl,-force_load cpu_backend)
else()
target_link_libraries(ngraph PUBLIC -Wl,--whole-archive cpu_backend -Wl,--no-whole-archive)
endif()
endif() endif()
#----------------------------------------------------------------------------------------------- #-----------------------------------------------------------------------------------------------
......
...@@ -76,6 +76,6 @@ if ((NGRAPH_CPU_ENABLE AND NOT NGRAPH_DEX_ONLY) OR NGRAPH_GPU_ENABLE) ...@@ -76,6 +76,6 @@ if ((NGRAPH_CPU_ENABLE AND NOT NGRAPH_DEX_ONLY) OR NGRAPH_GPU_ENABLE)
set_target_properties(codegen PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION}) set_target_properties(codegen PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION})
add_dependencies(codegen header_resource libmkldnn libeigen) add_dependencies(codegen header_resource libmkldnn libeigen)
target_include_directories(codegen SYSTEM PUBLIC ${CMAKE_BINARY_DIR}) target_include_directories(codegen SYSTEM PUBLIC ${CMAKE_BINARY_DIR})
target_link_libraries(codegen PRIVATE libllvm ngraph_core) target_link_libraries(codegen PRIVATE libllvm ngraph)
install(TARGETS codegen DESTINATION ${NGRAPH_INSTALL_LIB}) install(TARGETS codegen DESTINATION ${NGRAPH_INSTALL_LIB})
endif() endif()
...@@ -133,9 +133,8 @@ endif() ...@@ -133,9 +133,8 @@ endif()
if (NGRAPH_CPU_ENABLE) if (NGRAPH_CPU_ENABLE)
set(NGRAPH_CPU_DEBUGINFO_ENABLE 0 CACHE STRING "Enable debuginfo in the CPU backend") set(NGRAPH_CPU_DEBUGINFO_ENABLE 0 CACHE STRING "Enable debuginfo in the CPU backend")
add_library(cpu_backend STATIC ${SRC}) add_library(cpu_backend SHARED ${SRC})
set_target_properties(cpu_backend PROPERTIES VERSION ${NGRAPH_VERSION}) set_target_properties(cpu_backend PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION})
target_compile_options(cpu_backend PRIVATE -fPIC)
if (NGRAPH_DEX_ONLY) if (NGRAPH_DEX_ONLY)
target_compile_definitions(cpu_backend PRIVATE "NGRAPH_DEX_ONLY") target_compile_definitions(cpu_backend PRIVATE "NGRAPH_DEX_ONLY")
endif() endif()
...@@ -149,9 +148,12 @@ if (NGRAPH_CPU_ENABLE) ...@@ -149,9 +148,12 @@ if (NGRAPH_CPU_ENABLE)
endif() endif()
add_dependencies(cpu_backend ext_mkldnn ext_eigen) add_dependencies(cpu_backend ext_mkldnn ext_eigen)
target_link_libraries(cpu_backend PUBLIC ngraph_core libmkldnn libeigen libjson libtbb) target_link_libraries(cpu_backend PUBLIC ngraph libmkldnn libeigen libjson libtbb)
if (NOT NGRAPH_DEX_ONLY) if (NOT NGRAPH_DEX_ONLY)
target_link_libraries(cpu_backend PUBLIC codegen) target_link_libraries(cpu_backend PUBLIC codegen)
endif() endif()
target_include_directories(cpu_backend SYSTEM PUBLIC libmkldnn) target_include_directories(cpu_backend SYSTEM PUBLIC libmkldnn)
set_target_properties(cpu_backend PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${NGRAPH_BUILD_DIR})
install(TARGETS cpu_backend LIBRARY DESTINATION ${NGRAPH_INSTALL_LIB})
endif() endif()
...@@ -17,7 +17,6 @@ ...@@ -17,7 +17,6 @@
#include <tbb/tbb_stddef.h> #include <tbb/tbb_stddef.h>
#include "ngraph/graph_util.hpp" #include "ngraph/graph_util.hpp"
#include "ngraph/runtime/backend_manager.hpp"
#include "ngraph/runtime/cpu/cpu_backend.hpp" #include "ngraph/runtime/cpu/cpu_backend.hpp"
#include "ngraph/runtime/cpu/cpu_call_frame.hpp" #include "ngraph/runtime/cpu/cpu_call_frame.hpp"
#include "ngraph/runtime/cpu/cpu_external_function.hpp" #include "ngraph/runtime/cpu/cpu_external_function.hpp"
...@@ -27,21 +26,21 @@ ...@@ -27,21 +26,21 @@
using namespace ngraph; using namespace ngraph;
using namespace std; using namespace std;
namespace extern "C" const char* get_ngraph_version_string()
{ {
runtime::Backend* new_backend(const char* configuration_string) return NGRAPH_VERSION;
{ }
// Force TBB to link to the backend
tbb::TBB_runtime_interface_version();
return new runtime::cpu::CPU_Backend();
}
static class NGRAPH_CPUStaticInit extern "C" runtime::Backend* new_backend(const char* configuration_string)
{ {
public: // Force TBB to link to the backend
NGRAPH_CPUStaticInit() { runtime::BackendManager::register_backend("CPU", new_backend); } tbb::TBB_runtime_interface_version();
~NGRAPH_CPUStaticInit() {} return new runtime::cpu::CPU_Backend();
} s_init; }
extern "C" void delete_backend(runtime::Backend* backend)
{
delete backend;
} }
shared_ptr<runtime::cpu::CPU_CallFrame> runtime::cpu::CPU_Backend::make_call_frame( shared_ptr<runtime::cpu::CPU_CallFrame> runtime::cpu::CPU_Backend::make_call_frame(
......
...@@ -27,7 +27,6 @@ if (NGRAPH_INTERPRETER_ENABLE) ...@@ -27,7 +27,6 @@ if (NGRAPH_INTERPRETER_ENABLE)
set_target_properties(interpreter_backend PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION}) set_target_properties(interpreter_backend PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION})
target_link_libraries(interpreter_backend PUBLIC ngraph) target_link_libraries(interpreter_backend PUBLIC ngraph)
set_target_properties(interpreter_backend PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${NGRAPH_BUILD_DIR}) set_target_properties(interpreter_backend PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${NGRAPH_BUILD_DIR})
target_compile_options(interpreter_backend PRIVATE -fPIC)
install(TARGETS interpreter_backend install(TARGETS interpreter_backend
LIBRARY DESTINATION "${NGRAPH_INSTALL_LIB}" LIBRARY DESTINATION "${NGRAPH_INSTALL_LIB}"
......
...@@ -22,6 +22,9 @@ set (SRC ...@@ -22,6 +22,9 @@ set (SRC
add_executable(nbench ${SRC}) add_executable(nbench ${SRC})
target_link_libraries(nbench ngraph) target_link_libraries(nbench ngraph)
if (NGRAPH_CPU_ENABLE)
target_link_libraries(nbench cpu_backend)
endif()
if (NGRAPH_INTELGPU_ENABLE) if (NGRAPH_INTELGPU_ENABLE)
target_link_libraries(nbench intelgpu_backend) target_link_libraries(nbench intelgpu_backend)
endif() endif()
......
...@@ -131,7 +131,7 @@ endif() ...@@ -131,7 +131,7 @@ endif()
if (NGRAPH_CPU_ENABLE) if (NGRAPH_CPU_ENABLE)
# The INTERPRETER backend is required for graph_partition, convolution, and backwards unit tests # The INTERPRETER backend is required for graph_partition, convolution, and backwards unit tests
target_link_libraries(unit-test interpreter_backend) target_link_libraries(unit-test cpu_backend interpreter_backend)
target_link_libraries(unit-test libmkldnn) target_link_libraries(unit-test libmkldnn)
endif() endif()
...@@ -150,7 +150,7 @@ endif() ...@@ -150,7 +150,7 @@ endif()
add_custom_target(unit-test-check add_custom_target(unit-test-check
COMMAND ${PROJECT_BINARY_DIR}/test/unit-test \${ARGS} COMMAND ${PROJECT_BINARY_DIR}/test/unit-test \${ARGS}
DEPENDS unit-test nbench DEPENDS unit-test
) )
add_custom_target(check add_custom_target(check
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment