rpi-kernel: split into rpi, rpi2, rpi3
Until now, rpi-kernel served rpi0/rpi1 + rpi2 + rpi3 all at once. The
variants were solely distiguished by the target architecture; it was
nice while it lasted, but now that rpi4 is on its way, we need to split
things up a little.
With the split,
* rpi-kernel serves rpi0 + rpi1, armv6l* only
* rpi2-kernel serves rpi2, armv7l* only
* rpi3-kernel serves rpi3, aarch64* only
To help migrate existing devices to the new kernel packages, rpi-kernel
will be an empty mega package for !armv6l* and depend on rpi2-kernel or
rpi3-kernel (depending on target architecture) for the foreseeable
future, thus resolving like this:
* rpi-kernel -> rpi2-kernel (armv7l*)
* rpi-kernel -> rpi3-kernel (aarch64*)
Relates to: #29139
Acked-by: Duncaen <duncaen@voidlinux.org>
2021-02-22 20:35:00 +00:00
|
|
|
# Template file for 'rpi2-kernel'
|
2021-08-04 14:42:39 +00:00
|
|
|
# See rpi-kernel for version policy
|
rpi-kernel: split into rpi, rpi2, rpi3
Until now, rpi-kernel served rpi0/rpi1 + rpi2 + rpi3 all at once. The
variants were solely distiguished by the target architecture; it was
nice while it lasted, but now that rpi4 is on its way, we need to split
things up a little.
With the split,
* rpi-kernel serves rpi0 + rpi1, armv6l* only
* rpi2-kernel serves rpi2, armv7l* only
* rpi3-kernel serves rpi3, aarch64* only
To help migrate existing devices to the new kernel packages, rpi-kernel
will be an empty mega package for !armv6l* and depend on rpi2-kernel or
rpi3-kernel (depending on target architecture) for the foreseeable
future, thus resolving like this:
* rpi-kernel -> rpi2-kernel (armv7l*)
* rpi-kernel -> rpi3-kernel (aarch64*)
Relates to: #29139
Acked-by: Duncaen <duncaen@voidlinux.org>
2021-02-22 20:35:00 +00:00
|
|
|
|
2021-08-04 14:42:39 +00:00
|
|
|
_githash="86729e78125d4f3d203457940feee8bc97b11f6c"
|
rpi-kernel: split into rpi, rpi2, rpi3
Until now, rpi-kernel served rpi0/rpi1 + rpi2 + rpi3 all at once. The
variants were solely distiguished by the target architecture; it was
nice while it lasted, but now that rpi4 is on its way, we need to split
things up a little.
With the split,
* rpi-kernel serves rpi0 + rpi1, armv6l* only
* rpi2-kernel serves rpi2, armv7l* only
* rpi3-kernel serves rpi3, aarch64* only
To help migrate existing devices to the new kernel packages, rpi-kernel
will be an empty mega package for !armv6l* and depend on rpi2-kernel or
rpi3-kernel (depending on target architecture) for the foreseeable
future, thus resolving like this:
* rpi-kernel -> rpi2-kernel (armv7l*)
* rpi-kernel -> rpi3-kernel (aarch64*)
Relates to: #29139
Acked-by: Duncaen <duncaen@voidlinux.org>
2021-02-22 20:35:00 +00:00
|
|
|
_gitshort="${_githash:0:7}"
|
|
|
|
|
|
|
|
pkgname=rpi2-kernel
|
2021-08-04 14:42:39 +00:00
|
|
|
version=5.10.52
|
|
|
|
revision=1
|
rpi-kernel: split into rpi, rpi2, rpi3
Until now, rpi-kernel served rpi0/rpi1 + rpi2 + rpi3 all at once. The
variants were solely distiguished by the target architecture; it was
nice while it lasted, but now that rpi4 is on its way, we need to split
things up a little.
With the split,
* rpi-kernel serves rpi0 + rpi1, armv6l* only
* rpi2-kernel serves rpi2, armv7l* only
* rpi3-kernel serves rpi3, aarch64* only
To help migrate existing devices to the new kernel packages, rpi-kernel
will be an empty mega package for !armv6l* and depend on rpi2-kernel or
rpi3-kernel (depending on target architecture) for the foreseeable
future, thus resolving like this:
* rpi-kernel -> rpi2-kernel (armv7l*)
* rpi-kernel -> rpi3-kernel (aarch64*)
Relates to: #29139
Acked-by: Duncaen <duncaen@voidlinux.org>
2021-02-22 20:35:00 +00:00
|
|
|
archs="armv7l*"
|
|
|
|
wrksrc="linux-${_githash}"
|
|
|
|
hostmakedepends="perl kmod uboot-mkimage openssl-devel bc bison flex"
|
|
|
|
makedepends="ncurses-devel"
|
|
|
|
maintainer="Piraty <piraty1@inbox.ru>"
|
|
|
|
homepage="http://www.kernel.org"
|
|
|
|
license="GPL-2.0-only"
|
|
|
|
short_desc="Linux kernel for Raspberry Pi 2 (${version%.*} series [git ${_gitshort}])"
|
|
|
|
distfiles="https://github.com/raspberrypi/linux/archive/${_githash}.tar.gz"
|
2021-08-04 14:42:39 +00:00
|
|
|
checksum=a25a7dfce4c2ca5bdca39ddab5e43539d9b04900b0dbefe19f4f9b053e59968c
|
rpi-kernel: split into rpi, rpi2, rpi3
Until now, rpi-kernel served rpi0/rpi1 + rpi2 + rpi3 all at once. The
variants were solely distiguished by the target architecture; it was
nice while it lasted, but now that rpi4 is on its way, we need to split
things up a little.
With the split,
* rpi-kernel serves rpi0 + rpi1, armv6l* only
* rpi2-kernel serves rpi2, armv7l* only
* rpi3-kernel serves rpi3, aarch64* only
To help migrate existing devices to the new kernel packages, rpi-kernel
will be an empty mega package for !armv6l* and depend on rpi2-kernel or
rpi3-kernel (depending on target architecture) for the foreseeable
future, thus resolving like this:
* rpi-kernel -> rpi2-kernel (armv7l*)
* rpi-kernel -> rpi3-kernel (aarch64*)
Relates to: #29139
Acked-by: Duncaen <duncaen@voidlinux.org>
2021-02-22 20:35:00 +00:00
|
|
|
python_version=3
|
|
|
|
|
|
|
|
_kernver="${version}_${revision}"
|
|
|
|
|
|
|
|
nodebug=yes
|
|
|
|
nostrip=yes
|
|
|
|
noverifyrdeps=yes
|
|
|
|
noshlibprovides=yes
|
|
|
|
|
|
|
|
triggers="kernel-hooks"
|
|
|
|
# These files could be modified when an external module is built.
|
|
|
|
mutable_files="
|
|
|
|
/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"
|
|
|
|
|
|
|
|
_arch=
|
|
|
|
case "$XBPS_TARGET_MACHINE" in
|
|
|
|
arm*) _arch=arm ;;
|
|
|
|
aarch64*) _arch=arm64 ;;
|
|
|
|
esac
|
|
|
|
_cross=
|
|
|
|
if [ "$CROSS_BUILD" ]; then
|
|
|
|
_cross="CROSS_COMPILE=${XBPS_CROSS_TRIPLET}-"
|
|
|
|
fi
|
|
|
|
|
|
|
|
pre_configure() {
|
|
|
|
# Remove .git directory, otherwise scripts/setkernelversion.sh
|
|
|
|
# modifies KERNELRELEASE and appends + to it.
|
|
|
|
rm -rf .git
|
|
|
|
}
|
|
|
|
do_configure() {
|
|
|
|
local target defconfig
|
|
|
|
|
|
|
|
# Use upstream's default configuration, no need to maintain ours.
|
|
|
|
case "$XBPS_TARGET_MACHINE" in
|
|
|
|
armv7l*)
|
|
|
|
target=bcm2709_defconfig
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
defconfig="arch/${_arch}/configs/${target}"
|
|
|
|
echo "CONFIG_CONNECTOR=y" >> "$defconfig"
|
|
|
|
echo "CONFIG_PROC_EVENTS=y" >> "$defconfig"
|
|
|
|
echo "CONFIG_F2FS_FS_SECURITY=y" >> "$defconfig"
|
|
|
|
echo "CONFIG_CGROUP_PIDS=y" >> "$defconfig"
|
|
|
|
|
|
|
|
# IR Remote Support
|
|
|
|
echo "CONFIG_RC_CORE=y" >> "$defconfig"
|
|
|
|
echo "CONFIG_LIRC=y" >> "$defconfig"
|
|
|
|
echo "CONFIG_RC_DECODERS=y" >> "$defconfig"
|
|
|
|
echo "CONFIG_RC_DEVICES=y" >> "$defconfig"
|
|
|
|
echo "CONFIG_IR_RC6_DECODER=m" >> "$defconfig"
|
|
|
|
echo "CONFIG_IR_MCEUSB=m" >> "$defconfig"
|
|
|
|
|
|
|
|
# HID Controllers
|
|
|
|
echo "CONFIG_HID_STEAM=y" >> "$defconfig"
|
|
|
|
|
|
|
|
# LXD 4.2+ support
|
|
|
|
echo "CONFIG_BRIDGE_VLAN_FILTERING=y" >> "$defconfig"
|
|
|
|
|
|
|
|
make ${makejobs} ${_cross} ARCH=${_arch} ${target}
|
|
|
|
|
|
|
|
# Always use our revision to CONFIG_LOCALVERSION to match our pkg version.
|
|
|
|
vsed -i -e "s|^\(CONFIG_LOCALVERSION=\).*|\1\"_${revision}\"|" .config
|
|
|
|
}
|
|
|
|
do_build() {
|
|
|
|
local target
|
|
|
|
|
|
|
|
case "$XBPS_TARGET_MACHINE" in
|
|
|
|
arm*)
|
|
|
|
target="zImage modules dtbs"
|
|
|
|
;;
|
|
|
|
aarch64*)
|
|
|
|
target="Image modules dtbs"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
make ${makejobs} ${_cross} ARCH=${_arch} prepare
|
|
|
|
make ${makejobs} ${_cross} ARCH=${_arch} ${target}
|
|
|
|
}
|
|
|
|
do_install() {
|
|
|
|
local hdrdest
|
|
|
|
|
|
|
|
# Run depmod after compressing modules.
|
|
|
|
sed -i '2iexit 0' scripts/depmod.sh
|
|
|
|
|
|
|
|
# Install kernel, firmware and modules
|
|
|
|
make ${makejobs} ARCH=${_arch} INSTALL_MOD_PATH=${DESTDIR} modules_install
|
|
|
|
|
|
|
|
# Install device tree blobs
|
|
|
|
make ${makejobs} ARCH=${_arch} INSTALL_DTBS_PATH=${DESTDIR}/boot dtbs_install
|
|
|
|
|
|
|
|
# Generate kernel.img and install it to destdir.
|
|
|
|
vmkdir boot
|
|
|
|
cp arch/arm/boot/zImage ${DESTDIR}/boot/kernel7.img
|
|
|
|
|
|
|
|
hdrdest=${DESTDIR}/usr/src/${sourcepkg}-headers-${_kernver}
|
|
|
|
|
|
|
|
# Switch to /usr.
|
|
|
|
vmkdir usr
|
|
|
|
mv ${DESTDIR}/lib ${DESTDIR}/usr
|
|
|
|
|
|
|
|
cd ${DESTDIR}/usr/lib/modules/${_kernver}
|
|
|
|
rm -f source build
|
|
|
|
ln -sf ../../../src/${sourcepkg}-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
|
2021-08-04 14:42:39 +00:00
|
|
|
for file in $(find arch/${_arch} scripts -name module.lds -o -name Kbuild.platforms -o -name Platform); do
|
rpi-kernel: split into rpi, rpi2, rpi3
Until now, rpi-kernel served rpi0/rpi1 + rpi2 + rpi3 all at once. The
variants were solely distiguished by the target architecture; it was
nice while it lasted, but now that rpi4 is on its way, we need to split
things up a little.
With the split,
* rpi-kernel serves rpi0 + rpi1, armv6l* only
* rpi2-kernel serves rpi2, armv7l* only
* rpi3-kernel serves rpi3, aarch64* only
To help migrate existing devices to the new kernel packages, rpi-kernel
will be an empty mega package for !armv6l* and depend on rpi2-kernel or
rpi3-kernel (depending on target architecture) for the foreseeable
future, thus resolving like this:
* rpi-kernel -> rpi2-kernel (armv7l*)
* rpi-kernel -> rpi3-kernel (aarch64*)
Relates to: #29139
Acked-by: Duncaen <duncaen@voidlinux.org>
2021-02-22 20:35:00 +00:00
|
|
|
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 \
|
2021-08-04 14:42:39 +00:00
|
|
|
math-emu media net pcmcia scsi sound trace uapi vdso video xen; do
|
rpi-kernel: split into rpi, rpi2, rpi3
Until now, rpi-kernel served rpi0/rpi1 + rpi2 + rpi3 all at once. The
variants were solely distiguished by the target architecture; it was
nice while it lasted, but now that rpi4 is on its way, we need to split
things up a little.
With the split,
* rpi-kernel serves rpi0 + rpi1, armv6l* only
* rpi2-kernel serves rpi2, armv7l* only
* rpi3-kernel serves rpi3, aarch64* only
To help migrate existing devices to the new kernel packages, rpi-kernel
will be an empty mega package for !armv6l* and depend on rpi2-kernel or
rpi3-kernel (depending on target architecture) for the foreseeable
future, thus resolving like this:
* rpi-kernel -> rpi2-kernel (armv7l*)
* rpi-kernel -> rpi3-kernel (aarch64*)
Relates to: #29139
Acked-by: Duncaen <duncaen@voidlinux.org>
2021-02-22 20:35:00 +00:00
|
|
|
[ -d include/$i ] && cp -a include/$i ${hdrdest}/include
|
|
|
|
done
|
|
|
|
|
|
|
|
cd ${wrksrc}
|
|
|
|
# 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=${_arch} _mrproper_scripts
|
|
|
|
# remove host specific objects as well
|
|
|
|
find scripts -name '*.o' -delete
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Copy files necessary for later builds.
|
|
|
|
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
|
|
|
|
if [ -d "arch/${_arch}/tools" ]; then
|
|
|
|
cp -a arch/${_arch}/tools ${hdrdest}/arch/${_arch}
|
|
|
|
fi
|
|
|
|
|
|
|
|
# copy arch includes for external modules
|
|
|
|
mkdir -p ${hdrdest}/arch/${_arch}
|
|
|
|
cp -a arch/${_arch}/include ${hdrdest}/arch/${_arch}
|
|
|
|
|
|
|
|
mkdir -p ${hdrdest}/arch/${_arch}/kernel
|
|
|
|
cp arch/${_arch}/Makefile ${hdrdest}/arch/${_arch}
|
|
|
|
cp arch/${_arch}/kernel/asm-offsets.s ${hdrdest}/arch/${_arch}/kernel
|
|
|
|
if [ "$_arch" = "arm64" ] ; then
|
|
|
|
cp -a arch/${_arch}/kernel/vdso ${hdrdest}/arch/${_arch}/kernel/
|
|
|
|
fi
|
|
|
|
|
|
|
|
# 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 external modules
|
|
|
|
mkdir -p ${hdrdest}/include/config/dvb/
|
|
|
|
cp include/config/dvb/*.h ${hdrdest}/include/config/dvb/
|
|
|
|
|
|
|
|
# Remove unneeded architectures
|
|
|
|
# (save the correct one + Kconfig and delete all others)
|
|
|
|
mkdir -p arch-backup
|
|
|
|
cp -r ${hdrdest}/arch/${_arch} ${hdrdest}/arch/Kconfig arch-backup/
|
|
|
|
rm -rf ${hdrdest}/arch
|
|
|
|
mv arch-backup ${hdrdest}/arch
|
|
|
|
# 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
|
|
|
|
|
|
|
|
# Compress all modules with xz to save a few MBs.
|
|
|
|
msg_normal "$pkgver: compressing kernel modules with gzip, please wait...\n"
|
|
|
|
find ${DESTDIR} -name '*.ko' | xargs -n1 -P0 gzip -9
|
|
|
|
|
|
|
|
# ... and run depmod again.
|
|
|
|
depmod -b ${DESTDIR}/usr -F System.map ${_kernver}
|
|
|
|
}
|
|
|
|
|
|
|
|
rpi2-kernel-headers_package() {
|
|
|
|
nostrip=yes
|
|
|
|
noverifyrdeps=yes
|
|
|
|
noshlibprovides=yes
|
|
|
|
short_desc="${short_desc/kernel/kernel headers}"
|
|
|
|
pkg_install() {
|
|
|
|
vmove usr/src
|
|
|
|
vmove usr/lib/modules/${_kernver}/build
|
|
|
|
}
|
|
|
|
}
|