Skip to content
This repository has been archived by the owner on Jan 5, 2023. It is now read-only.
/ glibc-wsl Public archive

GNU C Library for Arch Linux on Windows Subsystem for Linux

Notifications You must be signed in to change notification settings

makotom/glibc-wsl

Repository files navigation

glibc-wsl

The GNU C Library for Arch Linux running on Windows Subsystem for Linux 1.

Why

  • WSL 1 has a known issue that its vDSO reports very old kernel version.
  • In February 2021, Arch Linux started to distribute a new build of GNU C Library, i.e., glibc-2.33-4, and stopped supporting Linux kernels < 4.4.
  • As a result, running pacman -Syu on WSL 1 will break your Arch Linux setup, as glibc is no longer compatible with WSL 1.
  • Fix for the issue is relatively easy, but actually there are other minor issues in packaging of glibc.
  • Then, this repository intends to provide patches (and resulting binaries) which make the package:
    1. WSL 1 compatible,
    2. buildable with simple makepkg, with out-of-box makepkg.conf, and
    3. GPL-safer with plain-text-formatted licence terms included in the distributed tarballs.

Why not AUR?

Because the author does not want to build it locally, as it would take some 30 - 60 minutes and eventually fail. Especially, it is totally nonsense to quasi-automatically trigger a build of glibc on each yay run.

Why not an independent package in an independent repository?

First of all, this distribution does not intend to permanently replace the official glibc package. These are just patches, and it is totally up to users and at their own risk to apply them or take advantage of "stray" builds with the patches applied.

Then, since these are just patches, there is a motivation to minify patches and minimize differences in version numbers. This is why the patches does not rename the package, and packages are provided as standalone ones.

Why not building periodically?

First of all, this distribution does not intend to permanently replace the official glibc package. These are just patches, and it is totally up to users and at their own risk to apply them or take advantage of "stray" builds with the patches applied.

With that being said, the build job can be a scheduled job, but it is ultimately meaningless because:

  1. most runs would be rebuilds or redundant polling runs, and unneeded builds are costly.
  2. any run which contains changes in the upstream is likely to fail and need human interventions, deteriorating benefits of periodical builds.

In other words, the author will try to manually track the changes in the upstream, as much as possible, and as fast as possible. In fact that is somewhat feasible, since the author is likely to take a look on any change in the upstream and implement countermeasures, regardless whether there are any automated processes, to salvage his own WSL environments.

How to?

You should be able to download the .pkg.tar.zst file for the latest release, and install it with pacman -U command. By downloading the corresponding .sig file as well, you should be able to verify your copy; follow this instruction to populate the GPG public key 2E6F2933950726A85333D84EE28A22F9AF2FEC65 used to sign the package.

Note that installing the package directly with pacman -U << URL >> would not work, as GitHub Releases redirects accesses to released assets towards another very-long URL, and it causes an error upon file downloads by pacman.

In order to avoid unexpected installation of future updates to the official glibc, add glibc to IgnorePkg of /etc/pacman.conf. Note that official future updates in glibc can overwrite the patched package, and consequently break your Arch Linux setup.

DIY?

By forking this repo and setting up your own CircleCI project, you are able build the package by yourself.

For your own CircleCI project, you need to setup 2 contexts:

  • Context gpg-glibc-wsl. This needs to contain the following env vars:
    1. PACKAGER (your display name as a packager, e.g., Makoto Mizukami <comm@makotom.org>),
    2. GPG_SECRET_KEY (the Base64-encoded GPG key to sign packages), and
    3. GPG_PASSPHRASE (the passphrase for the GPG key).
  • Context github. This needs to contain a GitHub personal access token, which has a sufficient permission to create a new release, in GITHUB_TOKEN env var.

About

GNU C Library for Arch Linux on Windows Subsystem for Linux

Resources

Stars

Watchers

Forks

Packages

No packages published