Custom Linux kernels for Proxmox VE arm64
- Linux 6.2 ->branch:v6.2
- Linux 6.1 -> master
- Linux 5.15 -> branch:v5.15
add arm64 kernel repo.
echo "deb https://mirrors.apqa.cn/proxmox/debian/kernel sid port" > /etc/apt/sources.list.d/pve-arm64-kernel.list
apt update
apt search pve-kernel
apt install pve-kernel-xxxx
You may also choose to manually build one of these kernels yourself.
Make sure you have at least 10 GB of free space available and have the following packages installed:
apt install devscripts debhelper equivs git
Obtain the source code as follows:
git https://github.com/jiangcuo/pve-arm64-kernel
cd pve-arm64-kernel
Then, select the branch of your likings (e.g. v6.1
) and update the submodules:
git checkout master
git submodule update --init --depth=1 --recursive linux
git submodule update --init --recursive
First, generate the Debian control file for your kernel by running the following in your command prompt:
debian/rules debian/control
Before we build, make sure you have installed the build dependencies:
sudo mk-build-deps -i
merge your confile,if your kernel config is /boot/config-5.10.167-edge
,do
cat /boot/config-5.10.167-edge >> debian/config/config.pve
Invoking the following command will build the kernel and its associated packages:
debuild -ePVE* --jobs=auto -b -uc -us
The Makefile provides several environmental variables to control:
PVE_KERNEL_CC
The compiler to use for the kernel build.PVE_KERNEL_CFLAGS
The compilation options to use for the kernel build. Use this variable to specify the optimization level or micro architecture to build for.
Kernel options may be controlled from debian/config/config.pve. To build with additional patches, you may add them to the debian/patches/pve directory and update the series file accordingly.
Use apt
to remove individual kernel packages from your system. If you want
to remove all packages from a particular kernel release, use the following
command:
apt remove pve-kernel-6.1* pve-headers-6.1*
Questions, suggestions and contributions are welcome and appreciated! You can contribute in various meaningful ways:
- Report a bug through Github issues.
- Propose new patches and flavors for the project.
- Contribute improvements to the documentation.
- Provide feedback about how we can improve the project.