Rebase DPDK to 21.11

Drop RHEL7 support

RHEL7 stopped at DPDK 18.11.
No need to maintain it anymore.

Changed conflict statement to only apply to RHEL8 (since RHEL9 never had
dpdk-18.11).
Removed build dependency on python3-devel.

Signed-off-by: David Marchand <david.marchand@redhat.com>

Don't require kernel headers

We don't build any kmod, this dependency can be dropped.

Signed-off-by: David Marchand <david.marchand@redhat.com>

Rebase DPDK to 21.11

DPDK 21.11 requires python3-pyelftools to build which is in EPEL8, and
in RHEL9.

The machine option has been replaced with platform/cpu_instruction_set
to accomodate with custom ARM targets. The 'generic' platform is
a special configuration for the common minimal baseline of one
architecture.

Remove workaround on vxlan python script.

Signed-off-by: David Marchand <david.marchand@redhat.com>

Use new configuration options

21.11 comes with new options to select drivers and unselect optional
libraries.
Make use of them and add a check to ensure we do embed the right parts.

Signed-off-by: David Marchand <david.marchand@redhat.com>

Delete unwanted files

Resolves: #2030616
This commit is contained in:
David Marchand 2021-11-18 10:08:32 +01:00 committed by Timothy Redaelli
parent cb5923422f
commit 9658f2cce8
2 changed files with 80 additions and 30 deletions

108
dpdk.spec
View File

