2019-06-25 11:12:58 +00:00
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
2018-05-15 09:49:22 +00:00
|
|
|
# Copyright 2012 6WIND S.A.
|
2019-06-25 11:12:58 +00:00
|
|
|
# Copyright 2012 Mellanox Technologies, Ltd
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
include $(RTE_SDK)/mk/rte.vars.mk
|
|
|
|
|
|
|
|
# Library name.
|
|
|
|
LIB = librte_pmd_mlx4.a
|
2019-06-25 11:12:58 +00:00
|
|
|
LIB_GLUE = $(LIB_GLUE_BASE).$(LIB_GLUE_VERSION)
|
|
|
|
LIB_GLUE_BASE = librte_pmd_mlx4_glue.so
|
|
|
|
LIB_GLUE_VERSION = 18.02.0
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
# Sources.
|
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4.c
|
2018-05-15 09:49:22 +00:00
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_ethdev.c
|
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_flow.c
|
2020-06-18 16:55:50 +00:00
|
|
|
ifneq ($(CONFIG_RTE_IBVERBS_LINK_DLOPEN),y)
|
2019-06-25 11:12:58 +00:00
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_glue.c
|
|
|
|
endif
|
2018-05-15 09:49:22 +00:00
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_intr.c
|
2020-06-18 16:55:50 +00:00
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_mp.c
|
2018-05-15 09:49:22 +00:00
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_mr.c
|
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_rxq.c
|
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_rxtx.c
|
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_txq.c
|
|
|
|
SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD) += mlx4_utils.c
|
2017-04-21 10:43:26 +00:00
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
ifeq ($(CONFIG_RTE_IBVERBS_LINK_DLOPEN),y)
|
2019-06-25 11:12:58 +00:00
|
|
|
INSTALL-$(CONFIG_RTE_LIBRTE_MLX4_PMD)-lib += $(LIB_GLUE)
|
|
|
|
endif
|
|
|
|
|
2017-04-21 10:43:26 +00:00
|
|
|
# Basic CFLAGS.
|
|
|
|
CFLAGS += -O3
|
2018-05-15 09:49:22 +00:00
|
|
|
CFLAGS += -std=c11 -Wall -Wextra
|
2017-04-21 10:43:26 +00:00
|
|
|
CFLAGS += -g
|
|
|
|
CFLAGS += -I.
|
|
|
|
CFLAGS += -D_BSD_SOURCE
|
|
|
|
CFLAGS += -D_DEFAULT_SOURCE
|
|
|
|
CFLAGS += -D_XOPEN_SOURCE=600
|
|
|
|
CFLAGS += $(WERROR_FLAGS)
|
2019-06-25 11:12:58 +00:00
|
|
|
CFLAGS += -DALLOW_EXPERIMENTAL_API
|
2020-06-18 16:55:50 +00:00
|
|
|
ifeq ($(CONFIG_RTE_IBVERBS_LINK_DLOPEN),y)
|
2019-06-25 11:12:58 +00:00
|
|
|
CFLAGS += -DMLX4_GLUE='"$(LIB_GLUE)"'
|
|
|
|
CFLAGS += -DMLX4_GLUE_VERSION='"$(LIB_GLUE_VERSION)"'
|
|
|
|
CFLAGS_mlx4_glue.o += -fPIC
|
|
|
|
LDLIBS += -ldl
|
2020-06-18 16:55:50 +00:00
|
|
|
else ifeq ($(CONFIG_RTE_IBVERBS_LINK_STATIC),y)
|
|
|
|
LDLIBS += $(shell $(RTE_SDK)/buildtools/options-ibverbs-static.sh)
|
2019-06-25 11:12:58 +00:00
|
|
|
else
|
2018-05-15 09:49:22 +00:00
|
|
|
LDLIBS += -libverbs -lmlx4
|
2019-06-25 11:12:58 +00:00
|
|
|
endif
|
2018-05-15 09:49:22 +00:00
|
|
|
LDLIBS += -lrte_eal -lrte_mbuf -lrte_mempool -lrte_ring
|
|
|
|
LDLIBS += -lrte_ethdev -lrte_net -lrte_kvargs
|
|
|
|
LDLIBS += -lrte_bus_pci
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
# A few warnings cannot be avoided in external headers.
|
|
|
|
CFLAGS += -Wno-error=cast-qual
|
|
|
|
|
|
|
|
EXPORT_MAP := rte_pmd_mlx4_version.map
|
|
|
|
# DEBUG which is usually provided on the command-line may enable
|
|
|
|
# CONFIG_RTE_LIBRTE_MLX4_DEBUG.
|
|
|
|
ifeq ($(DEBUG),1)
|
|
|
|
CONFIG_RTE_LIBRTE_MLX4_DEBUG := y
|
|
|
|
endif
|
|
|
|
|
|
|
|
# User-defined CFLAGS.
|
|
|
|
ifeq ($(CONFIG_RTE_LIBRTE_MLX4_DEBUG),y)
|
2020-06-18 16:55:50 +00:00
|
|
|
CFLAGS += -pedantic -UNDEBUG
|
|
|
|
ifneq ($(CONFIG_RTE_TOOLCHAIN_ICC),y)
|
|
|
|
CFLAGS += -DPEDANTIC
|
|
|
|
endif
|
|
|
|
AUTO_CONFIG_CFLAGS += -Wno-pedantic
|
2017-04-21 10:43:26 +00:00
|
|
|
else
|
|
|
|
CFLAGS += -DNDEBUG -UPEDANTIC
|
|
|
|
endif
|
|
|
|
|
|
|
|
include $(RTE_SDK)/mk/rte.lib.mk
|
|
|
|
|
|
|
|
# Generate and clean-up mlx4_autoconf.h.
|
|
|
|
|
|
|
|
export CC CFLAGS CPPFLAGS EXTRA_CFLAGS EXTRA_CPPFLAGS
|
2020-06-18 16:55:50 +00:00
|
|
|
export AUTO_CONFIG_CFLAGS += -Wno-error
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
ifndef V
|
|
|
|
AUTOCONF_OUTPUT := >/dev/null
|
|
|
|
endif
|
|
|
|
|
|
|
|
mlx4_autoconf.h.new: FORCE
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
mlx4_autoconf.h.new: $(RTE_SDK)/buildtools/auto-config-h.sh
|
2017-04-21 10:43:26 +00:00
|
|
|
$Q $(RM) -f -- '$@'
|
2018-05-15 09:49:22 +00:00
|
|
|
$Q : > '$@'
|
2020-06-18 16:55:50 +00:00
|
|
|
$Q sh -- '$<' '$@' \
|
|
|
|
HAVE_IBV_MLX4_BUF_ALLOCATORS \
|
|
|
|
infiniband/mlx4dv.h \
|
|
|
|
enum MLX4DV_SET_CTX_ATTR_BUF_ALLOCATORS \
|
|
|
|
$(AUTOCONF_OUTPUT)
|
|
|
|
$Q sh -- '$<' '$@' \
|
|
|
|
HAVE_IBV_MLX4_UAR_MMAP_OFFSET \
|
|
|
|
infiniband/mlx4dv.h \
|
|
|
|
enum MLX4DV_QP_MASK_UAR_MMAP_OFFSET \
|
|
|
|
$(AUTOCONF_OUTPUT)
|
2019-06-25 11:12:58 +00:00
|
|
|
$Q sh -- '$<' '$@' \
|
|
|
|
HAVE_IBV_MLX4_WQE_LSO_SEG \
|
|
|
|
infiniband/mlx4dv.h \
|
|
|
|
type 'struct mlx4_wqe_lso_seg' \
|
|
|
|
$(AUTOCONF_OUTPUT)
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
# Create mlx4_autoconf.h or update it in case it differs from the new one.
|
|
|
|
|
|
|
|
mlx4_autoconf.h: mlx4_autoconf.h.new
|
|
|
|
$Q [ -f '$@' ] && \
|
|
|
|
cmp '$<' '$@' $(AUTOCONF_OUTPUT) || \
|
|
|
|
mv '$<' '$@'
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
$(SRCS-$(CONFIG_RTE_LIBRTE_MLX4_PMD):.c=.o): mlx4_autoconf.h
|
2017-04-21 10:43:26 +00:00
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
# Generate dependency plug-in for rdma-core when the PMD must not be linked
|
|
|
|
# directly, so that applications do not inherit this dependency.
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
ifeq ($(CONFIG_RTE_IBVERBS_LINK_DLOPEN),y)
|
2019-06-25 11:12:58 +00:00
|
|
|
|
|
|
|
$(LIB): $(LIB_GLUE)
|
|
|
|
|
|
|
|
ifeq ($(LINK_USING_CC),1)
|
|
|
|
GLUE_LDFLAGS := $(call linkerprefix,$(LDFLAGS))
|
|
|
|
else
|
|
|
|
GLUE_LDFLAGS := $(LDFLAGS)
|
|
|
|
endif
|
|
|
|
$(LIB_GLUE): mlx4_glue.o
|
|
|
|
$Q $(LD) $(GLUE_LDFLAGS) $(EXTRA_LDFLAGS) \
|
|
|
|
-Wl,-h,$(LIB_GLUE) \
|
|
|
|
-shared -o $@ $< -libverbs -lmlx4
|
|
|
|
|
|
|
|
mlx4_glue.o: mlx4_autoconf.h
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
2017-04-21 10:43:26 +00:00
|
|
|
clean_mlx4: FORCE
|
|
|
|
$Q rm -f -- mlx4_autoconf.h mlx4_autoconf.h.new
|
2019-06-25 11:12:58 +00:00
|
|
|
$Q rm -f -- mlx4_glue.o $(LIB_GLUE_BASE)*
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
clean: clean_mlx4
|