%global pkg wireguard %global kernel_version_min 4.18.0-315.el8 # To pick a specific kernel use `--define "kernel_version 4.18.0-315.el8"` # Otherwise the later version of %%{kernel_version_min} and the 'latest' # installed version of kernel-devel will be used. %global kernel_version_latest %({ echo %{kernel_version_min}; rpm --query kernel-devel --queryformat '%%{VERSION}-%%{RELEASE}\\\n' | grep -v kernel-devel; } | sort -V | sed -e '0,/^%{kernel_version_min}$/d' | tail -n 1) %if "%{kernel_version_latest}" != "" %{!?kernel_version:%{expand:%%global kernel_version %{kernel_version_latest}}} %endif %global _use_internal_dependency_generator 0 %global debug_package %{nil} %global __spec_install_post \ %{?__debug_package:%{__debug_install_post}} \ %{__arch_install_post} \ %{__os_install_post} \ %{__mod_compress_install_post} %global __mod_compress_install_post find %{buildroot}/lib/modules -type f -name \*.ko -exec xz \{\} \\; Name: kmod-%{pkg} Version: 1.0.20210606 Release: 1%{?dist} Summary: Fast, modern, secure VPN tunnel License: GPLv2 URL: https://www.wireguard.com/ Source0: https://git.zx2c4.com/%{pkg}-linux-compat/snapshot/%{pkg}-linux-compat-%{version}.tar.xz Patch1: 0001-compat-account-for-latest-c8s-backports.patch ExclusiveArch: x86_64 aarch64 BuildRequires: elfutils-libelf-devel BuildRequires: gcc BuildRequires: kernel-abi-whitelists BuildRequires: kernel-rpm-macros BuildRequires: kmod BuildRequires: make BuildRequires: redhat-rpm-config BuildRequires: xz %{!?kernel_version: BuildRequires: kernel-devel >= %{kernel_version_min} } %{?kernel_version: BuildRequires: kernel-devel = %{kernel_version} Supplements: kernel = %{kernel_version} Requires: (kernel = %{kernel_version} if kernel) Provides: kernel-modules = %{kernel_version}.%{_arch} } Requires(post): /usr/sbin/depmod Requires(postun): /usr/sbin/depmod Provides: %{name} = %{?epoch:%{epoch}:}%{version}-%{release} Supplements: wireguard-tools Recommends: wireguard-tools %description WireGuard is an extremely simple yet fast and modern VPN that utilizes state-of-the-art cryptography. It aims to be faster, simpler, leaner, and more useful than IPsec, while avoiding the massive headache. It intends to be considerably more performant than OpenVPN. WireGuard is designed as a general purpose VPN for running on embedded interfaces and super computers alike, fit for many different circumstances. %prep %autosetup -p1 -n %{pkg}-linux-compat-%{version} %build pushd src %{__make} -C /usr/src/kernels/%{kernel_version}.%{_arch} %{?_smp_mflags} M=$PWD modules popd %install %{__install} -D -t %{buildroot}/lib/modules/%{kernel_version}.%{_arch}/extra/drivers/net/%{pkg} src/%{pkg}.ko # Make .ko objects temporarily executable for automatic stripping find %{buildroot}/lib/modules -type f -name \*.ko -exec chmod u+x \{\} \+ %clean %{__rm} -rf %{buildroot} %post /usr/sbin/depmod -aeF /lib/modules/%{kernel_version}.%{_arch}/System.map %{kernel_version}.%{_arch} %postun /usr/sbin/depmod -aeF /lib/modules/%{kernel_version}.%{_arch}/System.map %{kernel_version}.%{_arch} %files %defattr(644,root,root,755) /lib/modules/%{kernel_version}.%{_arch} %license COPYING %doc README.md %changelog * Wed Jul 21 2021 Peter Georg - 1.0.20210606-1 - Initial version