# Copyright 1999-2026 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI=8 # This revision is fundamentally different from pf-sources-6.19_p5{,-r1}. # Instead of fetching pf-kernel/codeberg's GA-only sourcetree (Linux 6.19.0 # + pf patchset, no linux-stable updates), it builds on top of the same # vanilla 6.19.tar.xz + Gentoo genpatches stack that gentoo-sources-6.19.X # uses, then applies a *curated* subset of natalenko's pf-kernel delta # on top. See pkg_postinst for what's preserved versus what's dropped # and why. The slot's pretend version stays "6.19_p5" so this ebuild # remains drop-in-replaceable for users on the existing pf-sources slot. ETYPE="sources" # Track the latest 6.19.X linux-stable via genpatches. K=11 carries # 1001..1011 = stable 6.19.2 through 6.19.12. K=12 and K=13 were # briefly published by alicef and then withdrawn — they only survive # in our Manifest as orphan hashes; the original -r70 was authored # against K=13 (stable 6.19.14). Pinning to K=11 is a real regression # of two linux-stable point releases, but it's the only K still # fetchable. Bump back up if alicef catches up. verified 2026-05-10. K_GENPATCHES_VER="11" # Curated pf delta sets EXTRAVERSION via the patch itself. K_NOSETEXTRAVERSION="1" # pf-sources has historically carried K_SECURITY_UNSUPPORTED. Even with # linux-stable now baked in (which closes the largest gap), we keep the # flag because the curated pf delta is not covered by Gentoo's security # team — bugs in the pf-specific portions (BBRv3, x86 ISA levels, TEO # cpuidle governor, ovpn data-channel offload, zstd bump, v4l2loopback, # DDCCI) need to be reported to natalenko or the overlay maintainers. K_SECURITY_UNSUPPORTED="1" K_WANT_GENPATCHES="base extras" # Map "6.19_p5" → "6.19" for the kernel.org tarball + genpatches. SHPV="${PV/_p*/}" # Pretend version visible in /lib/modules and /usr/src. PFPV="${PV/_p/-pf}" inherit kernel-2 optfeature DESCRIPTION="Linux kernel: gentoo-sources base + curated pf-kernel patchset" HOMEPAGE="https://pfkernel.natalenko.name/ https://dev.gentoo.org/~alicef/genpatches/" # Vanilla 6.19 from kernel.org + Gentoo's genpatches (stable + non-stable) # + our curated pf delta. The codeberg pf-kernel tarball is intentionally # not fetched — its content is replaced by the much smaller curated # patch in files/. SRC_URI="https://www.kernel.org/pub/linux/kernel/v6.x/linux-${SHPV}.tar.xz https://dev.gentoo.org/~alicef/dist/genpatches/genpatches-${SHPV}-${K_GENPATCHES_VER}.base.tar.xz https://dev.gentoo.org/~alicef/dist/genpatches/genpatches-${SHPV}-${K_GENPATCHES_VER}.extras.tar.xz https://raw.githubusercontent.com/istitov/extra-stuff/pf-curated-${SHPV}-r70-0/sys-kernel/pf-sources/pf-curated-${SHPV}.tar.xz -> pf-curated-${SHPV}-r70-0.tar.xz" S="${WORKDIR}/linux-${SHPV}" KEYWORDS="~amd64 ~x86" K_EXTRAEINFO="For more info on pf-sources and details on how to report problems, see: ${HOMEPAGE}." pkg_setup() { ewarn "" ewarn "${PN} is *not* supported by the Gentoo Kernel Project in any way." ewarn "If you need support, please contact the pf developers directly." ewarn "Do *not* open bugs in Gentoo's bugzilla unless you have issues with" ewarn "the ebuilds. Thank you." ewarn "" kernel-2_pkg_setup } src_unpack() { # Vanilla kernel.org tarball unpacks to linux-${SHPV} directly; no # rename needed. unpack ${A} } src_prepare() { # Apply genpatches stack. Unlike pf-sources -r1, we DO NOT delete # `1*linux*.patch` — the linux-stable backport chain # (1000_linux-${SHPV}.1.patch through 1NNN_linux-${SHPV}.X.patch) # is the entire point of this revision. eapply "${WORKDIR}"/*.patch # Curated pf-kernel delta on top of gentoo-sources state. # See pkg_postinst for the kept/dropped breakdown. eapply "${WORKDIR}/pf-curated-${SHPV}"/*.patch default } pkg_postinst() { # Fixes "wrongly" detected directory name, bgo#862534. local KV_FULL="${PFPV}" kernel-2_pkg_postinst elog "" elog "This revision (-r70) is the gentoo-sources-based pf-sources variant." elog "It tracks linux-stable (6.19.X) via Gentoo's genpatches AND keeps a" elog "curated subset of natalenko's pf-kernel delta on top. CVE backports" elog "now arrive automatically with each gentoo-sources stable bump." elog "" elog "6.19 is the youngest active branch; pf hasn't had time to accumulate" elog "many 'minor fixes' that overlap with stable, so the curated subset" elog "is small (34 files / ~4k lines) and applies with normal-fuzz only" elog "on a fresh gentoo-sources-6.19.X tree." elog "" elog "Curated pf features RETAINED from natalenko's patchset:" elog " * BBRv3 TCP congestion control (net/ipv4/tcp_bbr* and helpers)" elog " * x86 ISA levels (arch/x86/Kconfig.cpu + arch/x86/Makefile)" elog " * TEO cpuidle governor + haltpoll + governor helpers" elog " * zstd compression library updates" elog " * v4l2loopback driver" elog " * ovpn (OpenVPN data-channel offload) updates" elog " * Subset of fs/smb/client/ tweaks (cifsencrypt, smb2transport)" elog "" elog "Patches DROPPED from natalenko's patchset, with reasons:" elog " * kernel/futex/pi.c: comment + cosmetic differences;" elog " functional path is the same in stable's newer form." elog " * kernel/sched/{core,sched.h}: gentoo-sources has newer scheduler" elog " helpers. Keeping pf's older form would regress, not improve," elog " scheduler behaviour." elog " * Most 'minor fixes' pf carries are now in linux-stable's 6.19.X" elog " backports already (often in newer/better form)." elog "" elog "If you specifically need pf-kernel's full scheduler tuning or" elog "futex2 extensions, install pf-sources-6.19_p5-r1 instead — it" elog "stays GA-frozen and ships natalenko's patchset verbatim, at the" elog "cost of missing linux-stable security fixes." elog "" optfeature "userspace KSM helper" sys-process/uksmd } pkg_postrm() { # Same here, bgo#862534. local KV_FULL="${PFPV}" kernel-2_pkg_postrm }