summaryrefslogtreecommitdiff
path: root/sys-kernel/linux-image-redcore-lts
diff options
context:
space:
mode:
Diffstat (limited to 'sys-kernel/linux-image-redcore-lts')
-rw-r--r--sys-kernel/linux-image-redcore-lts/Manifest1
-rw-r--r--sys-kernel/linux-image-redcore-lts/linux-image-redcore-lts-5.4.41.ebuild155
2 files changed, 156 insertions, 0 deletions
diff --git a/sys-kernel/linux-image-redcore-lts/Manifest b/sys-kernel/linux-image-redcore-lts/Manifest
index 6f4dde97..780f98f1 100644
--- a/sys-kernel/linux-image-redcore-lts/Manifest
+++ b/sys-kernel/linux-image-redcore-lts/Manifest
@@ -1 +1,2 @@
DIST linux-5.4.35.tar.xz 109524684 BLAKE2B 0e73ef5292d77329d26b165d7da887f5ebc018049d6e9ff25f0036062201e1438f6b8c8234d0201b064e5c663d25b0c258e58ded44c1087c53cf6406676d7724 SHA512 66daf0192339450b0838cd1aef013ea8675f8687e2271d8d9b79c842e8cb081541788eb16fb0b6e5cd0b15617be67813c53a4db2d2e63219f3c64e692c325c5d
+DIST linux-5.4.41.tar.xz 109535752 BLAKE2B 806e55dc2e2b649a280667e6bc043b0c84771043319e0c8a734c3bdb735f6bb15459863f4a4835c87d90e97e2774646902f85dc3bed4307063594a5aa23f261c SHA512 711db80661f2e94fd4819991bd69ff7c3124832ffd6c17025bb82daf2177b82d6700454f7cc58f76c9f839fddf1316f49406af3c2572723b3455b2aac689f7a4
diff --git a/sys-kernel/linux-image-redcore-lts/linux-image-redcore-lts-5.4.41.ebuild b/sys-kernel/linux-image-redcore-lts/linux-image-redcore-lts-5.4.41.ebuild
new file mode 100644
index 00000000..367c11d4
--- /dev/null
+++ b/sys-kernel/linux-image-redcore-lts/linux-image-redcore-lts-5.4.41.ebuild
@@ -0,0 +1,155 @@
+# 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}"
+KV_MAJOR="5.4"
+
+DESCRIPTION="Redcore Linux Kernel Image (LTS)"
+HOMEPAGE="https://redcorelinux.org"
+SRC_URI="https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-${PV}.tar.xz"
+
+KEYWORDS="~amd64"
+LICENSE="GPL-2"
+SLOT="${PVR}"
+IUSE="+cryptsetup +dmraid +dracut +dkms +mdadm"
+
+RESTRICT="binchecks strip mirror"
+DEPEND="
+ app-arch/lz4
+ 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-0.44-r8 )
+ dkms? ( sys-kernel/dkms sys-kernel/linux-sources-redcore-lts:${SLOT} )
+ mdadm? ( sys-fs/mdadm )
+ >=sys-kernel/linux-firmware-20180314"
+RDEPEND="${DEPEND}"
+
+PATCHES=(
+ "${FILESDIR}"/"${KV_MAJOR}"-enable_alx_wol.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-drop_ancient-and-wrong-msg.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-ata-fix-NCQ-LOG-strings-and-move-to-debug.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-radeon_dp_aux_transfer_native-no-ratelimited_debug.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-acpi-use-kern_warning_even_when_error.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-ath10k-be-quiet.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-Unknow-SSD-HFM128GDHTNG-8310B-QUIRK_NO_APST.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-nvme-suspend-resume-workaround.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-nvme-pci-more-info.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-acer-wmi-silence-unknow-functions-messages.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-amdgpu-dc_link-drop-some-asserts.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-nvme-hwmon.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-linux-hardened.patch
+ "${FILESDIR}"/"${KV_MAJOR}"-uksm-linux-hardened.patch
+)
+
+S="${WORKDIR}"/linux-"${PV}"
+
+pkg_setup() {
+ export KBUILD_BUILD_USER="nexus"
+ export KBUILD_BUILD_HOST="nexus.redcorelinux.org"
+
+ 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 "${FILESDIR}"/"${KV_MAJOR}"-amd64.config .config
+ rm -rf $(find . -type f|grep -F \.orig)
+}
+
+src_compile() {
+ emake prepare modules_prepare 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 -N -f --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' | uniq) ; do
+ dkms remove "${DKMSMOD}" -k "${KV_FULL}"
+ done
+ fi
+}
+
+_kernel_modules_delete() {
+ rm -rf "${ROOT}"lib/modules/"${KV_FULL}"
+}
+
+pkg_postinst() {
+ if [ $(stat -c %d:%i /) == $(stat -c %d:%i /proc/1/root/.) ]; then
+ if use dracut; then
+ _dracut_initrd_create
+ fi
+ _grub2_update_grubcfg
+ fi
+}
+
+pkg_postrm() {
+ if [ $(stat -c %d:%i /) == $(stat -c %d:%i /proc/1/root/.) ]; then
+ if use dracut; then
+ _dracut_initrd_delete
+ fi
+ _grub2_update_grubcfg
+ fi
+ if use dkms; then
+ _dkms_modules_delete
+ fi
+ _kernel_modules_delete
+}