commit:     500f3a3fda403ac77f6b6ee830a03aee49a09fa1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 18 20:14:20 2026 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Jan 19 04:20:50 2026 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=500f3a3f

sys-kernel/gentoo-kernel-bin: Bump to 6.12.66

Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>

 sys-kernel/gentoo-kernel-bin/Manifest              |   5 +
 .../gentoo-kernel-bin-6.12.66.ebuild               | 236 +++++++++++++++++++++
 2 files changed, 241 insertions(+)

diff --git a/sys-kernel/gentoo-kernel-bin/Manifest 
b/sys-kernel/gentoo-kernel-bin/Manifest
index fb184d83c828..401963e34945 100644
--- a/sys-kernel/gentoo-kernel-bin/Manifest
+++ b/sys-kernel/gentoo-kernel-bin/Manifest
@@ -22,6 +22,10 @@ DIST gentoo-kernel-6.12.65-1.amd64.gpkg.tar 311705600 
BLAKE2B be27ce241d8b964ef9
 DIST gentoo-kernel-6.12.65-1.arm64.gpkg.tar 280535040 BLAKE2B 
1f813f6d9a3eea8b9e0a2014d6b6b55d7a68b824d7261578b3083fc3a9a0dab6edf1cae7142af41a790af510ab70e9a9d416c8f1679c6fe73719831fac72d500
 SHA512 
e6691e0d1a717bb16973ab8cfabf8ae9d7d8476ab08fec6ed7b33ccdcd8742d7732217a760e4a15e55461ac601040d3d7a8d5118750f76f2dda6f74342b4c6c4
 DIST gentoo-kernel-6.12.65-1.ppc64le.gpkg.tar 74199040 BLAKE2B 
6daccc0e089927ba8634ed344041710a72ad2498a085e54efcdb68900ead104c2dc8da1931ae2f3fc5239c77d9876411a5c4507f545ac50faf5355a960c84a20
 SHA512 
8c9f2ae2038708c3d5b931f0bed030a76d87cf13fba8f67761509bac6a246a1c82555873a7d1f0b13a8cc2badaf776d4c5634f1bbc8b2f64ad043d6f29dd5e73
 DIST gentoo-kernel-6.12.65-1.x86.gpkg.tar 77813760 BLAKE2B 
9ede249512870c3f5db94879e1617baf87a05cd98a8fabecf6a2839933568047d37efeebdfa64337ddfc0452a91c2bbe47504d487821bbc5f5974f9d85b80b2c
 SHA512 
30602b82b9a98c4e00a0e99d9f473ce8373edd89c97f8012c116231b59625e42476ece2493640bff24394eb08ef1c6a3637aa6b0f416afb8a86a12316ca65374
+DIST gentoo-kernel-6.12.66-1.amd64.gpkg.tar 311777280 BLAKE2B 
02c41e92649687bdad493a869996d0baf4a17f0185ccc92e75a873c7eeb52ec40d5178cabf1480f10787f381fe07ec4fde63278127b7ab427509d8cf32248e4b
 SHA512 
17c70c869528c87dcfc59810f24b071163cbafa2b263020a1eb7ab61a5cd57b50ae802adec53039833941f6f4af8f38897cbf68a552123d2c8d64aa7af4e5949
+DIST gentoo-kernel-6.12.66-1.arm64.gpkg.tar 280657920 BLAKE2B 
ab2897b563f811b46622011e0a3aa17db5852fc12da68f3823c5f115a194d47aa3bb01c95b7790e32e14ae0ffe5335b93661127ba114f02b357ab383165b7251
 SHA512 
8d9e46fbce60ef03bce3b7d16217ef3be924c3bebcc135aa14141fb7db223ba2ee2dbd78eab1317c8597179b0b3feb7617c89f5b9755595381fbb104102cac6c
+DIST gentoo-kernel-6.12.66-1.ppc64le.gpkg.tar 74188800 BLAKE2B 
96998aeaf032eef694ff4c900d4d3b587c98b68eba5426ba21f21384f6c4af5465981fc07c4fd41dca33626743c78942a47db605dcc8df67d5435521c5b6b51b
 SHA512 
