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:
parent
cb5923422f
commit
9658f2cce8
108
dpdk.spec
108
dpdk.spec
@ -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)
|
||||||
|
|
||||||
|
2
sources
2
sources
@ -1 +1 @@
|
|||||||
SHA512 (dpdk-20.11.1.tar.xz) = 8eda369ab880b1071d313530a09a3f7ac8c449811fc9151c58524264e3ea9868d35b21b9481fb22daa6068db7de285109d822387f845100d73cdbd18c7527c69
|
SHA512 (dpdk-21.11.tar.xz) = 843282023c2f77a9b8af393d50c6dde54f09d490cd6f4a99f03d4df5df13a7d963aa86885fdf64e13f9da71e01c881d1f301dd093574a32cddd84f4b1fb58fd5
|
||||||
|
Loading…
Reference in New Issue
Block a user