build: add combined shared library (libspdk.so)
Change-Id: If48df087c145a3fd278c0ae04558d8352b01cc1a Signed-off-by: Daniel Verkamp <daniel.verkamp@intel.com> Reviewed-on: https://review.gerrithub.io/414687 Reviewed-by: Jim Harris <james.r.harris@intel.com> Reviewed-by: Ben Walker <benjamin.walker@intel.com> Reviewed-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com> Tested-by: SPDK Automated Test System <sys_sgsw@intel.com>
This commit is contained in:
parent
9e21207a7c
commit
6f46e272c3
@ -2,6 +2,15 @@
|
|||||||
|
|
||||||
## v18.07: (Upcoming Release)
|
## v18.07: (Upcoming Release)
|
||||||
|
|
||||||
|
### Build System
|
||||||
|
|
||||||
|
The build system now generates a combined shared library (libspdk.so) that may be used
|
||||||
|
in place of the individual static libraries (libspdk_*.a).
|
||||||
|
The combined library includes all components of SPDK and is intended to make linking
|
||||||
|
against SPDK easier.
|
||||||
|
The static libraries are also still provided for users that prefer to link only the
|
||||||
|
minimal set of components required.
|
||||||
|
|
||||||
### RPC
|
### RPC
|
||||||
|
|
||||||
The `start_nbd_disk` RPC method now returns the path to the kernel NBD device node
|
The `start_nbd_disk` RPC method now returns the path to the kernel NBD device node
|
||||||
|
3
Makefile
3
Makefile
@ -36,7 +36,7 @@ S :=
|
|||||||
SPDK_ROOT_DIR := $(CURDIR)
|
SPDK_ROOT_DIR := $(CURDIR)
|
||||||
include $(SPDK_ROOT_DIR)/mk/spdk.common.mk
|
include $(SPDK_ROOT_DIR)/mk/spdk.common.mk
|
||||||
|
|
||||||
DIRS-y += lib examples app include
|
DIRS-y += lib shared_lib examples app include
|
||||||
DIRS-$(CONFIG_TESTS) += test
|
DIRS-$(CONFIG_TESTS) += test
|
||||||
|
|
||||||
.PHONY: all clean $(DIRS-y) config.h CONFIG.local mk/cc.mk cc_version cxx_version
|
.PHONY: all clean $(DIRS-y) config.h CONFIG.local mk/cc.mk cc_version cxx_version
|
||||||
@ -56,6 +56,7 @@ clean: $(DIRS-y)
|
|||||||
install: all
|
install: all
|
||||||
$(Q)echo "Installed to $(DESTDIR)$(CONFIG_PREFIX)"
|
$(Q)echo "Installed to $(DESTDIR)$(CONFIG_PREFIX)"
|
||||||
|
|
||||||
|
shared_lib: lib
|
||||||
lib: $(DPDKBUILD)
|
lib: $(DPDKBUILD)
|
||||||
app: lib
|
app: lib
|
||||||
test: lib
|
test: lib
|
||||||
|
@ -58,9 +58,7 @@ else
|
|||||||
DPDK_CONFIG := $(DPDK_CONFIG)-gcc
|
DPDK_CONFIG := $(DPDK_CONFIG)-gcc
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(CONFIG_FIO_PLUGIN),y)
|
|
||||||
DPDK_CFLAGS = -fPIC
|
DPDK_CFLAGS = -fPIC
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(CONFIG_DEBUG),y)
|
ifeq ($(CONFIG_DEBUG),y)
|
||||||
DPDK_CFLAGS += -O0 -g
|
DPDK_CFLAGS += -O0 -g
|
||||||
|
@ -238,6 +238,12 @@ INSTALL_LIB=\
|
|||||||
install -d -m 755 "$(DESTDIR)$(libdir)"; \
|
install -d -m 755 "$(DESTDIR)$(libdir)"; \
|
||||||
install -m 644 "$(LIB)" "$(DESTDIR)$(libdir)/"
|
install -m 644 "$(LIB)" "$(DESTDIR)$(libdir)/"
|
||||||
|
|
||||||
|
# Install a shared library
|
||||||
|
INSTALL_SHARED_LIB=\
|
||||||
|
$(Q)echo " INSTALL $(DESTDIR)$(libdir)/$(notdir $(SHARED_LIB))"; \
|
||||||
|
install -d -m 755 "$(DESTDIR)$(libdir)"; \
|
||||||
|
install -m 644 "$(SHARED_LIB)" "$(DESTDIR)$(libdir)/"
|
||||||
|
|
||||||
# Install an app binary
|
# Install an app binary
|
||||||
INSTALL_APP=\
|
INSTALL_APP=\
|
||||||
$(Q)echo " INSTALL $(DESTDIR)$(bindir)/$(APP)"; \
|
$(Q)echo " INSTALL $(DESTDIR)$(bindir)/$(APP)"; \
|
||||||
|
106
shared_lib/Makefile
Normal file
106
shared_lib/Makefile
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
#
|
||||||
|
# BSD LICENSE
|
||||||
|
#
|
||||||
|
# Copyright (c) Intel Corporation.
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions
|
||||||
|
# are met:
|
||||||
|
#
|
||||||
|
# * Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
# * Redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in
|
||||||
|
# the documentation and/or other materials provided with the
|
||||||
|
# distribution.
|
||||||
|
# * Neither the name of Intel Corporation nor the names of its
|
||||||
|
# contributors may be used to endorse or promote products derived
|
||||||
|
# from this software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
|
||||||
|
SPDK_ROOT_DIR := $(abspath $(CURDIR)/..)
|
||||||
|
include $(SPDK_ROOT_DIR)/mk/spdk.common.mk
|
||||||
|
include $(SPDK_ROOT_DIR)/mk/spdk.app.mk
|
||||||
|
include $(SPDK_ROOT_DIR)/mk/spdk.modules.mk
|
||||||
|
|
||||||
|
# Build combined libspdk.so shared library
|
||||||
|
SHARED_LIB = $(SPDK_ROOT_DIR)/build/lib/libspdk.so
|
||||||
|
|
||||||
|
SPDK_LIB_LIST += app_rpc
|
||||||
|
SPDK_LIB_LIST += bdev
|
||||||
|
SPDK_LIB_LIST += bdev_rpc
|
||||||
|
SPDK_LIB_LIST += blobfs
|
||||||
|
SPDK_LIB_LIST += conf
|
||||||
|
SPDK_LIB_LIST += copy
|
||||||
|
SPDK_LIB_LIST += event
|
||||||
|
SPDK_LIB_LIST += event_bdev
|
||||||
|
SPDK_LIB_LIST += event_copy
|
||||||
|
SPDK_LIB_LIST += event_iscsi
|
||||||
|
SPDK_LIB_LIST += event_net
|
||||||
|
SPDK_LIB_LIST += event_nvmf
|
||||||
|
SPDK_LIB_LIST += event_scsi
|
||||||
|
SPDK_LIB_LIST += iscsi
|
||||||
|
SPDK_LIB_LIST += json
|
||||||
|
SPDK_LIB_LIST += jsonrpc
|
||||||
|
SPDK_LIB_LIST += log
|
||||||
|
SPDK_LIB_LIST += log_rpc
|
||||||
|
SPDK_LIB_LIST += nvmf
|
||||||
|
SPDK_LIB_LIST += rpc
|
||||||
|
SPDK_LIB_LIST += scsi
|
||||||
|
SPDK_LIB_LIST += trace
|
||||||
|
SPDK_LIB_LIST += util
|
||||||
|
|
||||||
|
ifeq ($(OS),Linux)
|
||||||
|
SPDK_LIB_LIST += event_nbd
|
||||||
|
SPDK_LIB_LIST += nbd
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_VHOST),y)
|
||||||
|
SPDK_LIB_LIST += event_vhost
|
||||||
|
SPDK_LIB_LIST += rte_vhost
|
||||||
|
SPDK_LIB_LIST += vhost
|
||||||
|
endif
|
||||||
|
|
||||||
|
endif
|
||||||
|
|
||||||
|
LIBS += $(BLOCKDEV_MODULES_LINKER_ARGS)
|
||||||
|
LIBS += $(COPY_MODULES_LINKER_ARGS)
|
||||||
|
LIBS += $(NET_MODULES_LINKER_ARGS)
|
||||||
|
LIBS += $(SPDK_LIB_LINKER_ARGS)
|
||||||
|
LIBS += $(ENV_LINKER_ARGS)
|
||||||
|
|
||||||
|
comma := ,
|
||||||
|
|
||||||
|
$(SHARED_LIB): $(SPDK_LIB_FILES) $(SPDK_WHOLE_LIBS) $(BLOCKDEV_MODULES_FILES) $(COPY_MODULES_FILES) $(NET_MODULES_FILES) $(LINKER_MODULES) $(ENV_LIBS) $(MAKEFILE_LIST)
|
||||||
|
$(Q)echo " SO $(notdir $@)"; \
|
||||||
|
rm -f $@; \
|
||||||
|
$(CC) -o $@ -shared $(CPPFLAGS) $(LDFLAGS) \
|
||||||
|
-Wl,--whole-archive \
|
||||||
|
$(filter-out -Wl$(comma)--no-whole-archive,$(LIBS)) \
|
||||||
|
-Wl,--no-whole-archive \
|
||||||
|
-lcrypto \
|
||||||
|
$(SYS_LIBS)
|
||||||
|
|
||||||
|
.PHONY: all clean $(DIRS-y)
|
||||||
|
|
||||||
|
all: $(SHARED_LIB)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(CLEAN_C) $(SHARED_LIB)
|
||||||
|
|
||||||
|
install:
|
||||||
|
$(INSTALL_SHARED_LIB)
|
||||||
|
|
||||||
|
include $(SPDK_ROOT_DIR)/mk/spdk.subdirs.mk
|
Loading…
Reference in New Issue
Block a user