89d5b3b113d3bfe2a9f8feae31b66b242c8c3f8a4c0ca27c83a50ac40d9ddc9e36c0eedee89112af09ea8d9e87fb2afe28c27473773675104aef39230b41c347
+DIST gentoo-kernel-6.12.66-1.x86.gpkg.tar 77824000 BLAKE2B 
4b9196a4bf469d1cd1d5554d643b4fc3ae89d96a06131abcd9f6a46df11325ca77d4eac0fcbeb563b9206a7f32d178d2fd22b6340eebd31e8ffd5a967bfc2250
 SHA512 
9ee8703acb8769aada1e538879e0c0a75c4162393fb9cfbc4c67f9b82ee95c507598b7ef23a444e2d8266f95ec14a5058736af9a84607a1d248d7704afd24d54
 DIST gentoo-kernel-6.18.4-1.amd64.gpkg.tar 458813440 BLAKE2B 
e5c841752e2cc3ff708f9c2dfd26c93e2fa5368bd44aa87bfbd8d771186486ffdd4f1098f2e6533f0cd3ebd5f671ef11028afa489da0525c9a0a09600d44ae95
 SHA512 
5cd49b70006048e4dd0f9c5b5ebbde81b42f0923644900c75187519e1d3493502452213ab4fa6b3c995ef6de606542cd0bec6e5352f48a73baa15b5761100b28
 DIST gentoo-kernel-6.18.4-1.arm64.gpkg.tar 434636800 BLAKE2B 
287766d58c7e363e7f81723f5fef2be1c46842025bea025d6902308e7aeeb91ebd4d104aa07a997407cb6066f4611c4b16b7e5c8f7c323f1aa857feababc9284
 SHA512 
1f95417870e651f01fe3defff4ec0bf67a08c6c7efe12902392c7cfa8f46b2438a718e684a5dfa68deea3a7c029767b21b2cc2211ba572a96d3770d898d83831
 DIST gentoo-kernel-6.18.4-1.ppc64le.gpkg.tar 77066240 BLAKE2B 
677033bcd5ae66177ca72b04a524f1436cc45e33583ba2adcdf196cbd078220c5b9fab0a6aed19bf9820933b15cc456e6e3bea67610391a898b5d925afcc6b21
 SHA512 
8259c7b94587cf80acd8de3788e64e35e946c734efd969f516fa65cfb734891764eef5ce0e65c82c923cdc17bf65940257ba3b16be7be320cc4c2f7580863f68
@@ -66,6 +70,7 @@ DIST patch-6.1.159.xz 6840392 BLAKE2B 
d5f15dc1fe5239b2d047ded7dc179ead7f1914900c
 DIST patch-6.12.63.xz 3592380 BLAKE2B 
fa3c4052b06ad8b2793401040cd93bed542f46e22534597c5371add84173fe11beda6a789a8523a800d9d8813a38ebf6eb2066968b4dc08a29b9741d3a6086d8
 SHA512 
cf7a06f423cdde52a1a81defccf3c8533c91126be1965a279949a5ff4b91c39aad0863bd2a1582c9ef7ffdf80ee1534838d4f554e6b58a9833780e79747a04f8
 DIST patch-6.12.64.xz 3723996 BLAKE2B 
79527e9990c84105254f3f515906809a3d2fb0094488cb4e1d734c5ca0541553d0d557dc68fda0399ee6dd20a7f515e90b8a1fbaaa5fbeadd82afaf5d6e3a4c7
 SHA512 
428b10d6c34d696ba9bdd2c4e359ffa5a5c56cee3b0d9790e231a0eb0a365272b54c0cdeec6ff31af6f3190adcd5cf69fbe2cbdb47de3b22e449e1fcd0cb480b
 DIST patch-6.12.65.xz 3728296 BLAKE2B 
eddc8ef3db5f267d11222eb19b95c6ee46bebd63abc7e107b10894c426ed3303537522738e1cdb14f6feeaa1c513fc415e57e35b247a7e361f6cba42242855fd
 SHA512 
668f8af255a429048875d23c0c859d763ee6998d5205bd4e1614dfa46dfb389c8fe14cb29a22fdb6989f289c477bd1d1afb28be77d4c7ba933f10a6b4332e609
+DIST patch-6.12.66.xz 3752552 BLAKE2B 
ed48dbfe0b583092e82f863702026e477809615f47bf4cab4cfb80bfebbed0dd938c92d2ab269267f5a7ae9a08ce984dbd2aa2ae56c48f0205b96fc3932c0bf9
 SHA512 
