summaryrefslogtreecommitdiff
path: root/linux-lts-6.14-rc2-blob/PKGBUILD
diff options
context:
space:
mode:
authorsrv <enmanuel.saravia.externo@pandero.com.pe>2025-05-05 15:29:27 -0500
committersrv <enmanuel.saravia.externo@pandero.com.pe>2025-05-05 15:29:27 -0500
commit81555e3bd23c74ce915d246ca51fa65d84c22ae7 (patch)
tree1ba136af6b87426d37d010866b5cdac110eaeaa8 /linux-lts-6.14-rc2-blob/PKGBUILD
First commitdevelop
Diffstat (limited to 'linux-lts-6.14-rc2-blob/PKGBUILD')
-rwxr-xr-xlinux-lts-6.14-rc2-blob/PKGBUILD284
1 files changed, 284 insertions, 0 deletions
diff --git a/linux-lts-6.14-rc2-blob/PKGBUILD b/linux-lts-6.14-rc2-blob/PKGBUILD
new file mode 100755
index 0000000..ec2b898
--- /dev/null
+++ b/linux-lts-6.14-rc2-blob/PKGBUILD
@@ -0,0 +1,284 @@
+# Maintainer: David P. <megver83@parabola.nu>
+# Contributor: André Silva <emulatorman@hyperbola.info>
+# Contributor: Márcio Silva <coadde@hyperbola.info>
+# Contributor: fauno <fauno@parabola.nu>
+# Contributor: Sorin-Mihai Vârgolici <smv@yobicore.org>
+# Contributor: Michał Masłowski <mtjm@mtjm.eu>
+# Contributor: Luke R. <g4jc@openmailbox.org>
+# Contributor: Andreas Grapentin <andreas@grapentin.org>
+# No official contributor: Enmanuel Eli <saravia@riseup.net>
+# Based on linux package
+_replacesarchkernel=('linux%') # '%' gets replaced with kernel suffix
+_replacesoldkernels=() # '%' gets replaced with kernel suffix
+_replacesoldmodules=() # '%' gets replaced with kernel suffix
+_pkgbase=linux-libre
+pkgbase=linux-libre-lts
+_archpkgver=${_pkgver%-*}
+_replacesarchkernel=('linux%') # '%' gets replaced with _kernelname
+_replacesmainlinearchkernel=('linux%') # '%' gets replaced with _kernelname
+_replacesoldkernels=() # '%' gets replaced with _kernelname
+_replacesoldmodules=() # '%' gets replaced with _kernelname
+_pkgbasever=6.14
+_pkgver=${_pkgbasever}
+#-rc2
+pkgver=${_pkgbasever}
+pkgrel=1
+pkgdesc='Linux-libre'
+url='https://linux-libre.fsfla.org/'
+arch=(x86_64)
+license=(GPL-2)
+makedepends=(
+ bc
+ cpio
+ gettext
+ libelf
+ dwarves
+ perl
+ python
+ tar
+ xz
+ xmlto
+ docbook-xsl
+ kmod
+ # htmldocs
+ graphviz
+ imagemagick
+ python-sphinx
+ # texlive-latexextra
+)
+options=('!strip')
+_srcname=linux-$pkgver
+source=(
+ "https://git.kernel.org/torvalds/t/linux-${_pkgbasever}-rc2.tar.gz"
+ config.x86_64 # I have only x86_64
+ linux.install
+ linux.install.pkg
+ linux.preset
+ 90-linux.hook
+ # maintain the TTY over USB disconnects
+ # http://www.coreboot.org/EHCI_Gadget_Debug
+ 0001-usb-serial-gadget-no-TTY-hangup-on-USB-disconnect-WI.patch
+ # Arch Linux patches
+ # https://github.com/archlinux/linux
+ 0001-ZEN-Add-sysctl-and-CONFIG-to-disallow-unprivileged-C.patch
+ 0003-arch-Kconfig-Default-to-maximum-amount-of-ASLR-bits.patch
+)
+sha512sums=('83774297991487335ab23b6f70467a245cb0b5a0deea00efe10374159d7dbf25fa29bd3892ccd6f11cfb643580b402b34922609dd7b59dc0a0a532e0da4e5b6e'
+ '7de56a60d7b94fb63e804a5939f6904bbf709c7b51187028e73228ce8d6efe7fc48f1206fbd38510cbf145ef89e6aab3d9236b2418c61321970970a6f9a3233e'
+ '07354d4c283c3bb71aea6521c02e35017e0dc888f206d841a08b064cd0e60ede3a9a532616f51c78de7af28052bd0b0fcdc547ccad9020ace0f1218524d673d5'
+ '655b8c4c2412cc45b8adc9f1184e8fe49376db74471bebc0089b2b14a6795e418740daee23228601481d302998bcc856e508c7d9d9666e311b14a97b42e7692f'
+ '2dc6b0ba8f7dbf19d2446c5c5f1823587de89f4e28e9595937dd51a87755099656f2acec50e3e2546ea633ad1bfd1c722e0c2b91eef1d609103d8abdc0a7cbaf'
+ '38ddc517f33fe41dec63b31313a82e0e8c05788e9db5e448d23a01605c50fe3422927cfd902e81c3b0eae17502db06f48e7f713e1ba1c9c76fd26f1473b02983'
+ '02af4dd2a007e41db0c63822c8ab3b80b5d25646af1906dc85d0ad9bb8bbf5236f8e381d7f91cf99ed4b0978c50aee37cb9567cdeef65b7ec3d91b882852b1af'
+ 'd26fc559df706444b72a8ffa2e36be5fac75ccc3c9329c3a65e1be6c2b29952dc263813a9eed0983b6ef17e7fd008d0768d48b4122468ba774eac3ce73d8c69f'
+ '4aae75d307380390a6e1f8dd7593a0302e0e222d89c0723898cdb445e87adf2392f3b88a2217631bdf522d5a7c022b99fa699e948a925af0591d25de0ec103d1')
+validpgpkeys=(
+ 474402C8C582DAFBE389C427BCB7CF877E7D47A7 # Alexandre Oliva
+ 6DB9C4B4F0D8C0DC432CF6E4227CA7C556B2BA78 # David P.
+ ABAF11C65A2970B130ABE3C479BE3E4300411886 # Linus Torvalds
+ 647F28654894E3BD457199BE38DBBDC86092693E # Greg Kroah-Hartman
+ E27E5D8A3403A2EF66873BBCDEA66FF797772CDC # Sasha Levin
+ AC2B29BD34A6AFDDB3F68F35E7BFC8EC95861109 # Ben Hutchings
+)
+_replacesarchkernel=("${_replacesarchkernel[@]/\%/${pkgbase#linux-libre}}")
+_replacesoldkernels=("${_replacesoldkernels[@]/\%/${pkgbase#linux-libre}}")
+_replacesoldmodules=("${_replacesoldmodules[@]/\%/${pkgbase#linux-libre}}")
+case "$CARCH" in
+ i686|x86_64) KARCH=x86;;
+esac
+export KBUILD_BUILD_HOST=hyperbola
+export KBUILD_BUILD_USER=$pkgbase
+export KBUILD_BUILD_TIMESTAMP="$(date -Ru${SOURCE_DATE_EPOCH:+d @$SOURCE_DATE_EPOCH})"
+prepare() {
+ cd "${srcdir}/linux-${_pkgver}-rc2"
+ echo "Setting version..."
+ echo "-$pkgrel" > localversion.10-pkgrel
+ echo "${pkgbase#linux-libre}" > localversion.20-pkgname
+ local source=("${source[@]}")
+ local src
+ for src in "${source[@]}"; do
+ src="${src%%::*}"
+ src="${src##*/}"
+ [[ $src = *.patch ]] || continue
+ echo "Applying patch $src..."
+ patch -p1 -i "${srcdir}/$src"
+ done
+ echo "Setting config..."
+ cp ../config.$CARCH .config
+ yes "" | make olddefconfig
+ diff -u ../config.$CARCH .config || :
+ yes "" | make -s kernelrelease > version
+ echo "Prepared $pkgbase version $(<version)"
+}
+build() {
+ echo "!enma $(pwd) build"
+ cd "${srcdir}/linux-${pkgver}-rc2"
+ make ${MAKEFLAGS} LOCALVERSION= bzImage modules
+}
+_package() {
+ pkgdesc="The ${pkgbase^} kernel and modules"
+ [ "${pkgbase}" = "linux-libre-lts" ] && groups=('base')
+ depends=('coreutils' 'kmod' 'mkinitcpio>=0.7')
+ optdepends=('kernel-firmware: firmware files for Linux-libre'
+ 'crda: to set the correct wireless channels of your country')
+ provides=("${_replacesarchkernel[@]/%/=${_archpkgver}-rc2}" "${_replacesoldkernels[@]}" "kernel=${_archpkgver}-rc2" "${_replacesmainlinearchkernel[@]}")
+ conflicts=("${_replacesarchkernel[@]}" "${_replacesoldkernels[@]}" "${_replacesoldmodules[@]}" "${_replacesmainlinearchkernel[@]}")
+ replaces=("${_replacesarchkernel[@]}" "${_replacesoldkernels[@]}" "${_replacesoldmodules[@]}" "${_replacesmainlinearchkernel[@]}")
+ backup=("etc/mkinitcpio.d/${pkgbase}.preset")
+ install=linux.install
+ cd "${srcdir}/linux-${_pkgver}-rc2"
+ # get kernel version
+ _kernver="$(make LOCALVERSION= kernelrelease)"
+ _basekernel=${_kernver%%-*}
+ _basekernel=${_basekernel%.*}
+ mkdir -p "${pkgdir}"/{lib/modules,lib/firmware,boot}
+ install -Dm644 arch/$KARCH/boot/bzImage "${pkgdir}/boot/vmlinuz-${pkgbase}"
+ make ${MAKEFLAGS} LOCALVERSION= INSTALL_MOD_PATH="${pkgdir}" INSTALL_MOD_STRIP=1 modules_install
+ # set correct depmod command for install
+ sed -e "s|%PKGBASE%|${pkgbase}|g;s|%KERNVER%|${_kernver}|g" \
+ "${startdir}/${install}" > "${startdir}/${install}.pkg"
+ true && install=${install}.pkg
+ # install mkinitcpio preset file for kernel
+ sed "s|%PKGBASE%|${pkgbase}|g" "${srcdir}/linux.preset" |
+ install -D -m644 /dev/stdin "${pkgdir}/etc/mkinitcpio.d/${pkgbase}.preset"
+ # install pacman hook for initramfs regeneration
+ sed "s|%PKGBASE%|${pkgbase}|g" "${srcdir}/90-linux.hook" |
+ install -D -m644 /dev/stdin "${pkgdir}/usr/share/libalpm/hooks/90-${pkgbase}.hook"
+ # remove build and source links
+ rm -f "${pkgdir}"/lib/modules/${_kernver}/{source,build}
+ # # remove the firmware
+ # rm -rf "${pkgdir}/lib/firmware"
+ # make room for external modules
+ ln -s "../extramodules-${_basekernel}${_kernelname}" "${pkgdir}/lib/modules/${_kernver}/extramodules"
+ # add real version for building modules and running depmod from post_install/upgrade
+ mkdir -p "${pkgdir}/lib/modules/extramodules-${_basekernel}${_kernelname}"
+ echo "${_kernver}" > "${pkgdir}/lib/modules/extramodules-${_basekernel}${_kernelname}/version"
+ # Now we call depmod...
+ depmod -b "${pkgdir}" -F System.map "${_kernver}"
+ # add kernel configuration file
+ # https://issues.hyperbola.info/index.php?do=details&task_id=146
+ install -D -m644 .config "${pkgdir}/boot/config-${pkgbase}"
+ # install license file
+ install -D -m644 COPYING "${pkgdir}/usr/share/licenses/$pkgname/COPYING"
+}
+_package-headers() {
+ pkgdesc="Header files and scripts for building modules for ${pkgbase^} kernel"
+ provides=("${_replacesarchkernel[@]/%/-headers=${_archpkgver}-rc2}" "${_replacesoldkernels[@]/%/-headers}" "${_replacesmainlinearchkernel[@]/%/-headers}")
+ conflicts=("${_replacesarchkernel[@]/%/-headers}" "${_replacesoldkernels[@]/%/-headers}" "${_replacesmainlinearchkernel[@]/%/-headers}")
+ replaces=("${_replacesarchkernel[@]/%/-headers}" "${_replacesoldkernels[@]/%/-headers}" "${_replacesmainlinearchkernel[@]/%/-headers}")
+ install -dm755 "${pkgdir}/lib/modules/${_kernver}"
+ cd "${srcdir}/linux-${_pkgver}-rc2"
+ install -D -m644 Makefile \
+ "${pkgdir}/lib/modules/${_kernver}/build/Makefile"
+ install -D -m644 kernel/Makefile \
+ "${pkgdir}/lib/modules/${_kernver}/build/kernel/Makefile"
+ install -D -m644 .config \
+ "${pkgdir}/lib/modules/${_kernver}/build/.config"
+ install -D -m644 vmlinux \
+ "${pkgdir}/lib/modules/${_kernver}/build/vmlinux"
+ install -D -m644 System.map \
+ "${pkgdir}/lib/modules/${_kernver}/build/System.map"
+ install -D -m644 Module.symvers \
+ "${pkgdir}/lib/modules/${_kernver}/build/Module.symvers"
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/include"
+ for i in acpi asm-generic clocksource config crypto drm dt-bindings \
+ generated keys kunit kvm linux math-emu media memory misc net \
+ pcmcia ras rdma scsi soc sound target trace uapi vdso video xen; do
+ cp -a include/${i} "${pkgdir}/lib/modules/${_kernver}/build/include/"
+ done
+ # copy arch includes for external modules
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/arch/${KARCH}"
+ cp -a arch/${KARCH}/include "${pkgdir}/lib/modules/${_kernver}/build/arch/${KARCH}/"
+ # copy files necessary for later builds
+ cp -a scripts "${pkgdir}/lib/modules/${_kernver}/build"
+ # fix permissions on scripts dir
+ chmod og-w -R "${pkgdir}/lib/modules/${_kernver}/build/scripts"
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/.tmp_versions"
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/arch/${KARCH}/kernel"
+ cp arch/${KARCH}/Makefile "${pkgdir}/lib/modules/${_kernver}/build/arch/${KARCH}/"
+ cp arch/${KARCH}/kernel/asm-offsets.s "${pkgdir}/lib/modules/${_kernver}/build/arch/${KARCH}/kernel/"
+ # add dm headers
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/drivers/md"
+ cp drivers/md/*.h "${pkgdir}/lib/modules/${_kernver}/build/drivers/md"
+ # add inotify.h
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/include/linux"
+ cp include/linux/inotify.h "${pkgdir}/lib/modules/${_kernver}/build/include/linux/"
+ # add wireless headers
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/net/mac80211/"
+ cp net/mac80211/*.h "${pkgdir}/lib/modules/${_kernver}/build/net/mac80211/"
+ # add dvb headers for external modules
+ # http://bugs.archlinux.org/task/11194
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/include/config/dvb/"
+ cp include/uapi/linux/dvb/*.h "${pkgdir}/lib/modules/${_kernver}/build/include/config/dvb/"
+ # add dvb headers for http://mcentral.de/hg/~mrec/em28xx-new
+ # in reference to:
+ # http://bugs.archlinux.org/task/13146
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/dvb-frontends/"
+ cp drivers/media/dvb-frontends/lgdt330x.h "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/dvb-frontends/"
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/i2c/"
+ cp drivers/media/i2c/msp3400-driver.h "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/i2c/"
+ # add dvb headers
+ # in reference to:
+ # http://bugs.archlinux.org/task/20402
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/usb/dvb-usb"
+ cp drivers/media/usb/dvb-usb/*.h "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/usb/dvb-usb/"
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/dvb-frontends"
+ cp drivers/media/dvb-frontends/*.h "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/dvb-frontends/"
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/tuners"
+ cp drivers/media/tuners/*.h "${pkgdir}/lib/modules/${_kernver}/build/drivers/media/tuners/"
+ # add xfs and shmem for aufs building
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/fs/xfs"
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/mm"
+ # removed in 3.17-gnu series
+ # cp fs/xfs/xfs_sb.h "${pkgdir}/lib/modules/${_kernver}/build/fs/xfs/xfs_sb.h"
+ # copy in Kconfig files
+ for i in $(find . -name "Kconfig*"); do
+ mkdir -p "${pkgdir}"/lib/modules/${_kernver}/build/`echo ${i} | sed 's|/Kconfig.*||'`
+ cp ${i} "${pkgdir}/lib/modules/${_kernver}/build/${i}"
+ done
+ # add objtool for external module building and enabled VALIDATION_STACK option
+ if [ -f tools/objtool/objtool ]; then
+ mkdir -p "${pkgdir}/lib/modules/${_kernver}/build/tools/objtool"
+ cp -a tools/objtool/objtool ${pkgdir}/lib/modules/${_kernver}/build/tools/objtool/
+ fi
+ chown -R root.root "${pkgdir}/lib/modules/${_kernver}/build"
+ find "${pkgdir}/lib/modules/${_kernver}/build" -type d -exec chmod 755 {} \;
+ # strip scripts directory
+ find "${pkgdir}/lib/modules/${_kernver}/build/scripts" -type f -perm -u+w 2>/dev/null | while read binary ; do
+ case "$(file -bi "${binary}")" in
+ *application/x-sharedlib*) # Libraries (.so)
+ /usr/bin/strip ${STRIP_SHARED} "${binary}";;
+ *application/x-archive*) # Libraries (.a)
+ /usr/bin/strip ${STRIP_STATIC} "${binary}";;
+ *application/x-executable*) # Binaries
+ /usr/bin/strip ${STRIP_BINARIES} "${binary}";;
+ *application/x-pie-executable\;*) # Relocatable binaries
+ /usr/bin/strip ${$STRIP_SHARED} "${binary}";;
+ esac
+ done
+ # strip vmlinux
+ strip -v $STRIP_STATIC "${pkgdir}/lib/modules/${_kernver}/build/vmlinux"
+ # remove unneeded architectures
+ find "${pkgdir}"/lib/modules/${_kernver}/build/arch -mindepth 1 -maxdepth 1 -type d -not -name "$KARCH" -exec rm -rf {} +
+ # remove documentation
+ rm -r "${pkgdir}/lib/modules/${_kernver}/build/Documentation"
+ # remove broken symlinks
+ find -L "${pkgdir}/lib/modules/${_kernver}/build" -type l -printf 'Removing %P\n' -delete
+ # remove loose objects
+ find "${pkgdir}/lib/modules/${_kernver}/build" -type f -name '*.o' -printf 'Removing %P\n' -delete
+ # add symlink
+ mkdir -p "$pkgdir/usr/src"
+ ln -sr "${pkgdir}/lib/modules/${_kernver}/build" "$pkgdir/usr/src/$pkgbase"
+ # install license file
+ install -D -m644 COPYING "${pkgdir}/usr/share/licenses/$pkgname/COPYING"
+}
+pkgname=(
+ "$pkgbase"
+ "$pkgbase-headers"
+)
+for _p in "${pkgname[@]}"; do
+ eval "package_$_p() {
+ $(declare -f "_package${_p#$pkgbase}")
+ _package${_p#$pkgbase}
+ }"
+done