Spdk/lib/nvmf/Makefile

55 lines
1.3 KiB
Makefile
Raw Permalink Normal View History

# SPDX-License-Identifier: BSD-3-Clause
# Copyright (C) 2015 Intel Corporation.
# All rights reserved.
#
SPDK_ROOT_DIR := $(abspath $(CURDIR)/../..)
include $(SPDK_ROOT_DIR)/mk/spdk.common.mk
so_ver: increase all major versions To allow SO_MINOR updates on LTS for the whole year it is supported, the major version for all components needs to be increased. This is to prevent scenario where two versions exists with matching versions, but conflicting ABI. Ex. Next SPDK release adds an API call increasing the minor version, then LTS needs just a subset of those additions. Increasing major so version after LTS, allows the future releases to update versions as needed. Yet allowing LTS to increase minor version separately. Disabled test for increasing SO version without ABI change, as that is goal of this patch. This check shall be removed with SPDK 23.05 release. Looks like this was left over from prior LTS, to avoid that make sure it is only skipped when running against v23.01.x as latest release. This patch: - increases SO_VER by 1 for all components - resets SO_MINOR to 0 for all components - removes suppressions for ABI tests Short reference to how the versions were changed: MAX=$(git grep "SO_VER := " | cut -d" " -f 3 | sort -ubnr | head -1) for((i=$MAX;i>0;i-=1)); do find . -name "Makefile" -exec \ sed -i -e "s/SO_VER := $i\$/SO_VER := $(($i+1))/g" {} +; done find . -name "Makefile" -exec \ sed -i -e "s/SO_MINOR := .*/SO_MINOR := 0/g" {} + Change-Id: I3e5681802c0a5ac6d7d652a18896997cd07cc8bf Signed-off-by: Tomasz Zawadzki <tomasz.zawadzki@intel.com> Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/16419 Reviewed-by: Ben Walker <benjamin.walker@intel.com> Reviewed-by: Konrad Sztyber <konrad.sztyber@intel.com> Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
2023-01-23 17:24:28 +00:00
SO_VER := 15
SO_MINOR := 0
C_SRCS = ctrlr.c ctrlr_discovery.c ctrlr_bdev.c \
subsystem.c nvmf.c nvmf_rpc.c transport.c tcp.c
C_SRCS-$(CONFIG_RDMA) += rdma.c
LIBNAME = nvmf
LOCAL_SYS_LIBS =
ifeq ($(CONFIG_RDMA),y)
LOCAL_SYS_LIBS += -libverbs -lrdmacm
#Attach only if FreeBSD and RDMA is specified with configure
ifeq ($(OS),FreeBSD)
# Mellanox - MLX4 HBA Userspace Library
ifneq ("$(wildcard /usr/lib/libmlx4.*)","")
LOCAL_SYS_LIBS += -lmlx4
endif
# Mellanox - MLX5 HBA Userspace Library
ifneq ("$(wildcard /usr/lib/libmlx5.*)","")
LOCAL_SYS_LIBS += -lmlx5
endif
# Chelsio HBA Userspace Library
ifneq ("$(wildcard /usr/lib/libcxgb4.*)","")
LOCAL_SYS_LIBS += -lcxgb4
endif
endif
endif
NVMf: Add a custom(VFIOUSER) transport target support VFIO is a framework that allows a physical device to be securely passed through to a user space process. Typically, the user space process is a VM and the device is passed through to it in order to achieve high performance. VFIO provides an API and the required functionality in the kernel. vfio-user is a framework that allows implementing PCI devices in userspace. SPDK NVMf library provides the emulation of a NVMe device, combined with vfio-user protocol, we can provide the emulated NVMe device to VM or client application, such as SPDK NVMe perf. This patch has dependency on libvfio-user library, users can start NVMe identify/perf examples. Usage: 1. Start nvmf_target. 2. Use RPC to create a subsystem with namespace bdev. mkdir -p /var/run/muser mkdir -p /var/run/muser/iommu_group mkdir -p /var/run/muser/domain/muser0/8 mkdir -p /dev/shm/muser/muser0 scripts/rpc.py nvmf_create_transport -t VFIOUSER scripts/rpc.py nvmf_create_subsystem -a nqn.2019-07.io.spdk.muser:/var/run/muser/domain/muser0/8 scripts/rpc.py bdev_malloc_create -b muser0 $((512)) 512 scripts/rpc.py nvmf_subsystem_add_ns -n 1 nqn.2019-07.io.spdk.muser:/var/run/muser/domain/muser0/8 muser0 scripts/rpc.py nvmf_subsystem_add_listener -t VFIOUSER -a "/var/run/muser/domain/muser0/8" -s 0 nqn.2019-07.io.spdk.muser:/var/run/muser/domain/muser0/8 ln -s /var/run/muser/domain/muser0/8 /var/run/muser/domain/muser0/8/iommu_group ln -s /var/run/muser/domain/muser0/8 /var/run/muser/iommu_group/8 ln -s /var/run/muser/domain/muser0/8/bar0 /dev/shm/muser/muser0/bar0 Currently, file /var/run/muser/domain/muser0/8/ctrlr is the socket file which is used to transfer socket messages between target and client. [1] https://www.mail-archive.com/qemu-devel@nongnu.org/msg723794.html Co-authored-by: Ben Walker <benjamin.walker@intel.com> Co-authored-by: Changpeng Liu <changpeng.liu@intel.com> Co-authored-by: Thanos Makatos <thanos.makatos@nutanix.com> Signed-off-by: Thanos Makatos <thanos.makatos@nutanix.com> Signed-off-by: Jim Harris <james.r.harris@intel.com> Signed-off-by: Ben Walker <benjamin.walker@intel.com> Signed-off-by: Changpeng Liu <changpeng.liu@intel.com> Change-Id: I5f2a8e77314a6a13aa6366dd4a6dc77b13434e7b Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/3838 Community-CI: Broadcom CI Reviewed-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com> Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
2020-10-26 15:37:10 +00:00
ifeq ($(CONFIG_VFIO_USER), y)
C_SRCS += vfio_user.c
CFLAGS += -I$(VFIO_USER_INCLUDE_DIR)
LDFLAGS += -L$(VFIO_USER_LIBRARY_DIR)
LOCAL_SYS_LIBS += -lvfio-user -ljson-c
NVMf: Add a custom(VFIOUSER) transport target support VFIO is a framework that allows a physical device to be securely passed through to a user space process. Typically, the user space process is a VM and the device is passed through to it in order to achieve high performance. VFIO provides an API and the required functionality in the kernel. vfio-user is a framework that allows implementing PCI devices in userspace. SPDK NVMf library provides the emulation of a NVMe device, combined with vfio-user protocol, we can provide the emulated NVMe device to VM or client application, such as SPDK NVMe perf. This patch has dependency on libvfio-user library, users can start NVMe identify/perf examples. Usage: 1. Start nvmf_target. 2. Use RPC to create a subsystem with namespace bdev. mkdir -p /var/run/muser mkdir -p /var/run/muser/iommu_group mkdir -p /var/run/muser/domain/muser0/8 mkdir -p /dev/shm/muser/muser0 scripts/rpc.py nvmf_create_transport -t VFIOUSER scripts/rpc.py nvmf_create_subsystem -a nqn.2019-07.io.spdk.muser:/var/run/muser/domain/muser0/8 scripts/rpc.py bdev_malloc_create -b muser0 $((512)) 512 scripts/rpc.py nvmf_subsystem_add_ns -n 1 nqn.2019-07.io.spdk.muser:/var/run/muser/domain/muser0/8 muser0 scripts/rpc.py nvmf_subsystem_add_listener -t VFIOUSER -a "/var/run/muser/domain/muser0/8" -s 0 nqn.2019-07.io.spdk.muser:/var/run/muser/domain/muser0/8 ln -s /var/run/muser/domain/muser0/8 /var/run/muser/domain/muser0/8/iommu_group ln -s /var/run/muser/domain/muser0/8 /var/run/muser/iommu_group/8 ln -s /var/run/muser/domain/muser0/8/bar0 /dev/shm/muser/muser0/bar0 Currently, file /var/run/muser/domain/muser0/8/ctrlr is the socket file which is used to transfer socket messages between target and client. [1] https://www.mail-archive.com/qemu-devel@nongnu.org/msg723794.html Co-authored-by: Ben Walker <benjamin.walker@intel.com> Co-authored-by: Changpeng Liu <changpeng.liu@intel.com> Co-authored-by: Thanos Makatos <thanos.makatos@nutanix.com> Signed-off-by: Thanos Makatos <thanos.makatos@nutanix.com> Signed-off-by: Jim Harris <james.r.harris@intel.com> Signed-off-by: Ben Walker <benjamin.walker@intel.com> Signed-off-by: Changpeng Liu <changpeng.liu@intel.com> Change-Id: I5f2a8e77314a6a13aa6366dd4a6dc77b13434e7b Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/3838 Community-CI: Broadcom CI Reviewed-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com> Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
2020-10-26 15:37:10 +00:00
endif
ifeq ($(CONFIG_FC),y)
C_SRCS += fc.c fc_ls.c
CFLAGS += -I$(CURDIR) $(ENV_CFLAGS)
ifneq ($(strip $(CONFIG_FC_PATH)),)
CFLAGS += -I$(CONFIG_FC_PATH)
endif
endif
SPDK_MAP_FILE = $(abspath $(CURDIR)/spdk_nvmf.map)
include $(SPDK_ROOT_DIR)/mk/spdk.lib.mk