New package: linux5.14-5.14.8
This commit is contained in:
parent
20cea7aa68
commit
af09118df7
13 changed files with 61476 additions and 0 deletions
1
srcpkgs/linux5.14-dbg
Symbolic link
1
srcpkgs/linux5.14-dbg
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
linux5.14
|
1
srcpkgs/linux5.14-headers
Symbolic link
1
srcpkgs/linux5.14-headers
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
linux5.14
|
11899
srcpkgs/linux5.14/files/arm64-dotconfig
Normal file
11899
srcpkgs/linux5.14/files/arm64-dotconfig
Normal file
File diff suppressed because it is too large
Load diff
10192
srcpkgs/linux5.14/files/i386-dotconfig
Normal file
10192
srcpkgs/linux5.14/files/i386-dotconfig
Normal file
File diff suppressed because it is too large
Load diff
7
srcpkgs/linux5.14/files/mv-debug
Executable file
7
srcpkgs/linux5.14/files/mv-debug
Executable file
|
@ -0,0 +1,7 @@
|
||||||
|
#!/bin/sh
|
||||||
|
mod=$1
|
||||||
|
mkdir -p usr/lib/debug/${mod%/*}
|
||||||
|
$OBJCOPY --only-keep-debug --compress-debug-sections $mod usr/lib/debug/$mod
|
||||||
|
$OBJCOPY --add-gnu-debuglink=${DESTDIR}/usr/lib/debug/$mod $mod
|
||||||
|
/usr/bin/$STRIP --strip-debug $mod
|
||||||
|
gzip -9 $mod
|
8258
srcpkgs/linux5.14/files/ppc-dotconfig
Normal file
8258
srcpkgs/linux5.14/files/ppc-dotconfig
Normal file
File diff suppressed because it is too large
Load diff
10267
srcpkgs/linux5.14/files/ppc64-dotconfig
Normal file
10267
srcpkgs/linux5.14/files/ppc64-dotconfig
Normal file
File diff suppressed because it is too large
Load diff
9996
srcpkgs/linux5.14/files/ppc64le-dotconfig
Normal file
9996
srcpkgs/linux5.14/files/ppc64le-dotconfig
Normal file
File diff suppressed because it is too large
Load diff
10415
srcpkgs/linux5.14/files/x86_64-dotconfig
Normal file
10415
srcpkgs/linux5.14/files/x86_64-dotconfig
Normal file
File diff suppressed because it is too large
Load diff
16
srcpkgs/linux5.14/patches/fix-musl-objtool.patch
Normal file
16
srcpkgs/linux5.14/patches/fix-musl-objtool.patch
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
objtool is using the headers provided by kernel-libc-headers, which are kernel version 5.10, so
|
||||||
|
they use __always_inline instead of inline, and musl doesn't define __always_inline (glibc does)
|
||||||
|
|
||||||
|
diff --git a/tools/objtool/Makefile b/tools/objtool/Makefile
|
||||||
|
index 92ce4fc..d74b931 100644
|
||||||
|
--- a/tools/objtool/Makefile
|
||||||
|
+++ b/tools/objtool/Makefile
|
||||||
|
@@ -30,7 +30,7 @@ INCLUDES := -I$(srctree)/tools/include \
|
||||||
|
-I$(srctree)/tools/objtool/include \
|
||||||
|
-I$(srctree)/tools/objtool/arch/$(SRCARCH)/include
|
||||||
|
WARNINGS := $(EXTRA_WARNINGS) -Wno-switch-default -Wno-switch-enum -Wno-packed -Wno-nested-externs
|
||||||
|
-CFLAGS := -Werror $(WARNINGS) $(KBUILD_HOSTCFLAGS) -g $(INCLUDES) $(LIBELF_FLAGS)
|
||||||
|
+CFLAGS := -Werror $(WARNINGS) $(KBUILD_HOSTCFLAGS) -g $(INCLUDES) $(LIBELF_FLAGS) -D__always_inline=inline
|
||||||
|
LDFLAGS += $(LIBELF_LIBS) $(LIBSUBCMD) $(KBUILD_HOSTLDFLAGS)
|
||||||
|
|
||||||
|
# Allow old libelf to be used:
|
13
srcpkgs/linux5.14/patches/ppc-vas-on-4k.patch
Normal file
13
srcpkgs/linux5.14/patches/ppc-vas-on-4k.patch
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
diff --git a/arch/powerpc/platforms/book3s/Kconfig b/arch/powerpc/platforms/book3s/Kconfig
|
||||||
|
index 34c9315..88f4f87 100644
|
||||||
|
--- a/arch/powerpc/platforms/book3s/Kconfig
|
||||||
|
+++ b/arch/powerpc/platforms/book3s/Kconfig
|
||||||
|
@@ -1,7 +1,7 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
config PPC_VAS
|
||||||
|
bool "IBM Virtual Accelerator Switchboard (VAS)"
|
||||||
|
- depends on (PPC_POWERNV || PPC_PSERIES) && PPC_64K_PAGES
|
||||||
|
+ depends on PPC_POWERNV || PPC_PSERIES
|
||||||
|
default y
|
||||||
|
help
|
||||||
|
This enables support for IBM Virtual Accelerator Switchboard (VAS).
|
86
srcpkgs/linux5.14/patches/ppc64-be-elfv2.patch
Normal file
86
srcpkgs/linux5.14/patches/ppc64-be-elfv2.patch
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
This makes the Linux kernel build as ELFv2 on big endian ppc64. The upstream
|
||||||
|
doesn't seem to be interested in this but it's a small patch that is unlikely
|
||||||
|
to break/easy to remake and in worst case can always be ditched.
|
||||||
|
|
||||||
|
Using ELFv2 has some potential performance benefits and is already always used
|
||||||
|
on little endian. It requires a relatively modern toolchain, which we already
|
||||||
|
have.
|
||||||
|
|
||||||
|
Ping q66 if it does not apply.
|
||||||
|
|
||||||
|
--- a/arch/powerpc/Makefile 2020-01-05 14:40:50.395763093 +0100
|
||||||
|
+++ b/arch/powerpc/Makefile 2020-01-05 14:48:39.025251092 +0100
|
||||||
|
@@ -92,10 +92,8 @@
|
||||||
|
|
||||||
|
ifdef CONFIG_PPC64
|
||||||
|
ifndef CONFIG_CC_IS_CLANG
|
||||||
|
-cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mabi=elfv1)
|
||||||
|
-cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mcall-aixdesc)
|
||||||
|
-aflags-$(CONFIG_CPU_BIG_ENDIAN) += $(call cc-option,-mabi=elfv1)
|
||||||
|
-aflags-$(CONFIG_CPU_LITTLE_ENDIAN) += -mabi=elfv2
|
||||||
|
+cflags-y += $(call cc-option,-mabi=elfv2,$(call cc-option,-mcall-aixdesc))
|
||||||
|
+aflags-y += $(call cc-option,-mabi=elfv2,$(call cc-option,-mabi=elfv1))
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
@@ -144,14 +142,8 @@
|
||||||
|
|
||||||
|
CFLAGS-$(CONFIG_PPC64) := $(call cc-option,-mtraceback=no)
|
||||||
|
ifndef CONFIG_CC_IS_CLANG
|
||||||
|
-ifdef CONFIG_CPU_LITTLE_ENDIAN
|
||||||
|
CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mabi=elfv2,$(call cc-option,-mcall-aixdesc))
|
||||||
|
-AFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mabi=elfv2)
|
||||||
|
-else
|
||||||
|
-CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mabi=elfv1)
|
||||||
|
-CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mcall-aixdesc)
|
||||||
|
-AFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mabi=elfv1)
|
||||||
|
-endif
|
||||||
|
+AFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mabi=elfv2,$(call cc-option,-mabi=elfv1))
|
||||||
|
endif
|
||||||
|
CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mcmodel=medium,$(call cc-option,-mminimal-toc))
|
||||||
|
CFLAGS-$(CONFIG_PPC64) += $(call cc-option,-mno-pointers-to-nested-functions)
|
||||||
|
|
||||||
|
--- a/arch/powerpc/boot/Makefile
|
||||||
|
+++ b/arch/powerpc/boot/Makefile
|
||||||
|
@@ -48,8 +48,8 @@ ifdef CONFIG_CPU_BIG_ENDIAN
|
||||||
|
BOOTCFLAGS += -mbig-endian
|
||||||
|
else
|
||||||
|
BOOTCFLAGS += -mlittle-endian
|
||||||
|
-BOOTCFLAGS += $(call cc-option,-mabi=elfv2)
|
||||||
|
endif
|
||||||
|
+BOOTCFLAGS += $(call cc-option,-mabi=elfv2)
|
||||||
|
|
||||||
|
BOOTAFLAGS := -D__ASSEMBLY__ $(BOOTCFLAGS) -traditional -nostdinc
|
||||||
|
|
||||||
|
--- a/drivers/crypto/vmx/Makefile 2020-01-01 10:56:10.560965046 +0100
|
||||||
|
+++ b/drivers/crypto/vmx/Makefile 2020-01-01 10:57:05.189968856 +0100
|
||||||
|
@@ -5,7 +5,7 @@
|
||||||
|
ifeq ($(CONFIG_CPU_LITTLE_ENDIAN),y)
|
||||||
|
override flavour := linux-ppc64le
|
||||||
|
else
|
||||||
|
-override flavour := linux-ppc64
|
||||||
|
+override flavour := linux-ppc64v2
|
||||||
|
endif
|
||||||
|
|
||||||
|
quiet_cmd_perl = PERL $@
|
||||||
|
|
||||||
|
--- a/drivers/crypto/vmx/ppc-xlate.pl
|
||||||
|
+++ b/drivers/crypto/vmx/ppc-xlate.pl
|
||||||
|
@@ -40,7 +40,7 @@ my $globl = sub {
|
||||||
|
};
|
||||||
|
my $text = sub {
|
||||||
|
my $ret = ($flavour =~ /aix/) ? ".csect\t.text[PR],7" : ".text";
|
||||||
|
- $ret = ".abiversion 2\n".$ret if ($flavour =~ /linux.*64le/);
|
||||||
|
+ $ret = ".abiversion 2\n".$ret if ($flavour =~ /linux.*64(le|v2)/);
|
||||||
|
$ret;
|
||||||
|
};
|
||||||
|
my $machine = sub {
|
||||||
|
@@ -142,7 +142,7 @@ my $vmr = sub {
|
||||||
|
|
||||||
|
# Some ABIs specify vrsave, special-purpose register #256, as reserved
|
||||||
|
# for system use.
|
||||||
|
-my $no_vrsave = ($flavour =~ /linux-ppc64le/);
|
||||||
|
+my $no_vrsave = ($flavour =~ /linux-ppc64(le|v2)/);
|
||||||
|
my $mtspr = sub {
|
||||||
|
my ($f,$idx,$ra) = @_;
|
||||||
|
if ($idx == 256 && $no_vrsave) {
|
325
srcpkgs/linux5.14/template
Normal file
325
srcpkgs/linux5.14/template
Normal file
|
@ -0,0 +1,325 @@
|
||||||
|
# Template file for 'linux5.14'
|
||||||
|
pkgname=linux5.14
|
||||||
|
version=5.14.8
|
||||||
|
revision=1
|
||||||
|
wrksrc="linux-${version%.*}"
|
||||||
|
short_desc="Linux kernel and modules (${version%.*} series)"
|
||||||
|
maintainer="Érico Nogueira <ericonr@disroot.org>"
|
||||||
|
license="GPL-2.0-only"
|
||||||
|
homepage="https://www.kernel.org"
|
||||||
|
distfiles="https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-${version%.*}.tar.xz
|
||||||
|
https://cdn.kernel.org/pub/linux/kernel/v5.x/patch-${version}.xz"
|
||||||
|
checksum="7e068b5e0d26a62b10e5320b25dce57588cbbc6f781c090442138c9c9c3271b2
|
||||||
|
3ad8bc71d6fe35982e75dd60744f775159bc7f2d89fe1458ffe2f6aed03b6bd9"
|
||||||
|
skip_extraction="patch-${version}.xz"
|
||||||
|
python_version=3
|
||||||
|
|
||||||
|
# XXX Restrict archs until a proper <arch>-dotconfig is available in FILESDIR.
|
||||||
|
archs="x86_64* i686* aarch64* ppc*"
|
||||||
|
|
||||||
|
nodebug=yes # -dbg package is generated below manually
|
||||||
|
nostrip=yes
|
||||||
|
noverifyrdeps=yes
|
||||||
|
noshlibprovides=yes
|
||||||
|
preserve=yes
|
||||||
|
|
||||||
|
hostmakedepends="tar xz bc elfutils-devel flex gmp-devel kmod libmpc-devel
|
||||||
|
openssl-devel perl uboot-mkimage cpio pahole python3"
|
||||||
|
|
||||||
|
_kernver="${version}_${revision}"
|
||||||
|
triggers="kernel-hooks"
|
||||||
|
kernel_hooks_version="${_kernver}"
|
||||||
|
|
||||||
|
# These files could be modified when an external module is built.
|
||||||
|
mutable_files="
|
||||||
|
/usr/lib/modules/${_kernver}/modules.builtin.bin
|
||||||
|
/usr/lib/modules/${_kernver}/modules.builtin.alias.bin
|
||||||
|
/usr/lib/modules/${_kernver}/modules.softdep
|
||||||
|
/usr/lib/modules/${_kernver}/modules.dep
|
||||||
|
/usr/lib/modules/${_kernver}/modules.dep.bin
|
||||||
|
/usr/lib/modules/${_kernver}/modules.symbols
|
||||||
|
/usr/lib/modules/${_kernver}/modules.symbols.bin
|
||||||
|
/usr/lib/modules/${_kernver}/modules.alias
|
||||||
|
/usr/lib/modules/${_kernver}/modules.alias.bin
|
||||||
|
/usr/lib/modules/${_kernver}/modules.devname"
|
||||||
|
|
||||||
|
# reproducible build
|
||||||
|
export KBUILD_BUILD_TIMESTAMP=$(LC_ALL=C date -ud @${SOURCE_DATE_EPOCH:-0})
|
||||||
|
export KBUILD_BUILD_USER=voidlinux
|
||||||
|
export KBUILD_BUILD_HOST=voidlinux
|
||||||
|
|
||||||
|
if [ "$CROSS_BUILD" ]; then
|
||||||
|
_cross="CROSS_COMPILE=${XBPS_CROSS_TRIPLET}-"
|
||||||
|
fi
|
||||||
|
|
||||||
|
pre_patch() {
|
||||||
|
xzcat $XBPS_SRCDISTDIR/$pkgname-$version/patch-${version}.xz | patch -Np1
|
||||||
|
}
|
||||||
|
|
||||||
|
do_configure() {
|
||||||
|
# If there's a file called <arch>-dotconfig, use it to
|
||||||
|
# configure the kernel; otherwise use arch defaults and all stuff
|
||||||
|
# as modules (allmodconfig).
|
||||||
|
local arch subarch
|
||||||
|
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
i686*) arch=i386;;
|
||||||
|
x86_64*) arch=x86_64;;
|
||||||
|
arm*) arch=arm;;
|
||||||
|
aarch64*) arch=arm64;;
|
||||||
|
ppc64le*) arch=powerpc; subarch=ppc64le;;
|
||||||
|
ppc64*) arch=powerpc; subarch=ppc64;;
|
||||||
|
ppc*) arch=powerpc; subarch=ppc;;
|
||||||
|
mips*) arch=mips;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ -f ${FILESDIR}/${subarch:-$arch}-dotconfig-custom ]; then
|
||||||
|
msg_normal "Detected a custom .config file for your arch, using it.\n"
|
||||||
|
cp -f ${FILESDIR}/${subarch:-$arch}-dotconfig-custom .config
|
||||||
|
make ${makejobs} ARCH=$arch ${_cross} oldconfig
|
||||||
|
elif [ -f ${FILESDIR}/${subarch:-$arch}-dotconfig ]; then
|
||||||
|
msg_normal "Detected a .config file for your arch, using it.\n"
|
||||||
|
cp -f ${FILESDIR}/${subarch:-$arch}-dotconfig .config
|
||||||
|
make ${makejobs} ARCH=$arch ${_cross} oldconfig
|
||||||
|
fi
|
||||||
|
# Always use our revision to CONFIG_LOCALVERSION to match our pkg version.
|
||||||
|
sed -i -e "s|^\(CONFIG_LOCALVERSION=\).*|\1\"_${revision}\"|" .config
|
||||||
|
}
|
||||||
|
|
||||||
|
do_build() {
|
||||||
|
local arch _args
|
||||||
|
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
i686*) _args="bzImage modules"; arch=i386;;
|
||||||
|
x86_64*) _args="bzImage modules"; arch=x86_64;;
|
||||||
|
arm*) _args="zImage modules dtbs"; arch=arm;;
|
||||||
|
aarch64*) _args="Image modules dtbs"; arch=arm64;;
|
||||||
|
ppc*) _args="zImage modules"; arch=powerpc;;
|
||||||
|
mips*) _args="uImage modules dtbs"; arch=mips;;
|
||||||
|
esac
|
||||||
|
export LDFLAGS=
|
||||||
|
make ARCH=$arch ${_cross} ${makejobs} prepare
|
||||||
|
make ARCH=$arch ${_cross} ${makejobs} ${_args}
|
||||||
|
}
|
||||||
|
|
||||||
|
do_install() {
|
||||||
|
local arch subarch _args hdrdest
|
||||||
|
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
i686*) arch=x86; subarch=i386;;
|
||||||
|
x86_64*) arch=x86; subarch=x86_64;;
|
||||||
|
arm*) arch=arm;;
|
||||||
|
aarch64*) arch=arm64;;
|
||||||
|
ppc*) arch=powerpc;;
|
||||||
|
mips*) arch=mips;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Run depmod after compressing modules - makes depmod.sh a noop
|
||||||
|
sed -i '2iexit 0' scripts/depmod.sh
|
||||||
|
|
||||||
|
# Install kernel, firmware and modules
|
||||||
|
make ${makejobs} ARCH=${subarch:-$arch} INSTALL_MOD_PATH=${DESTDIR} ${_cross} modules_install
|
||||||
|
|
||||||
|
hdrdest=${DESTDIR}/usr/src/kernel-headers-${_kernver}
|
||||||
|
|
||||||
|
vinstall .config 644 boot config-${_kernver}
|
||||||
|
vinstall System.map 644 boot System.map-${_kernver}
|
||||||
|
|
||||||
|
case "$arch" in
|
||||||
|
x86)
|
||||||
|
vinstall arch/x86/boot/bzImage 644 boot vmlinuz-${_kernver}
|
||||||
|
;;
|
||||||
|
arm)
|
||||||
|
vinstall arch/arm/boot/zImage 644 boot
|
||||||
|
make ${makejobs} ARCH=${subarch:-$arch} INSTALL_DTBS_PATH=${DESTDIR}/boot/dtbs/dtbs-${_kernver} ${_cross} dtbs_install
|
||||||
|
;;
|
||||||
|
arm64)
|
||||||
|
vinstall arch/arm64/boot/Image 644 boot vmlinux-${_kernver}
|
||||||
|
make ${makejobs} ARCH=${subarch:-$arch} INSTALL_DTBS_PATH=${DESTDIR}/boot/dtbs/dtbs-${_kernver} ${_cross} dtbs_install
|
||||||
|
;;
|
||||||
|
powerpc)
|
||||||
|
# zImage on powerpc is useless as it won't load initramfs
|
||||||
|
# raw vmlinux is huge, and this is nostrip, so do it manually
|
||||||
|
vinstall vmlinux 644 boot vmlinux-${_kernver}
|
||||||
|
/usr/bin/$STRIP ${DESTDIR}/boot/vmlinux-${_kernver}
|
||||||
|
;;
|
||||||
|
mips)
|
||||||
|
vinstall arch/mips/boot/uImage.bin 644 boot uImage-${_kernver}
|
||||||
|
make ${makejobs} ARCH=${subarch:-$arch} INSTALL_DTBS_PATH=${DESTDIR}/boot/dtbs/dtbs-${_kernver} ${_cross} dtbs_install
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Switch to /usr.
|
||||||
|
vmkdir usr
|
||||||
|
mv ${DESTDIR}/lib ${DESTDIR}/usr
|
||||||
|
|
||||||
|
cd ${DESTDIR}/usr/lib/modules/${_kernver}
|
||||||
|
rm -f source build
|
||||||
|
ln -sf ../../../src/kernel-headers-${_kernver} build
|
||||||
|
|
||||||
|
cd ${wrksrc}
|
||||||
|
# Install required headers to build external modules
|
||||||
|
install -Dm644 Makefile ${hdrdest}/Makefile
|
||||||
|
install -Dm644 kernel/Makefile ${hdrdest}/kernel/Makefile
|
||||||
|
install -Dm644 .config ${hdrdest}/.config
|
||||||
|
for file in $(find . -name Kconfig\*); do
|
||||||
|
mkdir -p ${hdrdest}/$(dirname $file)
|
||||||
|
install -Dm644 $file ${hdrdest}/${file}
|
||||||
|
done
|
||||||
|
for file in $(find arch/${subarch:-$arch} scripts -name module.lds -o -name Kbuild.platforms -o -name Platform); do
|
||||||
|
mkdir -p ${hdrdest}/$(dirname $file)
|
||||||
|
install -Dm644 $file ${hdrdest}/${file}
|
||||||
|
done
|
||||||
|
mkdir -p ${hdrdest}/include
|
||||||
|
# Remove firmware stuff provided by the "linux-firmware" pkg.
|
||||||
|
rm -rf ${DESTDIR}/usr/lib/firmware
|
||||||
|
|
||||||
|
for i in acpi asm-generic clocksource config crypto drm generated linux vdso \
|
||||||
|
math-emu media net pcmcia scsi sound trace uapi video xen dt-bindings; do
|
||||||
|
if [ -d include/$i ]; then
|
||||||
|
cp -a include/$i ${hdrdest}/include
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
cd ${wrksrc}
|
||||||
|
mkdir -p ${hdrdest}/arch/${arch}
|
||||||
|
cp -a arch/${arch}/include ${hdrdest}/arch/${arch}
|
||||||
|
|
||||||
|
# Remove helper binaries built for host,
|
||||||
|
# if generated files from the scripts/ directory need to be included,
|
||||||
|
# they need to be copied to ${hdrdest} before this step
|
||||||
|
if [ "$CROSS_BUILD" ]; then
|
||||||
|
make ${makejobs} ARCH=${subarch:-$arch} ${_cross} _mrproper_scripts
|
||||||
|
# remove host specific objects as well
|
||||||
|
find scripts -name '*.o' -delete
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Copy files necessary for later builds, like nvidia and vmware
|
||||||
|
cp Module.symvers ${hdrdest}
|
||||||
|
cp -a scripts ${hdrdest}
|
||||||
|
mkdir -p ${hdrdest}/security/selinux
|
||||||
|
cp -a security/selinux/include ${hdrdest}/security/selinux
|
||||||
|
mkdir -p ${hdrdest}/tools/include
|
||||||
|
cp -a tools/include/tools ${hdrdest}/tools/include
|
||||||
|
|
||||||
|
mkdir -p ${hdrdest}/arch/${arch}/kernel
|
||||||
|
cp arch/${arch}/Makefile ${hdrdest}/arch/${arch}
|
||||||
|
if [ "$subarch" = "i386" ]; then
|
||||||
|
mkdir -p ${hdrdest}/arch/x86
|
||||||
|
cp arch/x86/Makefile_32.cpu ${hdrdest}/arch/x86
|
||||||
|
fi
|
||||||
|
if [ "$arch" = "x86" ]; then
|
||||||
|
mkdir -p ${hdrdest}/arch/x86/kernel
|
||||||
|
cp arch/x86/kernel/asm-offsets.s ${hdrdest}/arch/x86/kernel
|
||||||
|
elif [ "$arch" = "arm64" ]; then
|
||||||
|
mkdir -p ${hdrdest}/arch/arm64/kernel
|
||||||
|
cp -a arch/arm64/kernel/vdso ${hdrdest}/arch/arm64/kernel/
|
||||||
|
fi
|
||||||
|
|
||||||
|
# add headers for lirc package
|
||||||
|
# pci
|
||||||
|
for i in bt8xx cx88 saa7134; do
|
||||||
|
mkdir -p ${hdrdest}/drivers/media/pci/${i}
|
||||||
|
cp -a drivers/media/pci/${i}/*.h ${hdrdest}/drivers/media/pci/${i}
|
||||||
|
done
|
||||||
|
# usb
|
||||||
|
for i in cpia2 em28xx pwc; do
|
||||||
|
mkdir -p ${hdrdest}/drivers/media/usb/${i}
|
||||||
|
cp -a drivers/media/usb/${i}/*.h ${hdrdest}/drivers/media/usb/${i}
|
||||||
|
done
|
||||||
|
# i2c
|
||||||
|
mkdir -p ${hdrdest}/drivers/media/i2c
|
||||||
|
cp drivers/media/i2c/*.h ${hdrdest}/drivers/media/i2c
|
||||||
|
for i in cx25840; do
|
||||||
|
mkdir -p ${hdrdest}/drivers/media/i2c/${i}
|
||||||
|
cp -a drivers/media/i2c/${i}/*.h ${hdrdest}/drivers/media/i2c/${i}
|
||||||
|
done
|
||||||
|
|
||||||
|
# Add md headers
|
||||||
|
mkdir -p ${hdrdest}/drivers/md
|
||||||
|
cp drivers/md/*.h ${hdrdest}/drivers/md
|
||||||
|
|
||||||
|
# Add inotify.h
|
||||||
|
mkdir -p ${hdrdest}/include/linux
|
||||||
|
cp include/linux/inotify.h ${hdrdest}/include/linux
|
||||||
|
|
||||||
|
# Add wireless headers
|
||||||
|
mkdir -p ${hdrdest}/net/mac80211/
|
||||||
|
cp net/mac80211/*.h ${hdrdest}/net/mac80211
|
||||||
|
|
||||||
|
# add dvb headers for http://mcentral.de/hg/~mrec/em28xx-new
|
||||||
|
mkdir -p ${hdrdest}/drivers/media/dvb-frontends
|
||||||
|
cp drivers/media/dvb-frontends/lgdt330x.h \
|
||||||
|
${hdrdest}/drivers/media/dvb-frontends/
|
||||||
|
cp drivers/media/i2c/msp3400-driver.h ${hdrdest}/drivers/media/i2c/
|
||||||
|
|
||||||
|
# add dvb headers
|
||||||
|
mkdir -p ${hdrdest}/drivers/media/usb/dvb-usb
|
||||||
|
cp drivers/media/usb/dvb-usb/*.h ${hdrdest}/drivers/media/usb/dvb-usb/
|
||||||
|
mkdir -p ${hdrdest}/drivers/media/dvb-frontends
|
||||||
|
cp drivers/media/dvb-frontends/*.h ${hdrdest}/drivers/media/dvb-frontends/
|
||||||
|
mkdir -p ${hdrdest}/drivers/media/tuners
|
||||||
|
cp drivers/media/tuners/*.h ${hdrdest}/drivers/media/tuners/
|
||||||
|
|
||||||
|
# Add xfs and shmem for aufs building
|
||||||
|
mkdir -p ${hdrdest}/fs/xfs/libxfs
|
||||||
|
mkdir -p ${hdrdest}/mm
|
||||||
|
cp fs/xfs/libxfs/xfs_sb.h ${hdrdest}/fs/xfs/libxfs/xfs_sb.h
|
||||||
|
|
||||||
|
# Add objtool binary, needed to build external modules with dkms
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
x86_64*)
|
||||||
|
mkdir -p ${hdrdest}/tools/objtool
|
||||||
|
cp tools/objtool/objtool ${hdrdest}/tools/objtool
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Remove unneeded architectures
|
||||||
|
case "$arch" in
|
||||||
|
i386|x86_64) _args="arm* m* p*";;
|
||||||
|
arm|arm64) _args="x86* m* p*";;
|
||||||
|
powerpc) _args="arm* m* x86* parisc";;
|
||||||
|
mips) _args="arm* x86* p*";;
|
||||||
|
esac
|
||||||
|
for arch in alpha avr32 blackfin cris frv h8300 \
|
||||||
|
ia64 s* um v850 xtensa ${_args}; do
|
||||||
|
rm -rf ${hdrdest}/arch/${arch}
|
||||||
|
done
|
||||||
|
# Keep arch/x86/ras/Kconfig as it is needed by drivers/ras/Kconfig
|
||||||
|
mkdir -p ${hdrdest}/arch/x86/ras
|
||||||
|
cp -a arch/x86/ras/Kconfig ${hdrdest}/arch/x86/ras/Kconfig
|
||||||
|
|
||||||
|
# Extract debugging symbols and compress modules
|
||||||
|
msg_normal "$pkgver: extracting debug info and compressing modules, please wait...\n"
|
||||||
|
install -Dm644 vmlinux ${DESTDIR}/usr/lib/debug/boot/vmlinux-${_kernver}
|
||||||
|
(
|
||||||
|
cd ${DESTDIR}
|
||||||
|
export DESTDIR
|
||||||
|
find ./ -name '*.ko' -print0 | \
|
||||||
|
xargs -0r -n1 -P ${XBPS_MAKEJOBS} ${FILESDIR}/mv-debug
|
||||||
|
)
|
||||||
|
# ... and run depmod again.
|
||||||
|
depmod -b ${DESTDIR}/usr -F System.map ${_kernver}
|
||||||
|
}
|
||||||
|
linux5.14-headers_package() {
|
||||||
|
preserve=yes
|
||||||
|
nostrip=yes
|
||||||
|
noshlibprovides=yes
|
||||||
|
short_desc+=" - source headers for 3rd party modules"
|
||||||
|
pkg_install() {
|
||||||
|
vmove usr/src
|
||||||
|
vmove usr/lib/modules/${_kernver}/build
|
||||||
|
}
|
||||||
|
}
|
||||||
|
linux5.14-dbg_package() {
|
||||||
|
preserve=yes
|
||||||
|
nostrip=yes
|
||||||
|
noverifyrdeps=yes
|
||||||
|
noshlibprovides=yes
|
||||||
|
repository=debug
|
||||||
|
short_desc+=" - debugging symbols"
|
||||||
|
pkg_install() {
|
||||||
|
vmove usr/lib/debug
|
||||||
|
vmove "boot/System.map-${_kernver}"
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue