gnuboot-patches
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v1 09/14] scripts: misc: guix.sh: prevent OOM.


From: Adrien 'neox' Bourmault
Subject: Re: [PATCH v1 09/14] scripts: misc: guix.sh: prevent OOM.
Date: Mon, 29 Apr 2024 17:06:27 +0200
User-agent: Evolution 3.48.4

Le vendredi 19 avril 2024 à 19:06 +0200, Denis 'GNUtoo' Carikli a écrit :
> TODO:
> - Decide what to do with Trisquel 10: No Guix package.
> - Add tests if possible. The tests would install PureOS 10, install
>   the guix package and update it.
> - What to do with substitutes.
> --------------------------------------------------------------------------------
> We want to use Guix as a non-optional dependency in GNU Boot.
> 
> And we also want to make it as easy as possible for new users to
> contribute to GNU Boot, so if we depend on Guix, the build needs to
> work out of the box the first time without needing to learn Guix
> first, as starting with something that doesn't work can be very
> frustrating and make people go away as well as increase the amount of
> time assisting new contributors.
> 
> To achieve that we currently install the Guix package provided by the
> host distributions and provide an update script
> (resources/dependencies/guix) that can be be run manually and that
> could even be integrated to run automatically later on.
> 
> Since we currently support PureOS 10 (byzantium) and Trisquel 10
> (nabia) and that the later lacks a guix package, we would probably
> need to handle that somehow by various ways (that are not mutually
> exclusive) such as:
> 
> - Making it easy to install PureOS 10 in various setups. For instance
>   by enabling to install PureOS with debootstrap in most FSDG
>   compliant distributions and relying on the docker hub image for
>   other distributions.
> 
> - Making it easier to support more recent distributions by providing
>   ways of skipping builds for the KCMA-D8, KFSN4, KGPE-D16 mainboards
>   that are stuck in Coreboot 4.11 branch and that requires
>   distributions with older software to compile.
> 
> - By somehow building or providing the older software (compilers?)
>   that are necessary to bootstrap the build of Coreboot 4.11.
> 
> - By moving more of the build inside Guix, and removing the need to
>   depend on a host distribution completely.
> 
> - By adding other ways to install Guix, for instance by running the
>   guix installer or a modified version of it.
> 
> Here we need to update guix in any case because we are already working
> with upstream Guix, and so in the future we will most likely want to
> use specific Guix revision(s) (with guix time-machine) inside GNU Boot
> to use our contributions in upstream Guix once they are merged.
> 
> In addition using fixed revisions of Guix with guix time-machine also
> makes sure that the command line argument we use do work and also
> reduces the amount of work required to use Guix as tracking command
> line argument changes across different guix revisions can be tedious.
> 
> PureOS 10 (byzantium) has Guix 1.2.0 and so if we want to use a fixed
> revision that is more recent than that, Guix needs to be updated
> somehow as for now it doesn't automatically update itself to find new
> revisions.
> 
> The update script contains more logic than just running the 'guix
> pull' command. Beside minor details like setting up the right
> environment variables, it mainly tries to make sure that running 'guix
> pull' doesn't result in an out of memory situation that kills some
> Guix process because if for some reasons that happens, it would defeat
> the point of this script as it would make it harder for users to
> understand what is going on than if the script was not there in the
> first place.
> 
> Having the system go out of memory can happen if the total RAM size
> divided by the number of cores used by Guix is lower than a certain
> value.
> 
> To workaround that issue we adjust the number of cores used by Guix
> depending on the amount of RAM that the computer has.
> 
> How to test this patch:
> -----------------------
> 
> We need help for testing this patch as we're unsure of how much RAM
> per core Guix really requires. For x86_64 it's probably somewhere
> between 2GiB and 3GiB. It might be less for i686 as the 32bit programs
> occupy less space in RAM.
> 
> To test this patch users need to not have Guix already installed and
> install it though the package manager and run the
> resources/dependencies/guix script and see if it succeeds.
> 
> This should ideally be done on top of PureOS 10 (byzantium) with a
> graphical desktop that uses a lot of RAM during typically desktop
> usage that also use lot of RAM (like browsing with many tabs open).
> 
> Where the PureOS distributions are run is not very important. For
> instance they could run in virtual machines, in LXC containers,
> etc. What is more important is that commonly used RAM hungry programs
> are being used in parallel and to also write down the amount of RAM
> the test setup has.
> 
> Tests with other distributions are welcome as well as at some point we
> might succeed in adding support for newer distributions, especially
> because GNU Boot also has long term plans to upstream support for the
> KGPE D16 back into upstream Coreboot, to fix this problem and many
> other along the way (like issues in RAM initialization that requires
> very specific RAM modules), so if this plan works, the requirement for
> older distributions will be able to be dropped.
> 
> Signed-off-by: Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>

As discussed privately, this patch should be dropped for now until we
reconsider picking changes in it, for example by splitting it and
removing the OOM functionnality since it's now managed by ./configure
means.
-- 
Adrien Bourmault
Maintainer, GNU Boot project
Associate member, Free Software Foundation
GPG : 9AA8CDA0DC9C0604D26AE4A72974E1D5F25DFCC8





Attachment: signature.asc
Description: This is a digitally signed message part


reply via email to

[Prev in Thread] Current Thread [Next in Thread]