diff options
Diffstat (limited to '')
-rw-r--r-- | src/spdk/mk/spdk.modules.mk | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/src/spdk/mk/spdk.modules.mk b/src/spdk/mk/spdk.modules.mk new file mode 100644 index 00000000..77bcca0a --- /dev/null +++ b/src/spdk/mk/spdk.modules.mk @@ -0,0 +1,115 @@ +# +# 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. +# + +LVOL_MODULES_LIST = vbdev_lvol +# Modules below are added as dependency for vbdev_lvol +LVOL_MODULES_LIST += blob blob_bdev lvol + +BLOCKDEV_MODULES_LIST = $(LVOL_MODULES_LIST) +BLOCKDEV_MODULES_LIST += bdev_malloc bdev_null bdev_nvme nvme vbdev_passthru vbdev_error vbdev_gpt vbdev_split +BLOCKDEV_MODULES_LIST += vbdev_raid + +ifeq ($(CONFIG_CRYPTO),y) +BLOCKDEV_MODULES_LIST += vbdev_crypto +endif + +ifeq ($(CONFIG_RDMA),y) +BLOCKDEV_MODULES_DEPS += -libverbs -lrdmacm +endif + +ifeq ($(OS),Linux) +BLOCKDEV_MODULES_LIST += bdev_aio +BLOCKDEV_MODULES_DEPS += -laio +ifeq ($(CONFIG_VIRTIO),y) +BLOCKDEV_MODULES_LIST += bdev_virtio virtio +endif +ifeq ($(CONFIG_ISCSI_INITIATOR),y) +BLOCKDEV_MODULES_LIST += bdev_iscsi +# Fedora installs libiscsi to /usr/lib64/iscsi for some reason. +BLOCKDEV_MODULES_DEPS += -L/usr/lib64/iscsi -liscsi +endif +endif + +ifeq ($(CONFIG_RBD),y) +BLOCKDEV_MODULES_LIST += bdev_rbd +BLOCKDEV_MODULES_DEPS += -lrados -lrbd +endif + +ifeq ($(CONFIG_PMDK),y) +BLOCKDEV_MODULES_LIST += bdev_pmem +BLOCKDEV_MODULES_DEPS += -lpmemblk +endif + +SOCK_MODULES_LIST = sock +SOCK_MODULES_LIST += sock_posix + +ifeq ($(CONFIG_VPP),y) +ifneq ($(CONFIG_VPP_DIR),) +SOCK_MODULES_DEPS = -l:libvppinfra.a -l:libsvm.a -l:libvapiclient.a +SOCK_MODULES_DEPS += -l:libvppcom.a -l:libvlibmemoryclient.a +else +SOCK_MODULES_DEPS = -lvppcom +endif +SOCK_MODULES_LIST += sock_vpp +endif + +COPY_MODULES_LIST = copy_ioat ioat + +BLOCKDEV_MODULES_LINKER_ARGS = -Wl,--whole-archive \ + $(BLOCKDEV_MODULES_LIST:%=-lspdk_%) \ + -Wl,--no-whole-archive \ + $(BLOCKDEV_MODULES_DEPS) + +BLOCKDEV_MODULES_FILES = $(call spdk_lib_list_to_static_libs,$(BLOCKDEV_MODULES_LIST)) + +BLOCKDEV_NO_LVOL_MODULES_LIST = $(filter-out $(LVOL_MODULES_LIST),$(BLOCKDEV_MODULES_LIST)) +BLOCKDEV_NO_LVOL_MODULES_LINKER_ARGS = -Wl,--whole-archive \ + $(BLOCKDEV_NO_LVOL_MODULES_LIST:%=-lspdk_%) \ + -Wl,--no-whole-archive \ + $(BLOCKDEV_MODULES_DEPS) + +BLOCKDEV_NO_LVOL_MODULES_FILES = $(call spdk_lib_list_to_static_libs,$(BLOCKDEV_NO_LVOL_MODULES_LIST)) + +COPY_MODULES_LINKER_ARGS = -Wl,--whole-archive \ + $(COPY_MODULES_LIST:%=-lspdk_%) \ + -Wl,--no-whole-archive \ + $(COPY_MODULES_DEPS) + +COPY_MODULES_FILES = $(call spdk_lib_list_to_static_libs,$(COPY_MODULES_LIST)) + +SOCK_MODULES_LINKER_ARGS = -Wl,--whole-archive \ + $(SOCK_MODULES_LIST:%=-lspdk_%) \ + $(SOCK_MODULES_DEPS) \ + -Wl,--no-whole-archive + +SOCK_MODULES_FILES = $(call spdk_lib_list_to_static_libs,$(SOCK_MODULES_LIST)) |