diff options
Diffstat (limited to 'sys-kernel/linux-image-lts')
-rw-r--r-- | sys-kernel/linux-image-lts/Manifest | 1 | ||||
-rw-r--r-- | sys-kernel/linux-image-lts/linux-image-lts-4.14.12.ebuild | 124 |
2 files changed, 125 insertions, 0 deletions
diff --git a/sys-kernel/linux-image-lts/Manifest b/sys-kernel/linux-image-lts/Manifest index 272ae2fa..8c57201e 100644 --- a/sys-kernel/linux-image-lts/Manifest +++ b/sys-kernel/linux-image-lts/Manifest @@ -1,2 +1,3 @@ DIST linux-4.14.10-redcore-lts.tar.gz 157818343 SHA256 dc05644263b35e5311dc3580d2e34605c1bb32aa5bc1e43dbfaed8c5dc9aa74c SHA512 0b152d809a460e0541ad8a7ace7506811284648912ad612f0fa8eb3193048d51892f0e6f5cc23709b68e66b654020b08997d500680a031eb00bd64d510ca4a04 WHIRLPOOL 2a57ea9acf7e42b7068366dd1993962bc48f5d71c870380e1bca4b43699d1ab0bdb899fbe15bd279e002319c34819f6586e5ead57f95cccf86587144cffcf738 +DIST linux-4.14.12-redcore-lts.tar.gz 157830040 SHA256 4f437e6d7ab27583af95b5481530ff52b9eaa1aa739a010f8584bfefbf77af58 SHA512 36754a9c02867e73f1bcd04e6b629957f8da6d97d5400ac58cf2ed737b4c9c54823b9c40231f9f1bed219424afdca1b1bfa90bb8777692cacde20a137594a312 WHIRLPOOL 42499c3d59217e067e3c2325505d64eff7a8e0df46dfb37863f981ca42ae5717727bde4d316b6b37e7f0d4cb83d78f2e60fb64778c8becb39d607a7f2bd71ce7 DIST linux-4.9.75-redcore-lts.tar.gz 143406870 SHA256 577992e8c338fd81627a318922a3a23e31261c55599a2f39e2a8f760d0f3541d SHA512 63923dbcc7f35212407b05710a531f386bd32a8a48fd1c2328007c27317bd736d13e78901a2db52f86c88d78bd5463c9c99bdba81f7d35ad2df9c25cc06b3e7a WHIRLPOOL 86a04f194aefae77a3387608bad46759a9353e8c22578aeac78896decf16a7ac345a8f5c0e263237121c5c02429efaf44a058be9ce94194932a4ae73e84fa66e diff --git a/sys-kernel/linux-image-lts/linux-image-lts-4.14.12.ebuild b/sys-kernel/linux-image-lts/linux-image-lts-4.14.12.ebuild new file mode 100644 index 00000000..ab6acff9 --- /dev/null +++ b/sys-kernel/linux-image-lts/linux-image-lts-4.14.12.ebuild @@ -0,0 +1,124 @@ +# Copyright 1999-2017 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 + +EAPI=6 + +inherit eutils + +EXTRAVERSION="redcore-lts" +KV_FULL="${PV}-${EXTRAVERSION}" + +DESCRIPTION="Official Redcore Linux LTS Kernel Image" +HOMEPAGE="https://gitlab.com/redcore/kernel" +SRC_URI="https://github.com/redcorelinux/kernel/archive/linux-${KV_FULL}.tar.gz" + +KEYWORDS="amd64" +LICENSE="GPL-2" +SLOT="${PV}" +IUSE="+cryptsetup +dmraid +dracut +dkms +mdadm" + +RESTRICT="binchecks strip mirror" +DEPEND=" + app-arch/xz-utils + sys-devel/autoconf + sys-devel/bc + sys-devel/make + cryptsetup? ( sys-fs/cryptsetup ) + dmraid? ( sys-fs/dmraid ) + dracut? ( sys-kernel/dracut ) + dkms? ( sys-kernel/dkms ~sys-kernel/linux-headers-lts-${PV} ) + mdadm? ( sys-fs/mdadm ) + >=sys-kernel/linux-firmware-20171206" +RDEPEND="${DEPEND}" + +S="$WORKDIR/kernel-linux-${KV_FULL}" + +pkg_setup() { + export REAL_ARCH="$ARCH" + unset ARCH ; unset LDFLAGS #will interfere with Makefile if set +} + +src_prepare() { + default + emake mrproper + sed -ri "s|^(EXTRAVERSION =).*|\1 -${EXTRAVERSION}|" Makefile + cp "redcore/config/"${EXTRAVERSION}"-4.14-amd64.config" .config +} + +src_compile() { + emake prepare modules_prepare + emake bzImage modules +} + +src_install() { + dodir boot + insinto boot + newins .config config-"${KV_FULL}" + newins System.map System.map-"${KV_FULL}" + newins arch/x86/boot/bzImage vmlinuz-"${KV_FULL}" + + dodir usr/src/linux-"${KV_FULL}" + insinto usr/src/linux-"${KV_FULL}" + doins Module.symvers + doins System.map + exeinto usr/src/linux-"${KV_FULL}" + doexe vmlinux + + emake INSTALL_MOD_PATH="${D}" modules_install + + rm -f "${D}"lib/modules/"${KV_FULL}"/build + rm -f "${D}"lib/modules/"${KV_FULL}"/source + export local KSYMS + for KSYMS in build source ; do + dosym ../../../usr/src/linux-"${KV_FULL}" lib/modules/"${KV_FULL}"/"${KSYMS}" + done +} + +_grub2_update_grubcfg() { + if [[ -x $(which grub2-mkconfig) ]]; then + elog "Updating GRUB-2 bootloader configuration, please wait" + grub2-mkconfig -o "${ROOT}"boot/grub/grub.cfg + else + elog "It looks like you're not using GRUB-2, you must update bootloader configuration by hand" + fi +} + +_dracut_initrd_create() { + if [[ -x $(which dracut) ]]; then + elog "Generating initrd for "${KV_FULL}", please wait" + addpredict /etc/ld.so.cache~ + dracut -f --no-hostonly-cmdline --kver="${KV_FULL}" "${ROOT}"boot/initrd-"${KV_FULL}" + else + elog "It looks like you're not using dracut, you must generate an initrd by hand" + fi +} + +_dracut_initrd_delete() { + rm -rf "${ROOT}"boot/initrd-"${KV_FULL}" +} + +_dkms_modules_delete() { + if [[ -x $(which dkms) ]] ; then + export local DKMSMOD + for DKMSMOD in $(dkms status | cut -d " " -f1,2 | sed -e 's/,//g' | sed -e 's/ /\//g' | sed -e 's/://g') ; do + dkms remove "${DKMSMOD}" -k "${KV_FULL}" + done + fi +} + +pkg_postinst() { + if use dracut; then + _dracut_initrd_create + fi + _grub2_update_grubcfg +} + +pkg_postrm() { + if use dracut; then + _dracut_initrd_delete + fi + if use dkms; then + _dkms_modules_delete + fi + _grub2_update_grubcfg +} |