1# SPDX-License-Identifier: BSD-3-Clause 2# Copyright (C) 2017 Intel Corporation. 3# All rights reserved. 4# Copyright (c) 2021 NVIDIA CORPORATION & AFFILIATES. All rights reserved. 5# 6 7SPDK_ROOT_DIR := $(abspath $(CURDIR)/..) 8include $(SPDK_ROOT_DIR)/mk/spdk.common.mk 9 10.PHONY: all clean install uninstall 11 12DPDK_OPTS = -Denable_docs=false 13DPDK_OPTS += -Dtests=false 14 15ifeq ($(shell uname -m),aarch64) 16ifeq ($(shell uname -p),unknown) 17# Unknown ARM platform. ARM doesn't do platform=native which is DPDK's default. So change it. 18DPDK_OPTS += -Dplatform=generic 19else 20ifeq ($(shell $(SPDK_ROOT_DIR)/dpdk/config/arm/armv8_machine.py | cut -d' ' -f4),0x0) 21DPDK_OPTS += -Dplatform=generic 22endif 23endif 24endif 25 26DPDK_KMODS = false 27ifeq ($(OS),FreeBSD) 28DPDK_KMODS = true 29endif 30DPDK_OPTS += -Denable_kmods=$(DPDK_KMODS) 31 32ifeq ($(CONFIG_DEBUG),y) 33DPDK_OPTS += --buildtype=debug 34endif 35 36ifeq ($(CONFIG_SHARED),y) 37DPDK_OPTS += --default-library=shared 38else 39DPDK_OPTS += --default-library=static 40endif 41 42ifeq ($(CONFIG_LTO),y) 43# dpdk complains about compiler not supporting fat LTO objects when clang is in use so don't enable it in such a instance 44ifneq ($(CC_TYPE),clang) 45DPDK_OPTS += -Db_lto=true 46endif 47endif 48 49ifeq ($(CONFIG_PGO_CAPTURE),y) 50DPDK_OPTS += -Db_pgo=generate 51endif 52 53ifeq ($(CONFIG_PGO_USE),y) 54DPDK_OPTS += -Db_pgo=use 55endif 56 57ifneq ($(CONFIG_PGO_DIR),) 58DPDK_CFLAGS += -fprofile-dir=$(CONFIG_PGO_DIR) 59DPDK_LDFLAGS += -fprofile-dir=$(CONFIG_PGO_DIR) 60endif 61 62# the drivers we use 63DPDK_DRIVERS = bus bus/pci bus/vdev mempool/ring 64 65# Core DPDK libs 66DPDK_LIBS = eal ring mempool pci 67DPDK_LIBS += log kvargs telemetry 68# Governor required libs 69DPDK_LIBS += power timer ethdev net 70 71# common crypto/compress drivers 72ifeq ($(findstring y,$(CONFIG_DPDK_COMPRESSDEV)$(CONFIG_CRYPTO)$(CONFIG_VBDEV_COMPRESS)),y) 73DPDK_DRIVERS += crypto/qat compress/qat common/qat 74endif 75 76# common mlx5 libs 77ifeq ($(findstring y,$(CONFIG_CRYPTO_MLX5)$(CONFIG_VBDEV_COMPRESS_MLX5)),y) 78DPDK_DRIVERS += common/mlx5 bus/auxiliary 79endif 80 81# uadk drivers 82ifeq ($(findstring y,$(CONFIG_DPDK_UADK)),y) 83DPDK_DRIVERS += crypto/uadk 84endif 85ifeq ($(CONFIG_CRYPTO),y) 86DPDK_DRIVERS += crypto 87# aesni_mb is name of the PMD in DPDK 21.08 and earlier 88DPDK_DRIVERS += crypto/aesni_mb 89ifeq ($(CONFIG_CRYPTO_MLX5),y) 90DPDK_DRIVERS += crypto/mlx5 91endif 92ifeq ($(CONFIG_IPSEC_MB),y) 93DPDK_DRIVERS += crypto/ipsec_mb 94DPDK_CFLAGS += -I$(IPSEC_MB_DIR) 95# Workaround for DPDK 22.07 and DPDK 22.11.1, 96# will be able to remove starting with DPDK 23.03. 97ifeq ($(shell grep "define NO_COMPAT_IMB_API_053" $(SPDK_ROOT_DIR)/dpdk/drivers/crypto/qat/qat_sym_session.c), ) 98DPDK_CFLAGS += -DNO_COMPAT_IMB_API_053 99endif 100DPDK_LDFLAGS += -L$(IPSEC_MB_DIR) 101endif 102endif 103 104ifeq ($(findstring y,$(CONFIG_DPDK_COMPRESSDEV)$(CONFIG_VBDEV_COMPRESS)),y) 105DPDK_DRIVERS += compress compress/isal 106ifeq ($(CONFIG_VBDEV_COMPRESS_MLX5),y) 107DPDK_DRIVERS += compress/mlx5 108endif 109DPDK_CFLAGS += -I$(ISAL_DIR) -I$(ISAL_BUILD_DIR) 110DPDK_LDFLAGS += -L$(ISAL_DIR)/.libs -lisal 111endif 112 113DPDK_ENABLED_DRIVERS = $(shell echo $(DPDK_DRIVERS) | sed -E "s/ +/,/g") 114 115# crypto & compress deps 116DPDK_LIBS += reorder cryptodev 117DPDK_LIBS += compressdev 118DPDK_LIBS += security 119 120# vhost and deps 121DPDK_LIBS += cryptodev mbuf cmdline meter hash vhost dmadev 122 123# raid5 deps 124DPDK_LIBS += hash rcu 125 126DPDK_OPTS += -Dcpu_instruction_set=$(TARGET_ARCHITECTURE) 127 128ifneq ($(CONFIG_CROSS_PREFIX),) 129ifeq ($(findstring mingw,$(CONFIG_CROSS_PREFIX)),mingw) 130DPDK_OPTS += --cross-file $(SPDK_ROOT_DIR)/dpdk/config/x86/cross-mingw 131else 132$(error Automatic DPDK cross build is not supported. Please compile DPDK manually \ 133with e.g. `meson build --cross-file config/arm/arm64_armv8_linux_gcc`) 134endif 135endif 136 137# DPDK supports ASAN since version 21.11 138ifeq ($(CONFIG_ASAN),y) 139ifneq ($(OS),Windows) 140DPDK_OPTS += -Db_sanitize=address 141ifeq ($(CC_TYPE),clang) 142DPDK_OPTS += -Db_lundef=false 143endif 144endif 145endif 146 147DPDK_CFLAGS += -fPIC 148 149ifneq ($(CONFIG_MAX_LCORES),) 150DPDK_OPTS += -Dmax_lcores=$(CONFIG_MAX_LCORES) 151endif 152 153ifeq ($(CONFIG_WERROR),y) 154DPDK_CFLAGS += -Werror 155else 156DPDK_CFLAGS += -Wno-error 157endif 158 159ifeq ($(CONFIG_CET),y) 160DPDK_CFLAGS += -fcf-protection 161DPDK_LDFLAGS += -fcf-protection 162endif 163 164ifdef EXTRA_DPDK_CFLAGS 165$(warning EXTRA_DPDK_CFLAGS defined, possibly to work around an unsupported compiler version) 166$(shell sleep 1) 167endif 168 169# Allow users to specify EXTRA_DPDK_CFLAGS if they want to build DPDK using unsupported compiler versions 170DPDK_CFLAGS += $(EXTRA_DPDK_CFLAGS) 171 172# Force-disable scan-build 173SUB_CC = $(patsubst %ccc-analyzer,$(DEFAULT_CC),$(CC)) 174 175DPDK_ALL_LIB_DIRS = $(shell find $(SPDK_ROOT_DIR)/dpdk/lib -mindepth 1 -maxdepth 1 -type d) 176DPDK_ALL_LIBS = $(DPDK_ALL_LIB_DIRS:$(SPDK_ROOT_DIR)/dpdk/lib/%=%) 177DPDK_DISABLED_LIBS = $(shell echo $(filter-out $(DPDK_LIBS),$(DPDK_ALL_LIBS)) | sed -E "s/ +/,/g") 178 179ifeq ($(shell grep -q disable_apps $(SPDK_ROOT_DIR)/dpdk/meson_options.txt && echo 1), 1) 180DPDK_ALL_APP_DIRS = $(shell find $(SPDK_ROOT_DIR)/dpdk/app -mindepth 1 -maxdepth 1 -type d) 181DPDK_ALL_APPS = $(DPDK_ALL_APP_DIRS:$(SPDK_ROOT_DIR)/dpdk/app/%=%) 182DPDK_DISABLED_APPS = -Ddisable_apps="$(shell echo $(DPDK_ALL_APPS) | sed -E "s/ +/,/g")" 183endif 184 185ifneq ($(OS),FreeBSD) 186SED_INPLACE_FLAG = "-i" 187MESON_PREFIX = $(SPDK_ROOT_DIR)/dpdk/build 188else 189SED_INPLACE_FLAG = "-i ''" 190MESON_PREFIX = "/" 191endif 192 193# Some ninja versions come with a (broken?) jobserver which defaults to use 194# only 1 thread for the build. We workaround this by specifying -j to ninja 195# with the same value as top-makefile. This is OK as long as DPDK is not built 196# in parallel with anything else, which is the case for now. 197ifeq ($(MAKE_PID),) 198MAKE_PID := $(shell echo $$PPID) 199endif 200 201MAKE_NUMJOBS := $(shell ps T | sed -nE 's/[[:space:]]*$(MAKE_PID)[[:space:]].* (-j|--jobs=)( *[0-9]+).*/\1\2/p') 202 203all: $(SPDK_ROOT_DIR)/dpdk/build-tmp 204 $(Q)# DPDK doesn't handle nested make calls, so unset MAKEFLAGS 205 $(Q)env -u MAKEFLAGS meson compile -C $(SPDK_ROOT_DIR)/dpdk/build-tmp $(MAKE_NUMJOBS) 206 $(Q) \ 207 # Meson on FreeBSD sometimes appends --prefix value to the default DESTDIR (which is e.g. \ 208 # /usr/local) instead of replacing it. --prefix needs to be an absolute path, so we set \ 209 # it to / and then set DESTDIR directly, so libs and headers are copied to "DESTDIR//". \ 210 # DPDK kernel modules are set to install in $DESTDIR/boot/modules, but we move them \ 211 # to DESTDIR/kmod to be consistent with the makefile build. \ 212 # \ 213 # Also use meson install --only-changed instead of ninja install so that the shared \ 214 # libraries don't get reinstalled when they haven't been rebuilt - this avoids all of \ 215 # our applications getting relinked even when nothing has changed. 216 $(Q)if [ "$(OS)" = "FreeBSD" ]; then \ 217 env -u MAKEFLAGS DESTDIR=$(SPDK_ROOT_DIR)/dpdk/build ninja -C $(SPDK_ROOT_DIR)/dpdk/build-tmp $(MAKE_NUMJOBS) install > /dev/null && \ 218 mv $(SPDK_ROOT_DIR)/dpdk/build/boot/modules $(SPDK_ROOT_DIR)/dpdk/build/kmod; \ 219 else \ 220 env -u MAKEFLAGS meson install -C $(SPDK_ROOT_DIR)/dpdk/build-tmp --only-changed > /dev/null; \ 221 fi 222 223$(SPDK_ROOT_DIR)/dpdk/build-tmp: $(SPDK_ROOT_DIR)/mk/cc.mk $(SPDK_ROOT_DIR)/include/spdk/config.h 224 $(Q)rm -rf $(SPDK_ROOT_DIR)/dpdk/build $(SPDK_ROOT_DIR)/dpdk/build-tmp 225 $(Q)cd "$(SPDK_ROOT_DIR)/dpdk"; CC="$(SUB_CC)" meson setup --prefix="$(MESON_PREFIX)" --libdir lib -Dc_args="$(DPDK_CFLAGS)" -Dc_link_args="$(DPDK_LDFLAGS)" $(DPDK_OPTS) -Denable_drivers="$(DPDK_ENABLED_DRIVERS)" -Ddisable_libs="$(DPDK_DISABLED_LIBS)" $(DPDK_DISABLED_APPS) $(DPDKBUILD_FLAGS) build-tmp 226 $(Q)sed $(SED_INPLACE_FLAG) 's/#define RTE_EAL_PMD_PATH .*/#define RTE_EAL_PMD_PATH ""/g' $(SPDK_ROOT_DIR)/dpdk/build-tmp/rte_build_config.h 227 228clean: 229 $(Q)rm -rf $(SPDK_ROOT_DIR)/dpdk/build $(SPDK_ROOT_DIR)/dpdk/build-tmp 230 231install: 232 $(Q)cd "$(SPDK_ROOT_DIR)/dpdk"; CC="$(SUB_CC)" meson setup --prefix="$(CONFIG_PREFIX)" --reconfigure build-tmp 233 $(Q)env -u MAKEFLAGS meson install -C $(SPDK_ROOT_DIR)/dpdk/build-tmp --no-rebuild 234 $(Q)cd "$(SPDK_ROOT_DIR)/dpdk"; CC="$(SUB_CC)" meson setup --prefix="$(MESON_PREFIX)" --reconfigure build-tmp 235 236 237# meson has no uninstall target. We'll just do our best. 238uninstall: 239 $(Q)rm -rf $(DESTDIR)$(CONFIG_PREFIX)/share/dpdk 240 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/bin/dpdk-*.py 241 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/rte_*.h 242 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/generic/rte_*.h 243 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/lib/librte_* 244 $(Q)rm -rf $(DESTDIR)$(CONFIG_PREFIX)/lib/dpdk 245 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/lib/pkgconfig/libdpdk* 246 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_parse_portlist.h 247 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_cirbuf.h 248 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_socket.h 249 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_vt100.h 250 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_rdline.h 251 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_parse_string.h 252 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_parse_etheraddr.h 253 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_parse_ipaddr.h 254 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_parse_num.h 255 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline_parse.h 256 $(Q)rm -f $(DESTDIR)$(CONFIG_PREFIX)/include/cmdline.h 257