From: Vagrant Cascadian <vagrant@debian.org>
To: guix-devel <guix-devel@gnu.org>
Subject: linux-libre source tarballs
Date: Sat, 01 May 2021 18:45:32 -0700 [thread overview]
Message-ID: <87lf8xvrgj.fsf@yucca> (raw)
[-- Attachment #1: Type: text/plain, Size: 3984 bytes --]
So, for better or worse, I do a lot with guix on aarch64 platforms and
sometimes even armhf ones. And these platforms are... often...
quite... slow...
The way guix does updates of linux-libre sources by downloading upstream
linux tarballs and applying the linux-libre deblobbing and related
scripts to them is really technically excellent.
Pragmatically speaking, on slower platforms this is a huge resource
overhead. So much so that ci.guix.gnu.org *usually* times out when
generating the linux-libre aarch64 tarballs:
https://ci.guix.gnu.org/search?query=system%3Aaarch64-linux+linux-libre-arm64-generic
Same story for "linux-libre".
This means that platforms that are already fairly slow have to build one
or more source tarballs every linux-libre update, which can take several
hours to build the source for a kernel that takes only an hour or less
of compilation time.
I explored some of the alternatives last year:
https://lists.gnu.org/archive/html/guix-devel/2020-08/msg00089.html
Some of the surrounding threads also go into various issues around this
topic, but I'll summarize what I tried:
* Using linux-libre's git repository. A *bit* slow to download and
consumed ~1GB of space in /gnu/store, though much faster than running
the deblobbing scripts. Probably would deduplicate fairly well between
different versions, but would require re-downloading a lot of
content. Maybe a more savvy method to make use of this would be
possible. If a method somewhat like the mirror:// syntax for git
repositories allowed for a local git cache or a local git proxy, this
could save a lot of downloading and still get some benefits of
git. Needs someone to actually do the work, of course...
* Using the linux-libre tarballs. May have some issues with long-term
availability, but fast to download and the deblobbing scripts have
effectively already been run, saving a lot of local work. There is
basically support for this in guix already, and was the method used in
guix before july 2019 1ad9c105c208caa9059924cbfbe4759c8101f6c9.
Recently I've been thinking more about this for aarch64 and armhf; there
are a few things that might help considerably:
* Bump the timeouts on ci.guix.gnu.org for linux-libre so that the
deblob scripts actually get a chance to finish. Doesn't require much
change in the guix infrastructure to significantly improve the status
quo for slower architectures. Might take some tweaking over time to
find the right timeouts.
* Default to using the fsfla linux-libre tarballs on aarch64 and armhf,
while doing the full local deblobbing process for other faster
architectures. This keeps the infrastructure of both methods
up-to-date and tested, and can be used to do interesting things like
comparing to make sure the linux-libre tarballs guix generates and the
fsfla linux-libre tarballs do not contain significant
differences. This may very well require maintenance overhead by
generating two different hashes (one for the guix deblobbed tarball,
and one for the linux-libre deblobbed tarball), and doing things a
little differently by architecture is a little awkward.
* Produce the guix tarballs in a way that architectures could share the
resulting tarball. I'm not sure what hoops this would require jumping
through, something like generate the tarball, upload somewhere, update
hash. The tarball produced by running the deblob scripts really
shouldn't be architecture-dependent; re-doing this work on each
architecture seems suboptimal (though I get is also somewhat a result
of the functional package management model).
I like the idea of keeping all the infrastructure there to handle what
is currently done now, but would really like to figure out alternatives
at least for aarch64 and armhf.
Thanks for reading so far, please let me know what you think!
live well,
vagrant
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 227 bytes --]
next reply other threads:[~2021-05-02 1:46 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-05-02 1:45 Vagrant Cascadian [this message]
2021-05-02 2:45 ` linux-libre source tarballs Leo Famulari
2021-05-02 4:42 ` Leo Famulari
2021-05-02 21:08 ` Ludovic Courtès
2021-05-02 22:26 ` Leo Famulari
2021-05-02 22:38 ` Leo Famulari
2021-05-03 15:44 ` linux-libre source tarballs (disable "deblob-check"?) Leo Famulari
2021-05-03 16:39 ` linux-libre source tarballs Alexandre Oliva
2021-05-03 17:13 ` Leo Famulari
2021-05-06 4:10 ` Alexandre Oliva
2021-05-06 21:23 ` Leo Famulari
2021-05-06 20:30 ` Maxim Cournoyer
2021-05-09 3:27 ` Alexandre Oliva
2021-05-30 4:50 ` Vagrant Cascadian
2021-05-31 3:42 ` Leo Famulari
2021-05-31 19:57 ` Mathieu Othacehe
2021-08-01 20:45 ` source tarballs potentially built for each derivation Vagrant Cascadian
2021-08-01 21:04 ` Vagrant Cascadian
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://guix.gnu.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87lf8xvrgj.fsf@yucca \
--to=vagrant@debian.org \
--cc=guix-devel@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/guix.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).