54230c57698f0d891742f70e6f8bb957c0b6d188ab8d5dc219b2a8b2ef9b8e0c7bcf51002a08f0f9c4b584f39378f0ac3f613c1a5a7562f8535d2fd05cfd71a4
 DIST patch-6.18.4.xz 412512 BLAKE2B 
2a78cd052874eb01d38b8857e7647ea3f5904f8ec030b4c90f6b56262ee1974ee76de4359cc1748b9f0e97c5a330f9ac6dd9e3ad8623b96150b3292cb870e33b
 SHA512 
3321241effb0567caacc08f67a1ea8d59d11aac69e6c001b6fbf566f894d70416e91e9ec605ae27909e2e5feac25d9a93bed7db1ede06700afc810cd8e34030d
 DIST patch-6.18.5.xz 414548 BLAKE2B 
50fe5af5616fb080d90111c9b10d7f24ffa40ea6bcd7a645250622ff4adf7923f09bd1a93c82947c6e56a77ea457eb5df14aa215f6c3cae036cc1f11cc20f3d0
 SHA512 
2c07af94135abbb1fc118be061c7b39e3b692783e67231954eabe1ccac8948a126084e651d5648aebd6d58667ac82ba41264057df1cc81fcaa161df5eee56395
 DIST patch-6.18.6.xz 465484 BLAKE2B 
b7df26c8e524eacf89dfd34c92d572a0b36e0f6c6bbe3183d3cb909ef156487557337bd1e3780ce383966d06a9d2f640cf6ee4fc64750ff9c592a46fea010993
 SHA512 
ffc4711d98b639f1b43fbaeebb8f5c088218b263b178b03494522d3ef21898595fb961bb4202284d40aa42b3a8a38e365e3b610dd9ce86d19e19d9068e54609c

