Commit 5ab5a129 authored by Robert Kimball's avatar Robert Kimball Committed by Scott Cyphers

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

* static link cpu library to ngraph

* remove debug

* link ngraph and cpu backend into a single shared object

* add -fPIC and whole-archive for CPU backend

* Added conditional for --whole-archive for Mac OS.

* Added more conditonal for MacOS.

* fix linking problem and unit test failures caused by multiple copies of the same function in CPU backend and INTERPRETER

* fix nbench build

* add nbench to unit test build

* add version number to libngraph
parent 0050950d
......@@ -188,24 +188,25 @@ include_directories("${NGRAPH_INCLUDE_PATH}")
add_subdirectory(codegen)
add_subdirectory(runtime)
add_library(ngraph SHARED ${SRC})
target_compile_definitions(ngraph PRIVATE SHARED_LIB_EXT="${CMAKE_SHARED_LIBRARY_SUFFIX}")
set_target_properties(ngraph PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION})
target_link_libraries(ngraph PUBLIC libjson)
target_compile_definitions(ngraph PUBLIC NGRAPH_VERSION="${NGRAPH_VERSION}")
add_library(ngraph_core STATIC ${SRC})
target_compile_definitions(ngraph_core PRIVATE SHARED_LIB_EXT="${CMAKE_SHARED_LIBRARY_SUFFIX}")
set_target_properties(ngraph_core PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION})
target_link_libraries(ngraph_core PUBLIC libjson)
target_compile_definitions(ngraph_core PUBLIC NGRAPH_VERSION="${NGRAPH_VERSION}")
target_compile_options(ngraph_core PRIVATE -fPIC)
if (NGRAPH_ONNX_IMPORT_ENABLE)
add_dependencies(ngraph onnx_import)
add_dependencies(ngraph_core onnx_import)
endif()
if (NOT APPLE)
set_property(TARGET ngraph APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--rpath,$ORIGIN")
set_property(TARGET ngraph_core APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--rpath,$ORIGIN")
# 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
# 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.
set_property(TARGET ngraph APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--exclude-libs,ALL")
set_property(TARGET ngraph_core APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--exclude-libs,ALL")
# 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.
......@@ -214,19 +215,35 @@ if (NOT APPLE)
# _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
if (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
set_property(TARGET ngraph APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--no-as-needed")
set_property(TARGET ngraph_core APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--no-as-needed")
endif()
endif()
# Defines macro in C++ to load backend plugin
target_include_directories(ngraph PUBLIC "${NGRAPH_INCLUDE_PATH}")
target_include_directories(ngraph_core PUBLIC "${NGRAPH_INCLUDE_PATH}")
if (NOT WIN32)
target_link_libraries(ngraph PUBLIC dl pthread)
target_link_libraries(ngraph_core PUBLIC dl pthread)
endif()
if (NGRAPH_ONNX_IMPORT_ENABLE)
target_sources(ngraph PRIVATE $<TARGET_OBJECTS:onnx_import_interface>)
target_link_libraries(ngraph PRIVATE onnx_import)
target_sources(ngraph_core PRIVATE $<TARGET_OBJECTS:onnx_import_interface>)
target_link_libraries(ngraph_core 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()
#-----------------------------------------------------------------------------------------------
......
......@@ -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})
add_dependencies(codegen header_resource libmkldnn libeigen)
target_include_directories(codegen SYSTEM PUBLIC ${CMAKE_BINARY_DIR})
target_link_libraries(codegen PRIVATE libllvm ngraph)
target_link_libraries(codegen PRIVATE libllvm ngraph_core)
install(TARGETS codegen DESTINATION ${NGRAPH_INSTALL_LIB})
endif()
......@@ -133,8 +133,9 @@ endif()
if (NGRAPH_CPU_ENABLE)
set(NGRAPH_CPU_DEBUGINFO_ENABLE 0 CACHE STRING "Enable debuginfo in the CPU backend")
add_library(cpu_backend SHARED ${SRC})
set_target_properties(cpu_backend PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION})
add_library(cpu_backend STATIC ${SRC})
set_target_properties(cpu_backend PROPERTIES VERSION ${NGRAPH_VERSION})
target_compile_options(cpu_backend PRIVATE -fPIC)
if (NGRAPH_DEX_ONLY)
target_compile_definitions(cpu_backend PRIVATE "NGRAPH_DEX_ONLY")
endif()
......@@ -148,12 +149,9 @@ if (NGRAPH_CPU_ENABLE)
endif()
add_dependencies(cpu_backend ext_mkldnn ext_eigen)
target_link_libraries(cpu_backend PUBLIC ngraph libmkldnn libeigen libjson libtbb)
target_link_libraries(cpu_backend PUBLIC ngraph_core libmkldnn libeigen libjson libtbb)
if (NOT NGRAPH_DEX_ONLY)
target_link_libraries(cpu_backend PUBLIC codegen)
endif()
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()
......@@ -17,6 +17,7 @@
#include <tbb/tbb_stddef.h>
#include "ngraph/graph_util.hpp"
#include "ngraph/runtime/backend_manager.hpp"
#include "ngraph/runtime/cpu/cpu_backend.hpp"
#include "ngraph/runtime/cpu/cpu_call_frame.hpp"
#include "ngraph/runtime/cpu/cpu_external_function.hpp"
......@@ -26,21 +27,21 @@
using namespace ngraph;
using namespace std;
extern "C" const char* get_ngraph_version_string()
namespace
{
return NGRAPH_VERSION;
}
extern "C" runtime::Backend* new_backend(const char* configuration_string)
{
// Force TBB to link to the backend
tbb::TBB_runtime_interface_version();
return new runtime::cpu::CPU_Backend();
}
runtime::Backend* new_backend(const char* configuration_string)
{
// Force TBB to link to the backend
tbb::TBB_runtime_interface_version();
return new runtime::cpu::CPU_Backend();
}
extern "C" void delete_backend(runtime::Backend* backend)
{
delete backend;
static class NGRAPH_CPUStaticInit
{
public:
NGRAPH_CPUStaticInit() { runtime::BackendManager::register_backend("CPU", new_backend); }
~NGRAPH_CPUStaticInit() {}
} s_init;
}
shared_ptr<runtime::cpu::CPU_CallFrame> runtime::cpu::CPU_Backend::make_call_frame(
......
......@@ -27,6 +27,7 @@ if (NGRAPH_INTERPRETER_ENABLE)
set_target_properties(interpreter_backend PROPERTIES VERSION ${NGRAPH_VERSION} SOVERSION ${NGRAPH_API_VERSION})
target_link_libraries(interpreter_backend PUBLIC ngraph)
set_target_properties(interpreter_backend PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${NGRAPH_BUILD_DIR})
target_compile_options(interpreter_backend PRIVATE -fPIC)
install(TARGETS interpreter_backend
LIBRARY DESTINATION "${NGRAPH_INSTALL_LIB}"
......
......@@ -22,9 +22,6 @@ set (SRC
add_executable(nbench ${SRC})
target_link_libraries(nbench ngraph)
if (NGRAPH_CPU_ENABLE)
target_link_libraries(nbench cpu_backend)
endif()
if (NGRAPH_INTELGPU_ENABLE)
target_link_libraries(nbench intelgpu_backend)
endif()
......
......@@ -131,7 +131,7 @@ endif()
if (NGRAPH_CPU_ENABLE)
# The INTERPRETER backend is required for graph_partition, convolution, and backwards unit tests
target_link_libraries(unit-test cpu_backend interpreter_backend)
target_link_libraries(unit-test interpreter_backend)
target_link_libraries(unit-test libmkldnn)
endif()
......@@ -150,7 +150,7 @@ endif()
add_custom_target(unit-test-check
COMMAND ${PROJECT_BINARY_DIR}/test/unit-test \${ARGS}
DEPENDS unit-test
DEPENDS unit-test nbench
)
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