@ -8,14 +8,11 @@
#% define date 20191128 #% define date 20191128
#% define shortcommit0 %(c=%{commit0}; echo ${c:0:7}) #% define shortcommit0 %(c=%{commit0}; echo ${c:0:7})
%define ver 20.11.1 %define ver 21.11
%define rel 1 %define rel 1
%define srcname dpdk %define srcname dpdk
%define ninjaver 1.8.2
%define mesonver 0.49.2
Name: dpdk Name: dpdk
Version: %{ver} Version: %{ver}
Release: %{rel}%{?commit0:.%{date}git%{shortcommit0}}%{?dist} Release: %{rel}%{?commit0:.%{date}git%{shortcommit0}}%{?dist}
@ -26,8 +23,6 @@ Source: http://dpdk.org/browse/dpdk/snapshot/dpdk-%{commit0}.tar.xz
Source: http://fast.dpdk.org/rel/dpdk-%{ver}.tar.xz Source: http://fast.dpdk.org/rel/dpdk-%{ver}.tar.xz
%endif %endif
BuildRequires: meson
# Only needed for creating snapshot tarballs, not used in build itself # Only needed for creating snapshot tarballs, not used in build itself
Source100: dpdk-snapshot.sh Source100: dpdk-snapshot.sh
@ -54,19 +49,21 @@ ExclusiveArch: x86_64 aarch64 ppc64le
%define incdir %{_includedir}/%{name} %define incdir %{_includedir}/%{name}
%define pmddir %{_libdir}/%{name}-pmds %define pmddir %{_libdir}/%{name}-pmds
%define venvdir %{_builddir}/venv %if 0%{?rhel} && 0%{?rhel} < 9
# Fix conflicts with README and MAINTAINERS (included in dpdk-doc < 18.11-2),
%define _py python3 # this affects only RHEL8.
%define _py_exec %{?__python3}
%if 0%{?rhel} == 8
# Fix conflicts with README and MAINTAINERS (included in dpdk-doc < 18.11-2)
Conflicts: dpdk-doc < 18.11-2 Conflicts: dpdk-doc < 18.11-2
%endif %endif
BuildRequires: gcc, kernel-headers, zlib-devel, numactl-devel BuildRequires: meson
BuildRequires: doxygen, %{_py}-devel, %{_py}-sphinx %if 0%{?rhel} && 0%{?rhel} < 9
BuildRequires: python3-devel %define pyelftoolsver 0.27
Source1: https://github.com/eliben/pyelftools/archive/refs/tags/v%{pyelftoolsver}.tar.gz
%else
BuildRequires: python3-pyelftools
%endif
BuildRequires: gcc, zlib-devel, numactl-devel
BuildRequires: doxygen, python3-sphinx
%ifarch x86_64 %ifarch x86_64
BuildRequires: rdma-core-devel >= 15 BuildRequires: rdma-core-devel >= 15
%endif %endif
@ -97,7 +94,7 @@ API programming documentation for the Data Plane Development Kit.
%package tools %package tools
Summary: Tools for setting up Data Plane Development Kit environment Summary: Tools for setting up Data Plane Development Kit environment
Requires: %{name} = %{version}-%{release} Requires: %{name} = %{version}-%{release}
Requires: kmod pciutils findutils iproute %{_py_exec} Requires: kmod pciutils findutils iproute python3
%description tools %description tools
%{summary} %{summary}
@ -114,9 +111,18 @@ as L2 and L3 forwarding.
%endif %endif
%prep %prep
%autosetup -n %{srcname}-stable-%{?commit0:%{commit0}}%{!?commit0:%{ver}} -p1 %if 0%{?rhel} && 0%{?rhel} < 9
%setup -q -a 1 -n %{srcname}-%{?commit0:%{commit0}}%{!?commit0:%{ver}}
%else
%setup -q -n %{srcname}-%{?commit0:%{commit0}}%{!?commit0:%{ver}}
%endif
%autopatch -p1
%build %build
%if 0%{?rhel} && 0%{?rhel} < 9
export PYTHONPATH=$(pwd)/pyelftools-%{pyelftoolsver}
%endif
ENABLED_DRIVERS=( ENABLED_DRIVERS=(
bus/pci bus/pci
bus/vdev bus/vdev
@ -131,6 +137,7 @@ ENABLED_DRIVERS=(
%ifarch x86_64 %ifarch x86_64
ENABLED_DRIVERS+=( ENABLED_DRIVERS+=(
bus/auxiliary
bus/vmbus bus/vmbus
common/iavf common/iavf
common/mlx5 common/mlx5
@ -154,35 +161,75 @@ ENABLED_DRIVERS+=(
) )
%endif %endif
# Since upstream doesn't have a way for driver in ${ENABLED_DRIVERS[@]}; do
for driver in drivers/*/*/; do enable_drivers="${enable_drivers:+$enable_drivers,}"$driver
driver=${driver#drivers/} done
driver=${driver%/}
[[ " ${ENABLED_DRIVERS[@]} " == *" $driver "* ]] || \ # As of 21.11-rc3, following libraries can be disabled:
disable_drivers="${disable_drivers:+$disable_drivers,}"$driver # optional_libs = [
# 'bitratestats',
# 'gpudev',
# 'gro',
# 'gso',
# 'kni',
# 'jobstats',
# 'latencystats',
# 'metrics',
# 'pdump',
# 'power',
# 'vhost',
# ]
# If doing any updates, this must be aligned with:
# https://access.redhat.com/articles/3538141
DISABLED_LIBS=(
gpudev
kni
jobstats
power
)
for lib in "${DISABLED_LIBS[@]}"; do
disable_libs="${disable_libs:+$disable_libs,}"$lib
done done
%meson --includedir=include/dpdk \ %meson --includedir=include/dpdk \
--default-library=shared \ --default-library=shared \
-Ddisable_drivers="$disable_drivers" \ -Ddisable_libs="$disable_libs" \
-Ddrivers_install_subdir=dpdk-pmds \ -Ddrivers_install_subdir=dpdk-pmds \
-Denable_docs=true \ -Denable_docs=true \
-Dmachine=default \ -Denable_drivers="$enable_drivers" \
-Dplatform=generic \
-Dmax_ethports=32 \ -Dmax_ethports=32 \
-Dmax_numa_nodes=8 \ -Dmax_numa_nodes=8 \
-Dtests=false -Dtests=false
# Check drivers and libraries
for driver in "${ENABLED_DRIVERS[@]}"; do
config_token=RTE_$(echo $driver | tr [a-z/] [A-Z_])
! grep -q $config_token */rte_build_config.h || continue
echo "!!! Could not find $driver in rte_build_config.h, please check dependencies. !!!"
false
done
for lib in "${DISABLED_LIBS[@]}"; do
config_token=RTE_LIB_$(echo $lib | tr [a-z/] [A-Z_])
grep -q $config_token */rte_build_config.h || continue
echo "!!! Found $lib in rte_build_config.h. !!!"
false
done
%meson_build %meson_build
%install %install
%meson_install %meson_install
# FIXME this file doesn't have chmod +x upstream rm -f %{buildroot}%{_bindir}/dpdk-dumpcap
chmod +x %{buildroot}%{sdkdir}/examples/pipeline/examples/vxlan_table.py
rm -f %{buildroot}%{_bindir}/dpdk-pdump rm -f %{buildroot}%{_bindir}/dpdk-pdump
rm -f %{buildroot}%{_bindir}/dpdk-proc-info rm -f %{buildroot}%{_bindir}/dpdk-proc-info
rm -f %{buildroot}%{_bindir}/dpdk-test{,-acl,-bbdev,-cmdline,-compress-perf,-crypto-perf,-eventdev,-pipeline,-sad,-fib,-flow-perf,-regex} rm -f %{buildroot}%{_bindir}/dpdk-test{,-acl,-bbdev,-cmdline,-compress-perf,-crypto-perf,-eventdev,-pipeline,-sad,-fib,-flow-perf,-regex}
rm -f %{buildroot}%{_libdir}/*.a rm -f %{buildroot}%{_libdir}/*.a
# Taked from debian/rules
rm -f %{docdir}/html/.buildinfo
rm -f %{docdir}/html/objects.inv
rm -rf %{docdir}/html/.doctrees
%files %files
# BSD # BSD
@ -224,6 +271,9 @@ rm -f %{buildroot}%{_libdir}/*.a
%endif %endif
%changelog %changelog
* Tue Nov 23 2021 David Marchand <david.marchand@redhat.com> - 21.11-1
- Rebase to 21.11 (#2030616)
* Fri Nov 19 2021 Timothy Redaelli <tredaelli@redhat.com> - 20.11.1-1 * Fri Nov 19 2021 Timothy Redaelli <tredaelli@redhat.com> - 20.11.1-1
- Rebase to 20.11.1 (#2024994) - Rebase to 20.11.1 (#2024994)

View File

@ -1 +1 @@
SHA512 (dpdk-20.11.1.tar.xz) = 8eda369ab880b1071d313530a09a3f7ac8c449811fc9151c58524264e3ea9868d35b21b9481fb22daa6068db7de285109d822387f845100d73cdbd18c7527c69 SHA512 (dpdk-21.11.tar.xz) = 843282023c2f77a9b8af393d50c6dde54f09d490cd6f4a99f03d4df5df13a7d963aa86885fdf64e13f9da71e01c881d1f301dd093574a32cddd84f4b1fb58fd5