Go based buildbot to build official Archlinux repos with x86-64 feature levels, -O3 and LTO
Go to file
2023-12-16 12:39:15 +01:00
ent updated deps; regen ent 2023-11-20 16:18:03 +01:00
tpl fixed excess space in tooltip 2023-03-15 15:17:39 +01:00
.gitignore rename config to dist 2021-11-04 13:01:18 +01:00
.golangci.yaml code cleanup; switch to rm_chroot to remove builddir; new linter conf 2023-06-21 12:54:45 +02:00
alhp.service minor fixes 2022-08-14 16:06:59 +02:00
buildmanager.go add debug package cleanup to housekeeping 2023-12-16 12:39:15 +01:00
config_dist.yaml retry regardless of error, add retry limit 2023-05-23 21:51:37 +02:00
flags.yaml Fix firefox failing build (#217) 2023-11-01 11:34:05 +01:00
go.mod updated deps and downgraded to yaml.v2 2023-12-15 18:54:57 +01:00
go.sum updated deps and downgraded to yaml.v2 2023-12-15 18:54:57 +01:00
housekeeping.go add debug package cleanup to housekeeping 2023-12-16 12:39:15 +01:00
LICENSE added license and service file 2021-06-12 20:09:08 +02:00
main.go updated deps and downgraded to yaml.v2 2023-12-15 18:54:57 +01:00
package.go code cleanup, new linter conf 2023-06-14 15:56:26 +02:00
proto_package_test.go code cleanup, new linter conf 2023-06-14 15:56:26 +02:00
proto_package.go added detection for already build packages waiting to be moved 2023-12-10 14:51:53 +01:00
README.md added package cache clear to level change instructions 2023-12-12 22:23:46 +01:00
rm_chroot.py followup fixes for new weighted build-queue 2022-02-19 19:39:48 +01:00
utils.go updated deps and downgraded to yaml.v2 2023-12-15 18:54:57 +01:00

ALHP

Buildbot for Archlinux-based repos build with different x86-64 feature levels, -O3 and LTO.

📢 x86-64-v4 repos just released. If your CPU supports v4, you can try them out.

⚠️ NVIDIA graphic users using the proprietary driver is highly recommended reading the FAQ about Linux kernel modules ⚠️



Quickstart

1. Check your system for support

Important

: Before you enable any of these repos, check if your system supports the feature level you want to enable (e.g. x86-64-v3). If you don't check beforehand, you might be unable to boot your system anymore and need to downgrade any package that you may have upgraded.

Check which feature-levels your CPU supports with

/lib/ld-linux-x86-64.so.2 --help

Example output snippet for a system supporting up to x86-64-v3:

Subdirectories of glibc-hwcaps directories, in priority order:
  x86-64-v4
  x86-64-v3 (supported, searched)
  x86-64-v2 (supported, searched)

2. Install keyring & mirrorlist

Install alhp-keyring and alhp-mirrorlist from AUR.

Example with yay:

yay -S alhp-keyring alhp-mirrorlist

alhp-keyring provides the current signing keys used by ALHP, alhp-mirrorlist a selection of mirrors.

3. Choose a mirror (optional)

Edit /etc/pacman.d/alhp-mirrorlist and comment out/in mirrors you want to have enabled/disabled. Per default selected is a cloudflare-based mirror which should provide decent speed worldwide.

Note: Only alhp.dev is hosted by ALHP directly. If you have problems with a mirror, open an issue at the mirrorlist repo.

4. Modify /etc/pacman.conf

Add the appropriate repos above your regular Archlinux repos.

Example for x86-64-v3:

[core-x86-64-v3]
Include = /etc/pacman.d/alhp-mirrorlist

[extra-x86-64-v3]
Include = /etc/pacman.d/alhp-mirrorlist

[core]
Include = /etc/pacman.d/mirrorlist

[extra]
Include = /etc/pacman.d/mirrorlist

# if you need [multilib] support
[multilib-x86-64-v3]
Include = /etc/pacman.d/alhp-mirrorlist

[multilib]
Include = /etc/pacman.d/mirrorlist

Replace x86-64-v3 with the x86-64 feature level you want to enable.

ALHP builds for x86-64-v2, x86-64-v3 and x86-64-v4 at the moment. You can see all available repositories here.

5. Update package database and upgrade:

pacman -Suy

FAQ

Remove ALHP packages

To disable ALHP remove all x86-64-vX entries in /etc/pacman.conf and remove alhp-keyring and alhp-mirrorlist.

After that you can refresh pacmans databases and downgrade all packages like:

pacman -Suuy

LTO

Enabled for all packages build after 04 Nov 2021 12:07:00 UTC. More details. LTO status is visible per package on the package status page.

Linux Kernel packages

KCFLAGS/KCPPFLAGS are used to build the kernel packages with our additional flags.

Directly linked kernel modules

Due to our increase in pkgrel, building the kernel packages breaks all directly linked modules like nvidia (not nvidia-dkms) or virtualbox-host-modules-arch (not virtualbox-host-dkms). Their respective dkms-variant is not affected. This issue is being tracked in #68, a solution is being worked on.

Mirrors

You want to mirror ALHP? You are welcome to do so, see alhp-mirrorlist for how to become one.

What packages are built

Packages excluded from building (besides all 'any' architecture packages) are being listed in issue #16. Also package status page (search for blacklisted).

Why is package X not up-to-date

Also relevant for: I can't find package X / Application X fails to start because it links to an old/newer lib

ALHP build packages after they are released in the official Archlinux Repos (not including [*-testing]). This leads to packages being delayed if the current batch contains many packages or packages which take a while to build (e.g. chromium).

You can always check on the progress of the current build-cycle on the package status page. Please refrain from opening issues caused by packages currently in queue/not yet build/not yet moved to the repo. Please keep in mind that large rebuilds such as openssl or python can take days to complete on our current build hardware.

Debug symbols

ALHP provides a debuginfod instance under debuginfod.alhp.dev.

To use it, have debuginfod installed on your system and add it to your DEBUGINFOD_URLS with:

echo "https://debuginfod.alhp.dev" > /etc/debuginfod/alhp.urls

Switch between levels

If you want to switch between levels, e.g. from x86-64-v3 to x86-64-v4, you need to revert to official packages first, then enable your desired repos again.

  1. Comment or remove ALHP repo entries in /etc/pacman.conf.
  2. Downgrade packages with pacman -Suuy.
  3. Clear pacman's package cache with pacman -Scc.
  4. Uncomment/add your desired repos to /etc/pacman.conf and update with pacman -Suy.

Matrix

For any non-issue questions or if you just want to chat, ALHP has a matrix room here (#alhp@ofsg.eu). You can also find me (@idlegandalf) in #archlinux:archlinux.org.

Donations

I appreciate any money you want to throw my way, but donations are strictly optional. Donations are primarily used to pay for server costs. Also consider donating to the Archlinux Team, without their work ALHP would not be possible.

Donate using Liberapay

This project including all of its source files is released under the terms of the GNU General Public License version 2 (or any later version). See LICENSE for details.