diff --git a/sys-kernel/gentoo-kernel-bin/gentoo-kernel-bin-6.12.66.ebuild 
b/sys-kernel/gentoo-kernel-bin/gentoo-kernel-bin-6.12.66.ebuild
new file mode 100644
index 000000000000..d866cb039918
--- /dev/null
+++ b/sys-kernel/gentoo-kernel-bin/gentoo-kernel-bin-6.12.66.ebuild
@@ -0,0 +1,236 @@
+# Copyright 2020-2026 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+KERNEL_IUSE_GENERIC_UKI=1
+
+inherit kernel-install toolchain-funcs unpacker verify-sig
+
+BASE_P=linux-${PV%.*}
+PATCH_PV=${PV%_p*}
+PATCHSET=linux-gentoo-patches-6.12.62
+BINPKG=${P/-bin}-1
+SHA256SUM_DATE=20260118
+
+DESCRIPTION="Pre-built Linux kernel with Gentoo patches"
+HOMEPAGE="
+       https://wiki.gentoo.org/wiki/Project:Distribution_Kernel
+       https://www.kernel.org/
+"
+SRC_URI+="
+       https://cdn.kernel.org/pub/linux/kernel/v$(ver_cut 1).x/${BASE_P}.tar.xz
+       https://cdn.kernel.org/pub/linux/kernel/v$(ver_cut 
1).x/patch-${PATCH_PV}.xz
+       https://dev.gentoo.org/~mgorny/dist/linux/${PATCHSET}.tar.xz
+       verify-sig? (
+               https://cdn.kernel.org/pub/linux/kernel/v$(ver_cut 
1).x/sha256sums.asc
+                       -> linux-$(ver_cut 1).x-sha256sums-${SHA256SUM_DATE}.asc
+       )
+       amd64? (
+               
https://dev.gentoo.org/~mgorny/binpkg/amd64/kernel/sys-kernel/gentoo-kernel/${BINPKG}.gpkg.tar
+                       -> ${BINPKG}.amd64.gpkg.tar
+       )
+       arm64? (
+               
https://dev.gentoo.org/~mgorny/binpkg/arm64/kernel/sys-kernel/gentoo-kernel/${BINPKG}.gpkg.tar
+                       -> ${BINPKG}.arm64.gpkg.tar
+       )
+       ppc64? (
+               
https://dev.gentoo.org/~mgorny/binpkg/ppc64le/kernel/sys-kernel/gentoo-kernel/${BINPKG}.gpkg.tar
+                       -> ${BINPKG}.ppc64le.gpkg.tar
+       )
+       x86? (
+               
https://dev.gentoo.org/~mgorny/binpkg/x86/kernel/sys-kernel/gentoo-kernel/${BINPKG}.gpkg.tar
+                       -> ${BINPKG}.x86.gpkg.tar
+       )
+"
+S=${WORKDIR}
+
+KEYWORDS="~amd64 ~arm64 ~ppc64 ~x86"
+IUSE="debug"
+
+RDEPEND="
+       !sys-kernel/gentoo-kernel:${SLOT}
+"
+PDEPEND="
+       >=virtual/dist-kernel-${PV}
+"
+BDEPEND="
+       app-alternatives/bc
+       app-alternatives/lex
+       dev-util/pahole
+       virtual/libelf
+       app-alternatives/yacc
+       amd64? ( app-crypt/sbsigntools )
+       arm64? ( app-crypt/sbsigntools )
+       verify-sig? ( >=sec-keys/openpgp-keys-kernel-20250702 )
+"
+
+KV_LOCALVERSION='-gentoo-dist'
+KV_FULL=${PV/_p/-p}${KV_LOCALVERSION}
+
+QA_PREBUILT='*'
+
+VERIFY_SIG_OPENPGP_KEY_PATH=/usr/share/openpgp-keys/kernel.org.asc
+
+src_unpack() {
+       if use verify-sig; then
+               cd "${DISTDIR}" || die
+               verify-sig_verify_signed_checksums \
+                       "linux-$(ver_cut 1).x-sha256sums-${SHA256SUM_DATE}.asc" 
\
+                       sha256 "${BASE_P}.tar.xz patch-${PATCH_PV}.xz"
+               cd "${WORKDIR}" || die
+       fi
+
+       unpacker
+}
+
+src_prepare() {
+       local patch
+       cd "${BASE_P}" || die
+       eapply "${WORKDIR}/patch-${PATCH_PV}"
+       for patch in "${WORKDIR}/${PATCHSET}"/*.patch; do
+               eapply "${patch}"
+               # non-experimental patches always finish with Gentoo Kconfig
+               # we built -bins without them
+               if [[ ${patch} == *Add-Gentoo-Linux-support-config-settings* ]]
+               then
+                       break
+               fi
+       done
+
+       default
+
+       # add Gentoo patchset version
+       local extraversion=${PV#${PATCH_PV}}
+       sed -i -e "s:^\(EXTRAVERSION =\).*:\1 ${extraversion/_/-}:" Makefile || 
die
+}
+
+src_configure() {
+       # force ld.bfd if we can find it easily
+       local HOSTLD="$(tc-getBUILD_LD)"
+       if type -P "${HOSTLD}.bfd" &>/dev/null; then
+               HOSTLD+=.bfd
+       fi
+       local LD="$(tc-getLD)"
+       if type -P "${LD}.bfd" &>/dev/null; then
+               LD+=.bfd
+       fi
+       tc-export_build_env
+       local makeargs=(
+               V=1
+               WERROR=0
+
+               HOSTCC="$(tc-getBUILD_CC)"
+               HOSTCXX="$(tc-getBUILD_CXX)"
+               HOSTLD="${HOSTLD}"
+               HOSTAR="$(tc-getBUILD_AR)"
+               HOSTCFLAGS="${BUILD_CFLAGS}"
+               HOSTLDFLAGS="${BUILD_LDFLAGS}"
+
+               CROSS_COMPILE=${CHOST}-
+               AS="$(tc-getAS)"
+               CC="$(tc-getCC)"
+               LD="${LD}"
+               AR="$(tc-getAR)"
+               NM="$(tc-getNM)"
+               STRIP="$(tc-getSTRIP)"
+               OBJCOPY="$(tc-getOBJCOPY)"
+               OBJDUMP="$(tc-getOBJDUMP)"
+               READELF="$(tc-getREADELF)"
+
+               # we need to pass it to override colliding Gentoo envvar
+               ARCH="$(tc-arch-kernel)"
+
+               O="${WORKDIR}"/modprep
+       )
+
+       local kernel_dir="${BINPKG}/image/usr/src/linux-${KV_FULL}"
+
+       # If this is set it will have an effect on the name of the output
+       # image. Set this variable to track this setting.
+       if grep -q "CONFIG_EFI_ZBOOT=y" "${kernel_dir}/.config"; then
+               KERNEL_EFI_ZBOOT=1
+       elif use arm64 && use generic-uki; then
+               die "USE=generic-uki requires a CONFIG_EFI_ZBOOT enabled build"
+       fi
+
+       local image="${kernel_dir}/$(dist-kernel_get_image_path)"
+       local uki="${image%/*}/uki.efi"
+
+       # Override user variable with the cert used during build
+       openssl x509 \
+               -inform DER -in "${kernel_dir}/certs/signing_key.x509" \
+               -outform PEM -out "${T}/cert.pem" ||
+                       die "Failed to convert pcrpkey to PEM format"
+       export SECUREBOOT_SIGN_CERT=${T}/cert.pem
+
+       if [[ -s ${uki} ]]; then
+               # We need to extract the plain image for the test phase
+               # and USE=-generic-uki.
+               kernel-install_extract_from_uki linux "${uki}" "${image}"
+       fi
+
+       mkdir modprep || die
+       cp "${kernel_dir}/.config" modprep/ || die
+       emake -C "${BASE_P}" "${makeargs[@]}" modules_prepare
+}
+
+src_test() {
+       local kernel_dir="${BINPKG}/image/usr/src/linux-${KV_FULL}"
+       kernel-install_test "${KV_FULL}" \
+               "${WORKDIR}/${kernel_dir}/$(dist-kernel_get_image_path)" \
+               "${BINPKG}/image/lib/modules/${KV_FULL}"
+}
+
+src_install() {
+       local rel_kernel_dir=/usr/src/linux-${KV_FULL}
+       local kernel_dir="${BINPKG}/image${rel_kernel_dir}"
+       local image="${kernel_dir}/$(dist-kernel_get_image_path)"
+       local uki="${image%/*}/uki.efi"
+       if [[ -s ${uki} ]]; then
+               # Keep the kernel image type we don't want out of install tree
+               # Replace back with placeholder
+               if use generic-uki; then
+                       > "${image}" || die
+               else
+                       > "${uki}" || die
+               fi
+       fi
+
+       # Overwrite the identifier in the prebuilt package
+       echo "${CATEGORY}/${PF}:${SLOT}" > "${kernel_dir}/dist-kernel" || die
+
+       mv "${BINPKG}"/image/{lib,usr} "${ED}"/ || die
+
+       # FIXME: requires proper mount-boot
+       if [[ -d ${BINPKG}/image/boot/dtbs ]]; then
+               mv "${BINPKG}"/image/boot "${ED}"/ || die
+       fi
+
+       # strip out-of-source build stuffs from modprep
+       # and then copy built files
+       find modprep -type f '(' \
+                       -name Makefile -o \
+                       -name '*.[ao]' -o \
+                       '(' -name '.*' -a -not -name '.config' ')' \
+               ')' -delete || die
+       rm modprep/source || die
+       cp -p -R modprep/. "${ED}${rel_kernel_dir}"/ || die
+
+       # Update timestamps on all modules to ensure cleanup works correctly
+       # when switching USE=modules-compress.
+       find "${ED}/lib" -name '*.ko' -exec touch {} + || die
+
+       # Modules were already stripped before signing
+       dostrip -x /lib/modules
+       kernel-install_compress_modules
+
+       # Mirror the logic from kernel-build_src_install, for architectures
+       # where USE=debug is used.
+       if use ppc64; then
+               dostrip -x "${rel_kernel_dir}/$(dist-kernel_get_image_path)"
+       elif use debug && { use amd64 || use arm64; }; then
+               dostrip -x "${rel_kernel_dir}/vmlinux"
+               dostrip -x "${rel_kernel_dir}/vmlinux.ctfa"
+       fi
+}

Reply via email to