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.9.76.ebuild | 127 |
2 files changed, 128 insertions, 0 deletions
diff --git a/sys-kernel/linux-image-lts/Manifest b/sys-kernel/linux-image-lts/Manifest index 1cb5031b..07afc432 100644 --- a/sys-kernel/linux-image-lts/Manifest +++ b/sys-kernel/linux-image-lts/Manifest @@ -1,2 +1,3 @@ DIST linux-4.14.13-redcore-lts.tar.gz 157916151 SHA256 75abd220c2f4c6ddab86c3cc6d83f81379944f93041548f52512f949fa0e3fe6 SHA512 93e6839de0eaa942103ccb260442be249b5011b271b93267ba1977d4200c2bae210245695415263587468549f643adc980b207f4e084ad5db3bbbc29f7d5140c WHIRLPOOL 297ba3e2bbcb1c8a38a6ccd597bcc3644f8a3f810e4936e88ccc513ff2098199253f68fb969c5744eae4d4f08fdd3f146dd0807cf399d54b77974fb87a5cafed DIST linux-4.9.75-redcore-lts.tar.gz 143406870 SHA256 577992e8c338fd81627a318922a3a23e31261c55599a2f39e2a8f760d0f3541d SHA512 63923dbcc7f35212407b05710a531f386bd32a8a48fd1c2328007c27317bd736d13e78901a2db52f86c88d78bd5463c9c99bdba81f7d35ad2df9c25cc06b3e7a WHIRLPOOL 86a04f194aefae77a3387608bad46759a9353e8c22578aeac78896decf16a7ac345a8f5c0e263237121c5c02429efaf44a058be9ce94194932a4ae73e84fa66e +DIST linux-4.9.76-redcore-lts.tar.gz 143485673 SHA256 a6491bd04c051d53e76888599ad2a554cfd5b006048457e3e91adb3308b08cf3 SHA512 1a07b8627b13daabf2e33802dfb79553237c72f08cdcdda4d367ec4431b8c8263e2a80d729eba3ce1c1f9234105eabcebf7c7c440f29bfc228400ab2511bb64a WHIRLPOOL 1e079dcddb89cfa169135bc671410139dca275b9cc05b39aa1d812f300bf04ad3c99f0340a9031c9c96316c512c200c53fe7be6ddc5e7c522d81877a54b60149 diff --git a/sys-kernel/linux-image-lts/linux-image-lts-4.9.76.ebuild b/sys-kernel/linux-image-lts/linux-image-lts-4.9.76.ebuild new file mode 100644 index 00000000..55a2b3fe --- /dev/null +++ b/sys-kernel/linux-image-lts/linux-image-lts-4.9.76.ebuild @@ -0,0 +1,127 @@ +# 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.9-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 + + # remove firmware files + rm -rf "${D}"lib/firmware +} + +_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 +} |