* [gentoo-commits] repo/proj/guru:dev commit in: sys-kernel/usermode-kernel/
@ 2022-12-15 22:42 Tony Olagbaiye
0 siblings, 0 replies; 2+ messages in thread
From: Tony Olagbaiye @ 2022-12-15 22:42 UTC (permalink / raw
To: gentoo-commits
commit: fb414b1dbc7a1b4d48c2a1f62421b312137f103a
Author: Tony Olagbaiye <bqv <AT> fron <DOT> io>
AuthorDate: Thu Dec 15 22:42:19 2022 +0000
Commit: Tony Olagbaiye <gentoo <AT> fron <DOT> io>
CommitDate: Thu Dec 15 22:42:31 2022 +0000
URL: https://gitweb.gentoo.org/repo/proj/guru.git/commit/?id=fb414b1d
sys-kernel/usermode-kernel: new package, add 6.0.12
Signed-off-by: Tony Olagbaiye <bqv <AT> fron.io>
sys-kernel/usermode-kernel/Manifest | 8 +
.../usermode-kernel/usermode-kernel-6.0.12.ebuild | 282 +++++++++++++++++++++
2 files changed, 290 insertions(+)
diff --git a/sys-kernel/usermode-kernel/Manifest b/sys-kernel/usermode-kernel/Manifest
new file mode 100644
index 000000000..a1af33cea
--- /dev/null
+++ b/sys-kernel/usermode-kernel/Manifest
@@ -0,0 +1,8 @@
+DIST genpatches-6.0-12.base.tar.xz 658212 BLAKE2B 0daa718dd00d76224db3776d6792d51e072a2e4c8094ec22814d84cffcff8d18a670b73f94b5fe231e1eb586e05b42aa44942b8706ced76ac5c172777f8f8519 SHA512 e960c0a687b06ab108429ee99e5ef27dcc826dd3e6d90471addcb215284d37c1ed0cf40eb9d442a7ac90a5c4696a0ad95e0c5997ee954e4677b949a2c7ffcecf
+DIST genpatches-6.0-12.extras.tar.xz 3804 BLAKE2B fbf21f852110ac732124e5a227b38462d7a94ec17d788fbd48ab35e08c2a941f9c3549e58e7cdb4279f8a273daa2cfbde0a560a769d808ca9d26d2419b303b96 SHA512 efdc24c196c10ee2b47d6f81482b4408a5a7e829c21d9c2eff6426a92a1c17f0315c64875d45795cda7b735d183b7560ec44e308fee34b09e89c171526c9ee4f
+DIST gentoo-kernel-config-g3.tar.gz 4411 BLAKE2B 00edc4b5dc943834bc7ee977382b2960160888db00a25c5a7f73968784aa39a2b3b69f0bbda89b3ce8eb55e746006cff2839481493ac8bfca6a21de2299564f7 SHA512 44beae869bebf5445655dafe1facc47c3dbe602b34c5bf2fa984a581bfe3250fa0df908b8807c333c2e66ab9d1a2bb8026e22140f2a1f522d0dd647c96ca4d5e
+DIST kernel-aarch64-fedora.config.6.0.8-gentoo 249703 BLAKE2B d62624ff7072694a5ad98084925fbc892ac381fec0fce0aa01309df06ce9f115b0aaecf578a3e2ce6e6c3b25de9fe14d0c5b4ec2182fdf21dff30ed393ebbd8a SHA512 dc7d2aaa191f0ee2a61b563716c60dd1d62c741f16b6599dbc97a86e076cd5af7c93c264cf94ee4ab5570c7dc268ff50076372a8ffceeed4d0731b6b88757f9c
+DIST kernel-i686-fedora.config.6.0.8-gentoo 225904 BLAKE2B 4ff7e1866d3a76b34e462a20d539ea0a9a588b3588c222c1b17737414c7e883f68095959d68e374819a1e14079e410fa049cf6d264bd4995299299275de95b5b SHA512 6c518d1dd2130dfcb8001d97df66dd10cdc55e6e4d7a751d9a01978d2c47735a63a9c4e04e42965484ecff42255aa82f7d6725f018b0436140511ca6b4b7bc6a
+DIST kernel-ppc64le-fedora.config.6.0.8-gentoo 215817 BLAKE2B 75cb973385e1580b5d3b03762db6ad830e1cf2d6748a5f2591a0296d98c6e3fb9f3730c333e3dc85c8b06ebac41716a3e762e3b612017dbf7db75c7e4bc90872 SHA512 a568e97367927fb5e390ff7d30eba9b27ef27c89f8a20c02919589b8098205d94970685e386ca559b9d92898dd75a3a34b4113426dd2fa95bb025de284573a5a
+DIST kernel-x86_64-fedora.config.6.0.8-gentoo 226579 BLAKE2B 61661976712081684f28daf26559b489f1e9e0bae749c2ab19f8de7154c86408791fc5333ff589b277fe060bf44edf02b525f0233e44fdcb3c90e519b51f6fc9 SHA512 5dc327afaa87e51330881f5f8b1b83d7cad360626744023fe98146390c8a745da00f60c6f7363e594eee87bc4dc27970af88e9e31a415267b0d2752bea8ca08d
+DIST linux-6.0.tar.xz 133886176 BLAKE2B c09a9c877ac0fac83dc31d2d04d96f0a3331d4ed78e3ad4edfd4dc077e1c11d0c49f419fdac4008b5c93d1b09c2b724e12ef0b38371ad0962908abf85dfa95fa SHA512 bac41a7aeb6e809616cee2f13dcd1c45e829dfd1ccf60aee1dc4c46b1e28532f4485c7d819a32940de84fdfbf89db80a4e919bce8a74b2948c5a01551771b714
diff --git a/sys-kernel/usermode-kernel/usermode-kernel-6.0.12.ebuild b/sys-kernel/usermode-kernel/usermode-kernel-6.0.12.ebuild
new file mode 100644
index 000000000..e6ca2dbde
--- /dev/null
+++ b/sys-kernel/usermode-kernel/usermode-kernel-6.0.12.ebuild
@@ -0,0 +1,282 @@
+# Copyright 2020-2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit kernel-build toolchain-funcs
+
+MY_P=linux-${PV%.*}
+GENPATCHES_P=genpatches-${PV%.*}-$(( ${PV##*.} + 0 ))
+# https://koji.fedoraproject.org/koji/packageinfo?packageID=8
+# forked to https://github.com/projg2/fedora-kernel-config-for-gentoo
+CONFIG_VER=6.0.8-gentoo
+GENTOO_CONFIG_VER=g3
+
+DESCRIPTION="Linux kernel built with Gentoo patches"
+HOMEPAGE="https://www.kernel.org/"
+SRC_URI+="
+ https://cdn.kernel.org/pub/linux/kernel/v$(ver_cut 1).x/${MY_P}.tar.xz
+ https://dev.gentoo.org/~alicef/dist/genpatches/${GENPATCHES_P}.base.tar.xz
+ https://dev.gentoo.org/~alicef/dist/genpatches/${GENPATCHES_P}.extras.tar.xz
+ https://github.com/projg2/gentoo-kernel-config/archive/${GENTOO_CONFIG_VER}.tar.gz
+ -> gentoo-kernel-config-${GENTOO_CONFIG_VER}.tar.gz
+ amd64? (
+ https://raw.githubusercontent.com/projg2/fedora-kernel-config-for-gentoo/${CONFIG_VER}/kernel-x86_64-fedora.config
+ -> kernel-x86_64-fedora.config.${CONFIG_VER}
+ )
+ arm64? (
+ https://raw.githubusercontent.com/projg2/fedora-kernel-config-for-gentoo/${CONFIG_VER}/kernel-aarch64-fedora.config
+ -> kernel-aarch64-fedora.config.${CONFIG_VER}
+ )
+ ppc64? (
+ https://raw.githubusercontent.com/projg2/fedora-kernel-config-for-gentoo/${CONFIG_VER}/kernel-ppc64le-fedora.config
+ -> kernel-ppc64le-fedora.config.${CONFIG_VER}
+ )
+ x86? (
+ https://raw.githubusercontent.com/projg2/fedora-kernel-config-for-gentoo/${CONFIG_VER}/kernel-i686-fedora.config
+ -> kernel-i686-fedora.config.${CONFIG_VER}
+ )
+"
+S=${WORKDIR}/${MY_P}
+
+LICENSE="GPL-2"
+KEYWORDS="~amd64 ~arm ~arm64 ~hppa ~ppc ~ppc64 ~riscv ~x86"
+IUSE="debug hardened pic static +hostfs +iomem"
+REQUIRED_USE="arm? ( savedconfig )
+ hppa? ( savedconfig )
+ riscv? ( savedconfig )"
+
+RDEPEND="
+ sys-apps/usermode-utilities
+"
+BDEPEND="
+ debug? ( dev-util/pahole )
+"
+
+QA_FLAGS_IGNORED="
+ usr/src/linux-.*/scripts/gcc-plugins/.*.so
+ usr/src/linux-.*/vmlinux
+ usr/src/linux-.*/arch/powerpc/kernel/vdso.*/vdso.*.so.dbg
+"
+
+src_prepare() {
+ local PATCHES=(
+ # meh, genpatches have no directory
+ "${WORKDIR}"/*.patch
+ )
+ default
+
+ local biendian=false
+
+ # prepare the default config
+ case ${ARCH} in
+ amd64)
+ cp "${DISTDIR}/kernel-x86_64-fedora.config.${CONFIG_VER}" .config || die
+ ;;
+ arm)
+ return
+ ;;
+ arm64)
+ cp "${DISTDIR}/kernel-aarch64-fedora.config.${CONFIG_VER}" .config || die
+ biendian=true
+ ;;
+ hppa)
+ return
+ ;;
+ ppc)
+ # assume powermac/powerbook defconfig
+ # we still package.use.force savedconfig
+ cp "${WORKDIR}/${MY_P}/arch/powerpc/configs/pmac32_defconfig" .config || die
+ ;;
+ ppc64)
+ cp "${DISTDIR}/kernel-ppc64le-fedora.config.${CONFIG_VER}" .config || die
+ biendian=true
+ ;;
+ riscv)
+ return
+ ;;
+ x86)
+ cp "${DISTDIR}/kernel-i686-fedora.config.${CONFIG_VER}" .config || die
+ ;;
+ *)
+ die "Unsupported arch ${ARCH}"
+ ;;
+ esac
+
+ local myversion="-usermode-gentoo"
+ use hardened && myversion+="-hardened"
+ echo "CONFIG_LOCALVERSION=\"${myversion}\"" > "${T}"/version.config || die
+ local dist_conf_path="${WORKDIR}/gentoo-kernel-config-${GENTOO_CONFIG_VER}"
+
+ local merge_configs=(
+ "${T}"/version.config
+ "${dist_conf_path}"/base.config
+ )
+ use debug || merge_configs+=(
+ "${dist_conf_path}"/no-debug.config
+ )
+ if use hardened; then
+ merge_configs+=( "${dist_conf_path}"/hardened-base.config )
+
+ tc-is-gcc && merge_configs+=( "${dist_conf_path}"/hardened-gcc-plugins.config )
+
+ if [[ -f "${dist_conf_path}/hardened-${ARCH}.config" ]]; then
+ merge_configs+=( "${dist_conf_path}/hardened-${ARCH}.config" )
+ fi
+ fi
+
+ # this covers ppc64 and aarch64_be only for now
+ if [[ ${biendian} == true && $(tc-endian) == big ]]; then
+ merge_configs+=( "${dist_conf_path}/big-endian.config" )
+ fi
+
+ kernel-build_merge_configs "${merge_configs[@]}"
+}
+
+src_configure() {
+ default
+
+ MAKEARGS+=( ARCH="um" )
+
+ if use pic; then
+ MAKEARGS+=( KCFLAGS="-fPIC" )
+ fi
+
+ restore_config .config
+ emake O="${WORKDIR}"/modprep "${MAKEARGS[@]}" mrproper
+ mv .config "${WORKDIR}"/modprep/.config || die
+
+ # UML
+ if use static; then
+ echo "CONFIG_STATIC_LINK=y" >> "${WORKDIR}"/modprep/.config || die
+ fi
+ if use hostfs; then
+ echo "CONFIG_HOSTFS=y" >> "${WORKDIR}"/modprep/.config || die
+ fi
+ if use iomem; then
+ echo "CONFIG_MMAPPER=y" >> "${WORKDIR}"/modprep/.config || die
+ fi
+ echo "CONFIG_UML_TIME_TRAVEL_SUPPORT=y" >> "${WORKDIR}"/modprep/.config || die
+
+ # Character Devices
+ echo "CONFIG_STDERR_CONSOLE=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_SSL=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_NULL_CHAN=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_PORT_CHAN=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_PTY_CHAN=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_TTY_CHAN=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_XTERM_CHAN=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_UML_SOUND=y" >> "${WORKDIR}"/modprep/.config || die
+
+ # Network Devices
+ echo "CONFIG_UML_NET=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_UML_NET_VECTOR=y" >> "${WORKDIR}"/modprep/.config || die
+
+ # Kernel
+ echo "CONFIG_VIRTIO_UML=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_UML_RTC=y" >> "${WORKDIR}"/modprep/.config || die
+
+ # Block Devices
+ echo "CONFIG_BLK_DEV_UBD=y" >> "${WORKDIR}"/modprep/.config || die
+ echo "CONFIG_BLK_DEV_UBD_SYNC=y" >> "${WORKDIR}"/modprep/.config || die
+
+ # Watchdog Timer
+ echo "CONFIG_UML_WATCHDOG=y" >> "${WORKDIR}"/modprep/.config || die
+
+ # Character Devices
+ echo "CONFIG_UML_RANDOM=y" >> "${WORKDIR}"/modprep/.config || die
+
+ emake O="${WORKDIR}"/modprep "${MAKEARGS[@]}" olddefconfig
+ emake O="${WORKDIR}"/modprep "${MAKEARGS[@]}" modules_prepare
+ cp -pR "${WORKDIR}"/modprep "${WORKDIR}"/build || die
+}
+
+src_compile() {
+ emake O="${WORKDIR}"/build "${MAKEARGS[@]}" all
+}
+
+src_install() {
+ # do not use 'make install' as it behaves differently based
+ # on what kind of installkernel is installed
+ local targets=( modules_install )
+
+ emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
+ INSTALL_MOD_PATH="${ED}" INSTALL_PATH="${ED}/boot" "${targets[@]}"
+
+ # note: we're using mv rather than doins to save space and time
+ # install main and arch-specific headers first, and scripts
+ local kern_arch="um"
+ local mods_arch="x86" # hardcoded!
+ local dir_ver=${PV}${KV_LOCALVERSION}
+ local kernel_dir=/usr/src/linux-${dir_ver}
+ dodir "${kernel_dir}/arch/${kern_arch}"
+ dodir "${kernel_dir}/arch/${mods_arch}"
+ mv include scripts "${ED}${kernel_dir}/" || die
+ mv "arch/${kern_arch}/include" \
+ "${ED}${kernel_dir}/arch/${kern_arch}/" || die
+ mv "arch/${mods_arch}/include" \
+ "${ED}${kernel_dir}/arch/${mods_arch}/" || die
+
+ # remove everything but Makefile* and Kconfig*
+ find -type f '!' '(' -name 'Makefile*' -o -name 'Kconfig*' ')' \
+ -delete || die
+ find -type l -delete || die
+ cp -p -R * "${ED}${kernel_dir}/" || die
+
+ cd "${WORKDIR}" || die
+ # strip out-of-source build stuffs from modprep
+ # and then copy built files as well
+ 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}${kernel_dir}"/ || die
+
+ # install the kernel and files needed for module builds
+ insinto "${kernel_dir}"
+ doins build/{System.map,Module.symvers}
+ local image_path="linux"
+ cp -p "build/${image_path}" "${ED}${kernel_dir}/${image_path}" || die
+
+ # building modules fails with 'vmlinux has no symtab?' if stripped
+ use ppc64 && dostrip -x "${kernel_dir}/${image_path}"
+
+ # Install vmlinux with debuginfo when requested
+ if use debug; then
+ if [[ "${image_path}" != "linux" ]]; then
+ mv "build/linux" "${ED}${kernel_dir}/linux" || die
+ fi
+ dostrip -x "${kernel_dir}/linux"
+ fi
+ dobin "${kernel_dir}/linux"
+
+ # strip empty directories
+ find "${D}" -type d -empty -exec rmdir {} + || die
+
+ local relfile=${ED}${kernel_dir}/include/config/kernel.release
+ local module_ver
+ module_ver=$(<"${relfile}") || die
+
+ # fix source tree and build dir symlinks
+ dosym "../../../${kernel_dir}" "/lib/modules/${module_ver}/build"
+ dosym "../../../${kernel_dir}" "/lib/modules/${module_ver}/source"
+
+ save_config build/.config
+}
+
+pkg_postinst() {
+ # disable kernel-install_pkg_postinst
+ setcap cap_net_admin+ep "/usr/bin/linux" || die
+}
+
+pkg_prerm() {
+ # disable kernel-install_pkg_prerm
+ true
+}
+
+pkg_postrm() {
+ # disable kernel-install_pkg_postrm
+ true
+}
^ permalink raw reply related [flat|nested] 2+ messages in thread
* [gentoo-commits] repo/proj/guru:dev commit in: sys-kernel/usermode-kernel/
@ 2022-12-19 23:41 Julien Roy
0 siblings, 0 replies; 2+ messages in thread
From: Julien Roy @ 2022-12-19 23:41 UTC (permalink / raw
To: gentoo-commits
commit: a96a83b85715b84fd8b25483c5988e64bf6ceeed
Author: Julien Roy <julien <AT> jroy <DOT> ca>
AuthorDate: Mon Dec 19 23:40:22 2022 +0000
Commit: Julien Roy <julien <AT> jroy <DOT> ca>
CommitDate: Mon Dec 19 23:41:05 2022 +0000
URL: https://gitweb.gentoo.org/repo/proj/guru.git/commit/?id=a96a83b8
sys-kernel/usermode-kernel: unkeyword 6.0.12
Signed-off-by: Julien Roy <julien <AT> jroy.ca>
sys-kernel/usermode-kernel/metadata.xml | 14 ++++++++++++++
sys-kernel/usermode-kernel/usermode-kernel-6.0.12.ebuild | 2 +-
2 files changed, 15 insertions(+), 1 deletion(-)
diff --git a/sys-kernel/usermode-kernel/metadata.xml b/sys-kernel/usermode-kernel/metadata.xml
new file mode 100644
index 000000000..5c6167cb3
--- /dev/null
+++ b/sys-kernel/usermode-kernel/metadata.xml
@@ -0,0 +1,14 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd">
+<pkgmetadata>
+ <upstream>
+ <remote-id type="github">projg2/gentoo-kernel-config</remote-id>
+ </upstream>
+ <use>
+ <flag name="hardened">Use selection of hardening options recommended by Kernel Self Protection Project</flag>
+ <flag name="initramfs">Build initramfs along with the kernel.</flag>
+ <flag name="hostfs">Enable CONFIG_HOSTFS</flag>
+ <flag name="iomem">Enable CONFIG_MMAPPER</flag>
+ <flag name="pic">Enable the use of position independent code</flag>
+ </use>
+</pkgmetadata>
diff --git a/sys-kernel/usermode-kernel/usermode-kernel-6.0.12.ebuild b/sys-kernel/usermode-kernel/usermode-kernel-6.0.12.ebuild
index e6ca2dbde..f9abf9deb 100644
--- a/sys-kernel/usermode-kernel/usermode-kernel-6.0.12.ebuild
+++ b/sys-kernel/usermode-kernel/usermode-kernel-6.0.12.ebuild
@@ -40,7 +40,7 @@ SRC_URI+="
S=${WORKDIR}/${MY_P}
LICENSE="GPL-2"
-KEYWORDS="~amd64 ~arm ~arm64 ~hppa ~ppc ~ppc64 ~riscv ~x86"
+KEYWORDS="~amd64 ~arm ~x86"
IUSE="debug hardened pic static +hostfs +iomem"
REQUIRED_USE="arm? ( savedconfig )
hppa? ( savedconfig )
^ permalink raw reply related [flat|nested] 2+ messages in thread
end of thread, other threads:[~2022-12-19 23:41 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-12-19 23:41 [gentoo-commits] repo/proj/guru:dev commit in: sys-kernel/usermode-kernel/ Julien Roy
-- strict thread matches above, loose matches on Subject: below --
2022-12-15 22:42 Tony Olagbaiye
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox