diff options
| -rw-r--r-- | sys-kernel/gentoo-kernel-bin/Manifest | 5 | ||||
| -rw-r--r-- | sys-kernel/gentoo-kernel-bin/gentoo-kernel-bin-6.12.57.ebuild | 237 |
2 files changed, 242 insertions, 0 deletions
diff --git a/sys-kernel/gentoo-kernel-bin/Manifest b/sys-kernel/gentoo-kernel-bin/Manifest index 762acdf53eb7..c1d165b72434 100644 --- a/sys-kernel/gentoo-kernel-bin/Manifest +++ b/sys-kernel/gentoo-kernel-bin/Manifest @@ -50,6 +50,10 @@ DIST gentoo-kernel-6.12.56-1.amd64.gpkg.tar 307404800 BLAKE2B 0d151736334ec50a8c DIST gentoo-kernel-6.12.56-1.arm64.gpkg.tar 280453120 BLAKE2B 5835b2b61ad9f62e0cafdc7adebb4ebf2e0a88198f708c241187c24f77d67ec4a1b09307554b5611739ae600bfd2287a6fe1862dd15c396062f15c0ae688ac05 SHA512 89cab71eb293627295a58acf7acac6a8f9e5ad1d055a8c5c60c361a6c9f9fbf014e742fd2a70af34901db55483326da7efde27da6a3d48c56e4cda95b6de0b9f DIST gentoo-kernel-6.12.56-1.ppc64le.gpkg.tar 72509440 BLAKE2B e8e67410c23267c97921117e1c592de7d4a0c3b5b2684843461a20abcd3e78119a3588c121f0321447eb9562e0a565fa8e76658487bdc53d2d4855385cf128db SHA512 54cea7a66cdb858691142afbb600e4e2a74fb2bd84bc561ad67e408d542162604ff06c581558fc956576b85c6e02b8e6dd612996225da719ebe18bad9c8aef3f DIST gentoo-kernel-6.12.56-1.x86.gpkg.tar 77711360 BLAKE2B dcb72d3012d06bb621d657ca9107a74f11b44ead121291e5df938169d4775e7c2a9bf32a95d62db3a66b56d7b8998c628d69b863113a5b16b90df05c5c8d3de7 SHA512 2a5dcc332fccf8903d2f7b139fea0cd523fe2591c735a9457aaf131e0a98c9e6b4cb773abd05c95091c872c660b7d94b7ec4a66403b5532c6e666e2e3a1aec86 +DIST gentoo-kernel-6.12.57-1.amd64.gpkg.tar 307927040 BLAKE2B 2481928667645fbfbe431741e5ef8f1309a55d27c855af17742fa5232c253a1352d90df536308734e5bd82336a9e47754efe5d995eb3f0249b87ea1f0d12d47f SHA512 ee71bfa7f6760c66d118db26874ae0e1fc9bedd5bf70221512a9266fa4630a809c15bd6166ba643f0ff7199653ea695db7e5d1dd5d9eba708b9280b402e09b70 +DIST gentoo-kernel-6.12.57-1.arm64.gpkg.tar 280463360 BLAKE2B a04bf9acb5130e832fb492c494b4e2038b78199cedfcb1dcda630b912964a607d34eb84a541ce922d3dc06413061fa23607c57de46bd76b4425904c6302bb4b9 SHA512 4962d345fa430a9137ba782fdd9fb68d518c0019697ccfdd3537acc4026106392b89bb4f25e3d903a80b82687c15350beb8a771d290d5dc503190a93c3a18a1e +DIST gentoo-kernel-6.12.57-1.ppc64le.gpkg.tar 72529920 BLAKE2B 02f31015c2a06f34d0d1965c56b385e60771f92371696817ce243bb0dc7c331bff5c75655399d6831919508fcabff4735c150e54b9791172dcc76bcbba5c16e1 SHA512 c4fe1144f8cf89a001faea1e1a748679e7b58d5fc3a70534573875e318d779a0cb61a78317c8c0812ce8bdf711c172e5e9ce25fbaaccb2661d89d62597a2c068 +DIST gentoo-kernel-6.12.57-1.x86.gpkg.tar 77721600 BLAKE2B 240e0817874a631ba171e89cdc864f37776940b8d573036e1ba43f117b038581ea42a929222110f1d4d681aed9baecab265400cd1857477ab444e076dd3230fa SHA512 647335ccad473bda05d4db0dbd2be74e0803b34a66554112a1238121bcc9d25fa4dea998a4d8a364bd377ee618c513bf5b5a2981394a09d296b15a61a612f500 DIST gentoo-kernel-6.17.4-1.amd64.gpkg.tar 333434880 BLAKE2B 0289e6e6fffe5e9447092a0ecfd56daa6b6a7bc7fc7a5d466fb9cb0b7448c1887f944870fe9a55dd884225cfa80123a0ba5b8b2a4d73b1c42f8a67388db43f5b SHA512 0b57e94c1f42228c9dd5a07b63599cfe12f02017b7db79ede8d56510866e13784131433e88c9b61d25d8e63d024e67e87b38e1c300bdf1bb54b457f812d26168 DIST gentoo-kernel-6.17.4-1.arm64.gpkg.tar 297431040 BLAKE2B ee3b8ace08b67075f082f95c840d778dd5e7ee974f945a8789d5ad5ad7e6c9a6c4fc7a52881fd8dc05fd5f8de37a3e86c0eee79c89e630ed6239861292115b6b SHA512 b908377ddebd52df17cf718136fbe3cfda6dc3795f22ecaa51cfeab940995dd22650ef34d8640a613bf086eca2dd8f420160ffa9d1eb5649816572da9ef6de3b DIST gentoo-kernel-6.17.4-1.ppc64le.gpkg.tar 75550720 BLAKE2B edb5d49b310fb311840bb62407cfb0e36663bf8dc2830b2cbfe84e905007ba64800f68095d7c599198cdd9558046268b8a4abd77e99ae1c2cf62946a6cfb733e SHA512 6a8e4a69716fe6706b3865b1cb0c774eddc37b80b1d39122adc70aec1745e54487a828da66015f36923c607b61309a81da99d3a79166891270ffd2ee59fdb045 @@ -121,6 +125,7 @@ DIST patch-6.12.47.xz 2896968 BLAKE2B 4064af2ae029d13d63a0a6cfb9e4121266ab33622c DIST patch-6.12.54.xz 3096864 BLAKE2B f5bff8166a5a45535092614ef9ed1d9e39064fd2762f0d71e852a87437326892c9d25a095ad51eb3b7fdfe266ba5f16d271303b98c4c1c6ed1716cfa09b669bb SHA512 744143218b5258a67f4b00126c72d7630b6e563dd0cc0a9cf685bc38cb48dc217d717053117e72a52fba061b2171a99ef64d992288f75500f069c617d1663b5b DIST patch-6.12.55.xz 3132512 BLAKE2B b78f35653171cb91d00f115cfb7a9d5e1b1eb43e77f342b06e7eed3425e620975addcc35608b64eee11d08f0b0599850520ce92fc8170dad3742fd65a2d529b4 SHA512 c81f4e2afc3bb1e5c279147c26ad91bbc045b34bb557f0f2ccaa05d59991320e936a7fd71237ea177e246062280496d72e3e6a006b87e8d67aaaa6c8dfce4608 DIST patch-6.12.56.xz 3156620 BLAKE2B dec99addb9b6a695bfb77f38dda3d1fb6cfbf2854c41431dbe774992c7de20128238073a40d83cd6532bdc138c4b195f7e896dc034d478733951b90ce2398c8f SHA512 d52ed60eb1a7f4072017f6fda5a70b8566dd9db2d79ad6bdf0c18a404de08b218f1ff30c227a20caae0ce0ef82210059e8f15f6267d93be50f3f8e1652a9fb1c +DIST patch-6.12.57.xz 3166572 BLAKE2B d3de49aef49104485236672f0d932a790f81f43d10d3178c4d22dbdc42f2f0bf5e58f74455b1a2f96ff4edb28a68ade510400025eb5da0e3e9d0d0fedb1c0f3e SHA512 32c056e4bdc5ccdaa6d74517f841b5e051197337a3c22a9e1324a7c5ab23ccfa1842403ad4887a31a6a68beee73a5800c92c7fb043a22d49ddc316d6ad909ea5 DIST patch-6.17.4.xz 315840 BLAKE2B 4121f8cc485a71878335d1b186c39271b83bca4e176566ee63e60a26eedd74e68e5d238492c7bb462c4139fade13bff105c46a1d12411cb4fa0972c9eb9cb3d9 SHA512 c81d328581330b10d1b6b99e3bc1386a20c0661905d953a294bf0e68e8f7ccec698ba2286e2c868c8c0ed4e2f42fb8432a988080cc3cdeb57de36630b576400f DIST patch-6.17.5.xz 374980 BLAKE2B d1a8f1ab63801a8ca421981cce57aae2b5da5864336821fe8bbb5131a40b16c100d4fa3d3dd2d5c4ce28bb6e3dd9c6b4b5a642d81f2303dbe12739ce4b7f3c68 SHA512 decf5a01bb3ea68e62257233225e3648d140690ac471cbac9048386aa0ebe7f7362c34cfce1d8fb615c2b37368893d33346da6ea0376feab8b7f3d3187288c83 DIST patch-6.17.6.xz 425004 BLAKE2B 1ebe67d9ebed5fae42b26a6603560e100c6016a6fef85d8b50e5e7ab2467a569c99d5d79ecd4ee261046d342117dd523b28ffb5815ca8f60d5c83cac9a29b3e5 SHA512 1903795778b5a8e8ee017ae4dce5ad1309a975c13151d8ff637c8f74bed64401397ed71df431731fdce54541b4b6919de64e7aad44759ac7b2e596f88d56a05a diff --git a/sys-kernel/gentoo-kernel-bin/gentoo-kernel-bin-6.12.57.ebuild b/sys-kernel/gentoo-kernel-bin/gentoo-kernel-bin-6.12.57.ebuild new file mode 100644 index 000000000000..3ebbd660dc43 --- /dev/null +++ b/sys-kernel/gentoo-kernel-bin/gentoo-kernel-bin-6.12.57.ebuild @@ -0,0 +1,237 @@ +# Copyright 2020-2025 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +KERNEL_IUSE_GENERIC_UKI=1 +KERNEL_IUSE_MODULES_SIGN=1 + +inherit kernel-install toolchain-funcs unpacker verify-sig + +BASE_P=linux-${PV%.*} +PATCH_PV=${PV%_p*} +PATCHSET=linux-gentoo-patches-6.12.52 +BINPKG=${P/-bin}-1 +SHA256SUM_DATE=20251102 + +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 +} |
