commit:     c85fee7d87abf5b11e4a52ae2f437556091b2471
Author:     Alice Ferrazzi <alicef <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 19 05:36:40 2022 +0000
Commit:     Alice Ferrazzi <alicef <AT> gentoo <DOT> org>
CommitDate: Wed Oct 19 05:36:40 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c85fee7d

sys-kernel/kpatch: add 0.9.7

Signed-off-by: Alice Ferrazzi <alicef <AT> gentoo.org>

 sys-kernel/kpatch/Manifest            |   1 +
 sys-kernel/kpatch/kpatch-0.9.7.ebuild | 100 ++++++++++++++++++++++++++++++++++
 2 files changed, 101 insertions(+)

diff --git a/sys-kernel/kpatch/Manifest b/sys-kernel/kpatch/Manifest
index ba8ec801896f..921cb76ec222 100644
--- a/sys-kernel/kpatch/Manifest
+++ b/sys-kernel/kpatch/Manifest
@@ -1,2 +1,3 @@
 DIST kpatch-0.9.4.tar.gz 257885 BLAKE2B 
3c84dd120b0b512e6a55d342b5950ce5d3a81c8c1e956f167bdb25c0c89dde5d4c2bd91fad687ab9eec4d6f965c21ff647f330f1fbcbfe560ca1f3cd37c6ac54
 SHA512 
647509fb9772b7564c0533ea043a15a66e29d413e045258036e78890c1d9cb072622bf458dda9bd4a87fe0855522c9b6ec3761f9bb4ab7e08157a179abfbaa62
 DIST kpatch-0.9.6.tar.gz 260687 BLAKE2B 
5c535af463f54d7be00fe987716dcb84ed17df69e4ccf5c0a6b4bde32704756c1c217ec43d9f338ce478ff6e0403e5c10f15055c56fbfa786b592b7d67427c6f
 SHA512 
898c5704098c473187f2eab9bccd5fb3cfc31f4211492d658abcd0b7cac6d03f11a27df19a56ad17c20163803084ddf54a27defcf12b4975a8a8eb5dbad73f21
+DIST kpatch-0.9.7.tar.gz 283662 BLAKE2B 
c57578b2e5db8582cb09b9ba2bf2040cc5a178cd6c8fdb7f14a0819c50fd71eb8576b08264d019678498e98baf2875c3bd38247ebae31a9631f0e6a17ec5941a
 SHA512 
c876d9b1e5f6e6ab858fa6f302e78152beb3e50cedd93f3c61ab6f747e32199b0601ad4a36d426d43d0e9a37d9bf1d6bbfddccc86df4b31d5e3e6edead6cded3

diff --git a/sys-kernel/kpatch/kpatch-0.9.7.ebuild 
b/sys-kernel/kpatch/kpatch-0.9.7.ebuild
new file mode 100644
index 000000000000..c900d328d08d
--- /dev/null
+++ b/sys-kernel/kpatch/kpatch-0.9.7.ebuild
@@ -0,0 +1,100 @@
+# Copyright 1999-2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit flag-o-matic linux-mod
+
+if [[ "${PV}" == "9999" ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://github.com/dynup/${PN}.git";
+else
+       SRC_URI="https://github.com/dynup/${PN}/archive/v${PV}.tar.gz -> 
${P}.tar.gz"
+       KEYWORDS="~amd64"
+fi
+
+DESCRIPTION="Dynamic kernel patching for Linux"
+HOMEPAGE="https://github.com/dynup/kpatch";
+
+LICENSE="GPL-2+"
+SLOT="0"
+IUSE="contrib +kpatch +kpatch-build kmod test"
+RESTRICT="!test? ( test )"
+
+RDEPEND="
+       app-crypt/pesign
+       sys-libs/zlib
+       sys-apps/pciutils
+"
+
+DEPEND="
+       ${RDEPEND}
+       dev-libs/elfutils
+       sys-devel/bison
+       test? ( dev-util/shellcheck-bin )
+"
+
+PATCHES=(
+       "${FILESDIR}"/${PN}-0.9.4-no-werror.patch
+)
+
+pkg_setup() {
+       if use kmod; then
+               if kernel_is gt 3 9 0; then
+                       if ! linux_config_exists; then
+                               eerror "Unable to check the currently running 
kernel for kpatch support"
+                               eerror "Please be sure a .config file is 
available in the kernel src dir"
+                               eerror "and ensure the kernel has been built."
+                       else
+                               # Fail to build if these kernel options are not 
enabled (see kpatch/kmod/core/Makefile)
+                               CONFIG_CHECK="FUNCTION_TRACER HAVE_FENTRY 
MODULES SYSFS KALLSYMS_ALL"
+                               ERROR_FUNCTION_TRACER="CONFIG_FUNCTION_TRACER 
must be enabled in the kernel's config file"
+                               ERROR_HAVE_FENTRY="CONFIG_HAVE_FENTRY must be 
enabled in the kernel's config file"
+                               ERROR_MODULES="CONFIG_MODULES must be enabled 
in the kernel's config file"
+                               ERROR_SYSFS="CONFIG_SYSFS must be enabled in 
the kernel's config file"
+                               ERROR_KALLSYMS_ALL="CONFIG_KALLSYMS_ALL must be 
enabled in the kernel's config file"
+                       fi
+               else
+                       eerror
+                       eerror "kpatch is not available for Linux kernels below 
4.0.0"
+                       eerror
+                       die "Upgrade the kernel sources before installing 
kpatch."
+               fi
+               check_extra_config
+       fi
+
+}
+
+src_prepare() {
+       replace-flags '-O?' '-O1'
+       default
+}
+
+src_compile() {
+       use kpatch-build && emake -C kpatch-build
+       use kpatch && emake -C kpatch
+       use kmod && set_arch_to_kernel && emake -C kmod
+       use contrib && emake -C contrib
+       use test && emake check
+}
+
+src_install() {
+       if use kpatch-build; then
+               emake DESTDIR="${D}" PREFIX="/usr" install -C kpatch-build
+               insinto /usr/share/${PN}/patch
+               doins kmod/patch/kpatch{.lds.S,-macros.h,-patch.h,-patch-hook.c}
+               doins kmod/patch/{livepatch-patch-hook.c,Makefile,patch-hook.c}
+               doins kmod/core/kpatch.h
+               doman man/kpatch-build.1
+       fi
+
+       if use kpatch; then
+               emake DESTDIR="${D}" PREFIX="/usr" install -C kpatch
+               doman man/kpatch.1
+       fi
+
+       use kmod && set_arch_to_kernel && emake DESTDIR="${D}" PREFIX="/usr" 
install -C kmod
+       use contrib && emake DESTDIR="${D}" PREFIX="/usr" install -C contrib
+
+       dodoc README.md doc/patch-author-guide.md
+}

Reply via email to