1 # SPDX-License-Identifier: BSD-3-Clause
2 # Copyright 2015 6WIND S.A.
3 # Copyright 2015 Mellanox Technologies, Ltd
5 include $(RTE_SDK)/mk/rte.vars.mk
8 LIB = librte_pmd_mlx5.a
9 LIB_GLUE = $(LIB_GLUE_BASE).$(LIB_GLUE_VERSION)
10 LIB_GLUE_BASE = librte_pmd_mlx5_glue.so
11 LIB_GLUE_VERSION = 18.05.0
14 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5.c
15 ifneq ($(CONFIG_RTE_LIBRTE_MLX5_DLOPEN_DEPS),y)
16 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_glue.c
18 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_rxq.c
19 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_txq.c
20 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_rxtx.c
21 ifneq ($(filter y,$(CONFIG_RTE_ARCH_X86_64) \
22 $(CONFIG_RTE_ARCH_ARM64)),)
23 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_rxtx_vec.c
25 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_trigger.c
26 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_ethdev.c
27 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_mac.c
28 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_rxmode.c
29 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_vlan.c
30 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_stats.c
31 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_rss.c
32 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_mr.c
33 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_flow.c
34 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_socket.c
35 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_nl.c
36 SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD) += mlx5_nl_flow.c
38 ifeq ($(CONFIG_RTE_LIBRTE_MLX5_DLOPEN_DEPS),y)
39 INSTALL-$(CONFIG_RTE_LIBRTE_MLX5_PMD)-lib += $(LIB_GLUE)
44 CFLAGS += -std=c11 -Wall -Wextra
47 CFLAGS += -D_BSD_SOURCE
48 CFLAGS += -D_DEFAULT_SOURCE
49 CFLAGS += -D_XOPEN_SOURCE=600
50 CFLAGS += $(WERROR_FLAGS)
51 CFLAGS += -Wno-strict-prototypes
52 ifeq ($(CONFIG_RTE_LIBRTE_MLX5_DLOPEN_DEPS),y)
53 CFLAGS += -DMLX5_GLUE='"$(LIB_GLUE)"'
54 CFLAGS += -DMLX5_GLUE_VERSION='"$(LIB_GLUE_VERSION)"'
55 CFLAGS_mlx5_glue.o += -fPIC
58 LDLIBS += -libverbs -lmlx5
61 LDLIBS += -lrte_eal -lrte_mbuf -lrte_mempool -lrte_ring
62 LDLIBS += -lrte_ethdev -lrte_net -lrte_kvargs
63 LDLIBS += -lrte_bus_pci
65 # A few warnings cannot be avoided in external headers.
66 CFLAGS += -Wno-error=cast-qual
68 EXPORT_MAP := rte_pmd_mlx5_version.map
71 # memseg walk is not part of stable API
72 CFLAGS += -DALLOW_EXPERIMENTAL_API
74 # DEBUG which is usually provided on the command-line may enable
75 # CONFIG_RTE_LIBRTE_MLX5_DEBUG.
77 CONFIG_RTE_LIBRTE_MLX5_DEBUG := y
80 # User-defined CFLAGS.
81 ifeq ($(CONFIG_RTE_LIBRTE_MLX5_DEBUG),y)
82 CFLAGS += -pedantic -UNDEBUG -DPEDANTIC
84 CFLAGS += -DNDEBUG -UPEDANTIC
87 include $(RTE_SDK)/mk/rte.lib.mk
89 # Generate and clean-up mlx5_autoconf.h.
91 export CC CFLAGS CPPFLAGS EXTRA_CFLAGS EXTRA_CPPFLAGS
92 export AUTO_CONFIG_CFLAGS = -Wno-error
95 AUTOCONF_OUTPUT := >/dev/null
98 mlx5_autoconf.h.new: FORCE
100 mlx5_autoconf.h.new: $(RTE_SDK)/buildtools/auto-config-h.sh
103 HAVE_IBV_DEVICE_STRIDING_RQ_SUPPORT \
104 infiniband/mlx5dv.h \
105 enum MLX5DV_CQE_RES_FORMAT_CSUM_STRIDX \
108 HAVE_IBV_DEVICE_TUNNEL_SUPPORT \
109 infiniband/mlx5dv.h \
110 enum MLX5DV_CONTEXT_MASK_TUNNEL_OFFLOADS \
113 HAVE_IBV_DEVICE_MPLS_SUPPORT \
115 enum IBV_FLOW_SPEC_MPLS \
118 HAVE_IBV_WQ_FLAG_RX_END_PADDING \
120 enum IBV_WQ_FLAG_RX_END_PADDING \
123 HAVE_IBV_MLX5_MOD_SWP \
124 infiniband/mlx5dv.h \
125 type 'struct mlx5dv_sw_parsing_caps' \
128 HAVE_IBV_MLX5_MOD_MPW \
129 infiniband/mlx5dv.h \
130 enum MLX5DV_CONTEXT_FLAGS_MPW_ALLOWED \
133 HAVE_IBV_MLX5_MOD_CQE_128B_COMP \
134 infiniband/mlx5dv.h \
135 enum MLX5DV_CONTEXT_FLAGS_CQE_128B_COMP \
138 HAVE_ETHTOOL_LINK_MODE_25G \
139 /usr/include/linux/ethtool.h \
140 enum ETHTOOL_LINK_MODE_25000baseCR_Full_BIT \
143 HAVE_ETHTOOL_LINK_MODE_50G \
144 /usr/include/linux/ethtool.h \
145 enum ETHTOOL_LINK_MODE_50000baseCR2_Full_BIT \
148 HAVE_ETHTOOL_LINK_MODE_100G \
149 /usr/include/linux/ethtool.h \
150 enum ETHTOOL_LINK_MODE_100000baseKR4_Full_BIT \
153 HAVE_IBV_DEVICE_COUNTERS_SET_SUPPORT \
155 type 'struct ibv_counter_set_init_attr' \
159 rdma/rdma_netlink.h \
163 HAVE_RDMA_NLDEV_CMD_GET \
164 rdma/rdma_netlink.h \
165 enum RDMA_NLDEV_CMD_GET \
168 HAVE_RDMA_NLDEV_CMD_PORT_GET \
169 rdma/rdma_netlink.h \
170 enum RDMA_NLDEV_CMD_PORT_GET \
173 HAVE_RDMA_NLDEV_ATTR_DEV_INDEX \
174 rdma/rdma_netlink.h \
175 enum RDMA_NLDEV_ATTR_DEV_INDEX \
178 HAVE_RDMA_NLDEV_ATTR_DEV_NAME \
179 rdma/rdma_netlink.h \
180 enum RDMA_NLDEV_ATTR_DEV_NAME \
183 HAVE_RDMA_NLDEV_ATTR_PORT_INDEX \
184 rdma/rdma_netlink.h \
185 enum RDMA_NLDEV_ATTR_PORT_INDEX \
188 HAVE_RDMA_NLDEV_ATTR_NDEV_INDEX \
189 rdma/rdma_netlink.h \
190 enum RDMA_NLDEV_ATTR_NDEV_INDEX \
193 HAVE_IFLA_PHYS_SWITCH_ID \
195 enum IFLA_PHYS_SWITCH_ID \
198 HAVE_IFLA_PHYS_PORT_NAME \
200 enum IFLA_PHYS_PORT_NAME \
203 HAVE_TCA_FLOWER_ACT \
205 enum TCA_FLOWER_ACT \
208 HAVE_TCA_FLOWER_FLAGS \
210 enum TCA_FLOWER_FLAGS \
213 HAVE_TCA_FLOWER_KEY_ETH_TYPE \
215 enum TCA_FLOWER_KEY_ETH_TYPE \
218 HAVE_TCA_FLOWER_KEY_ETH_DST \
220 enum TCA_FLOWER_KEY_ETH_DST \
223 HAVE_TCA_FLOWER_KEY_ETH_DST_MASK \
225 enum TCA_FLOWER_KEY_ETH_DST_MASK \
228 HAVE_TCA_FLOWER_KEY_ETH_SRC \
230 enum TCA_FLOWER_KEY_ETH_SRC \
233 HAVE_TCA_FLOWER_KEY_ETH_SRC_MASK \
235 enum TCA_FLOWER_KEY_ETH_SRC_MASK \
238 HAVE_TCA_FLOWER_KEY_IP_PROTO \
240 enum TCA_FLOWER_KEY_IP_PROTO \
243 HAVE_TCA_FLOWER_KEY_IPV4_SRC \
245 enum TCA_FLOWER_KEY_IPV4_SRC \
248 HAVE_TCA_FLOWER_KEY_IPV4_SRC_MASK \
250 enum TCA_FLOWER_KEY_IPV4_SRC_MASK \
253 HAVE_TCA_FLOWER_KEY_IPV4_DST \
255 enum TCA_FLOWER_KEY_IPV4_DST \
258 HAVE_TCA_FLOWER_KEY_IPV4_DST_MASK \
260 enum TCA_FLOWER_KEY_IPV4_DST_MASK \
263 HAVE_TCA_FLOWER_KEY_IPV6_SRC \
265 enum TCA_FLOWER_KEY_IPV6_SRC \
268 HAVE_TCA_FLOWER_KEY_IPV6_SRC_MASK \
270 enum TCA_FLOWER_KEY_IPV6_SRC_MASK \
273 HAVE_TCA_FLOWER_KEY_IPV6_DST \
275 enum TCA_FLOWER_KEY_IPV6_DST \
278 HAVE_TCA_FLOWER_KEY_IPV6_DST_MASK \
280 enum TCA_FLOWER_KEY_IPV6_DST_MASK \
283 HAVE_TCA_FLOWER_KEY_TCP_SRC \
285 enum TCA_FLOWER_KEY_TCP_SRC \
288 HAVE_TCA_FLOWER_KEY_TCP_SRC_MASK \
290 enum TCA_FLOWER_KEY_TCP_SRC_MASK \
293 HAVE_TCA_FLOWER_KEY_TCP_DST \
295 enum TCA_FLOWER_KEY_TCP_DST \
298 HAVE_TCA_FLOWER_KEY_TCP_DST_MASK \
300 enum TCA_FLOWER_KEY_TCP_DST_MASK \
303 HAVE_TCA_FLOWER_KEY_UDP_SRC \
305 enum TCA_FLOWER_KEY_UDP_SRC \
308 HAVE_TCA_FLOWER_KEY_UDP_SRC_MASK \
310 enum TCA_FLOWER_KEY_UDP_SRC_MASK \
313 HAVE_TCA_FLOWER_KEY_UDP_DST \
315 enum TCA_FLOWER_KEY_UDP_DST \
318 HAVE_TCA_FLOWER_KEY_UDP_DST_MASK \
320 enum TCA_FLOWER_KEY_UDP_DST_MASK \
323 HAVE_TCA_FLOWER_KEY_VLAN_ID \
325 enum TCA_FLOWER_KEY_VLAN_ID \
328 HAVE_TCA_FLOWER_KEY_VLAN_PRIO \
330 enum TCA_FLOWER_KEY_VLAN_PRIO \
333 HAVE_TCA_FLOWER_KEY_VLAN_ETH_TYPE \
335 enum TCA_FLOWER_KEY_VLAN_ETH_TYPE \
339 linux/tc_act/tc_vlan.h \
340 enum TCA_VLAN_PUSH_VLAN_PRIORITY \
343 HAVE_SUPPORTED_40000baseKR4_Full \
344 /usr/include/linux/ethtool.h \
345 define SUPPORTED_40000baseKR4_Full \
348 HAVE_SUPPORTED_40000baseCR4_Full \
349 /usr/include/linux/ethtool.h \
350 define SUPPORTED_40000baseCR4_Full \
353 HAVE_SUPPORTED_40000baseSR4_Full \
354 /usr/include/linux/ethtool.h \
355 define SUPPORTED_40000baseSR4_Full \
358 HAVE_SUPPORTED_40000baseLR4_Full \
359 /usr/include/linux/ethtool.h \
360 define SUPPORTED_40000baseLR4_Full \
363 HAVE_SUPPORTED_56000baseKR4_Full \
364 /usr/include/linux/ethtool.h \
365 define SUPPORTED_56000baseKR4_Full \
368 HAVE_SUPPORTED_56000baseCR4_Full \
369 /usr/include/linux/ethtool.h \
370 define SUPPORTED_56000baseCR4_Full \
373 HAVE_SUPPORTED_56000baseSR4_Full \
374 /usr/include/linux/ethtool.h \
375 define SUPPORTED_56000baseSR4_Full \
378 HAVE_SUPPORTED_56000baseLR4_Full \
379 /usr/include/linux/ethtool.h \
380 define SUPPORTED_56000baseLR4_Full \
384 /usr/include/assert.h \
385 define static_assert \
388 # Create mlx5_autoconf.h or update it in case it differs from the new one.
390 mlx5_autoconf.h: mlx5_autoconf.h.new
392 cmp '$<' '$@' $(AUTOCONF_OUTPUT) || \
395 $(SRCS-$(CONFIG_RTE_LIBRTE_MLX5_PMD):.c=.o): mlx5_autoconf.h
397 # Generate dependency plug-in for rdma-core when the PMD must not be linked
398 # directly, so that applications do not inherit this dependency.
400 ifeq ($(CONFIG_RTE_LIBRTE_MLX5_DLOPEN_DEPS),y)
404 ifeq ($(LINK_USING_CC),1)
405 GLUE_LDFLAGS := $(call linkerprefix,$(LDFLAGS))
407 GLUE_LDFLAGS := $(LDFLAGS)
409 $(LIB_GLUE): mlx5_glue.o
410 $Q $(LD) $(GLUE_LDFLAGS) $(EXTRA_LDFLAGS) \
412 -shared -o $@ $< -libverbs -lmlx5
414 mlx5_glue.o: mlx5_autoconf.h
419 $Q rm -f -- mlx5_autoconf.h mlx5_autoconf.h.new
420 $Q rm -f -- mlx5_glue.o $(LIB_GLUE_BASE)*