pve-kernel-thunderx/README.md

109 lines
3.8 KiB
Markdown
Raw Normal View History

# Proxmox Edge kernels
Custom Linux kernels for Proxmox VE 7.
2020-07-06 21:00:35 +00:00
2021-11-28 13:31:24 +00:00
#### Available Versions
1. Linux 6.0
2. Linux 5.19 **[EOL]**
2020-07-06 21:00:35 +00:00
2021-11-28 13:31:24 +00:00
Older builds are still available at the [Releases](https://github.com/fabianishere/pve-edge-kernel/releases) page.
2020-07-06 21:00:35 +00:00
## Installation
[![Hosted By: Cloudsmith](https://img.shields.io/badge/OSS%20hosting%20by-cloudsmith-blue?logo=cloudsmith&style=flat-square)](https://cloudsmith.com)
First, set up our Debian repository on your Proxmox installation:
2021-10-20 07:41:44 +00:00
1. **Add the repository's GPG key:**
```bash
curl -1sLf 'https://dl.cloudsmith.io/public/pve-edge/kernel/gpg.8EC01CCF309B98E7.key' | gpg --dearmor -o /usr/share/keyrings/pve-edge-kernel.gpg
2021-10-20 07:41:44 +00:00
```
2. **Set up the `pve-edge-kernel` repository:**
```bash
echo "deb [signed-by=/usr/share/keyrings/pve-edge-kernel.gpg] https://dl.cloudsmith.io/public/pve-edge/kernel/deb/debian bullseye main" > /etc/apt/sources.list.d/pve-edge-kernel.list
2021-10-20 07:41:44 +00:00
```
3. **Install a kernel package:**
```bash
apt update
apt install pve-kernel-6.0-edge
2021-10-20 07:41:44 +00:00
```
Package repository hosting is graciously provided by [Cloudsmith](https://cloudsmith.com).
Cloudsmith is the only fully hosted, cloud-native, universal package management solution, that
enables your organization to create, store and share packages in any format, to any place, with total
confidence.
### Manual
Alternatively, you may manually install the kernels. Select from the [Releases](https://github.com/fabianishere/pve-edge-kernel/releases)
page the kernel version you want to install and download the appropriate Debian package.
Then, you can install the package as follows:
2020-07-06 21:00:35 +00:00
```sh
apt install ./pve-kernel-VERSION_amd64.deb
2020-07-06 21:00:35 +00:00
```
## 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:
```bash
apt install devscripts debhelper equivs git
```
#### Obtaining the source
Obtain the source code as follows:
```bash
git clone https://github.com/fabianishere/pve-edge-kernel
cd pve-edge-kernel
```
Then, select the branch of your likings (e.g. `v6.0.x`) and update the submodules:
```bash
git checkout v6.0.x
2021-03-15 19:34:24 +00:00
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:
```bash
debian/rules debian/control
```
Before we build, make sure you have installed the build dependencies:
```bash
sudo mk-build-deps -i
```
Invoking the following command will build the kernel and its associated packages:
```bash
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](debian/config/config.pve). To build with
2021-03-28 19:51:08 +00:00
additional patches, you may add them to the [debian/patches/pve](debian/patches/pve) directory
and update the [series](debian/patches/series.linux) 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:
```bash
apt remove pve-kernel-6.0*edge pve-headers-6.0*edge
```
## Contributing
Questions, suggestions and contributions are welcome and appreciated!
You can contribute in various meaningful ways:
* Report a bug through [Github issues](https://github.com/fabianishere/pve-edge-kernel/issues).
* Propose new patches and flavors for the project.
* Contribute improvements to the documentation.
* Provide feedback about how we can improve the project.