PVE linux kernel for ThunderX CPU
Find a file
Antoine Martin 7c92016131
All checks were successful
Kernel Release / Build (push) Successful in 1h20m34s
Kernel Release / release-deploy (push) Successful in 46s
Remove failing patch
2025-01-20 00:14:58 -05:00
.forgejo/workflows Install pkg-config dependency 2024-11-08 18:22:48 -05:00
.github/workflows forgejo: enable build.yml 2024-10-07 07:32:50 -04:00
debian Remove failing patch 2025-01-20 00:14:58 -05:00
linux@5748450da0 Update kernel to Ubuntu-6.8.0-53.54 2025-01-19 23:49:59 -05:00
scripts new file: scripts/clean.sh 2023-08-02 11:29:21 +08:00
zfs@bc06d8164b Update zfs to 2.3.0 2025-01-19 23:51:50 -05:00
.gitignore Ignore build artifacts 2020-09-17 17:11:23 +02:00
.gitmodules Fix linux submodule URL 2024-10-07 08:05:17 -04:00
autobuild.sh Update to Linux 6.5.11 2023-11-20 11:02:08 +08:00
README.md Update readme 2025-01-20 00:14:32 -05:00

Proxmox Thunderx kernels

Custom Linux kernels for Proxmox VE arm64 ThunderX (CN88xx) system based on Ubuntu linux

Available Versions

  1. Linux 5.4 > branch:v5.4
  2. Linux 5.15 -> branch:v5.15
  3. Linux 6.5 -> branch:v6.5
  4. Linux 6.8 -> main

Installation

add arm64 kernel repo.

curl https://ayakael.net/api/packages/forge/debian/repository.key -o /etc/apt/keyrings/forgejo-forge.asc
echo "deb [signed-by=/etc/apt/keyrings/forgejo-forge.asc] https://ayakael.net/api/packages/forge/debian bookworm main" | tee -a /etc/apt/sources.list.d/forgejo.list
apt update
apt search pve-kernel
apt install pve-kernel-xxxx

Building manually

You may also choose to manually build one of these kernels yourself.

Prerequisites

Make sure you have at least 10 GB of free space available and have the following packages installed:

apt install devscripts debhelper equivs git

Obtaining the source

Obtain the source code as follows:

git https://ayakael.net/forge/pve-kernel-thunderx
cd pve-kernel-thunderx

Then, select the branch of your likings (e.g. v5.15) and update the submodules:

git checkout master
git submodule update --init --depth=1 --recursive linux
git submodule update --init --recursive

Building

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:

  1. PVE_KERNEL_CC
    The compiler to use for the kernel build.
  2. 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.

Removal

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.8* pve-headers-6.8*

Contributing

Questions, suggestions and contributions are welcome and appreciated! You can contribute in various meaningful ways:

  • Report a bug by email dev@ayakael.net
  • Propose new patches and flavors for the project.
  • Contribute improvements to the documentation.
  • Provide feedback about how we can improve the project.