Home Explore Blog Models CI



nixpkgs

maintainers/scripts/bootstrap-files/README.md
0b756b3b195c6ed4380ec6b0734b199869552d4cc1c552050000000300000ded
# Bootstrap files

Currently `nixpkgs` builds most of it's packages using bootstrap seed binaries (without the reliance on external inputs):

- `bootstrap-tools`: an archive with the compiler toolchain and other helper tools enough to build the rest of the `nixpkgs`.
- initial binaries needed to unpack `bootstrap-tools.*`.
  On `linux` it's just `busybox`, on `darwin` and `freebsd` it is unpack.nar.xz which contains the binaries and script needed to unpack the tools.
  These binaries can be executed directly from the store.

These are called "bootstrap files".

Bootstrap files should always be fetched from hydra and uploaded to `tarballs.nixos.org` to guarantee that all the binaries were built from the code committed into `nixpkgs` repository.

The uploads to `tarballs.nixos.org` are done by `@lovesegfault` today.

This document describes the procedure of updating bootstrap files in `nixpkgs`.

## How to request the bootstrap seed update

To get the tarballs updated let's use an example `i686-unknown-linux-gnu` target:

1. Create a local update:

   ```
   $ maintainers/scripts/bootstrap-files/refresh-tarballs.bash --commit --targets=i686-unknown-linux-gnu
   ```

2. Test the update locally. I'll build local `hello` derivation with the result:

   ```
   $ nix-build -A hello --argstr system i686-linux
   ```

   To validate cross-targets `binfmt` `NixOS` helper can be useful.
   For `riscv64-unknown-linux-gnu` the `/etc/nixos/configuration.nix` entry would be `boot.binfmt.emulatedSystems = [ "riscv64-linux" ]`.

3. Propose the commit as a PR to update bootstrap tarballs, tag people who can help you test the updated architecture and once reviewed tag `@lovesegfault` to upload the tarballs.

## How to add bootstrap files for a new target

The procedure to add a new target is very similar to the update procedure.
The only difference is that you need to set up a new job to build the `bootstrapFiles`.
To do that you will need the following:

1. Add your new target to `lib/systems/examples.nix`

   This will populate `pkgsCross.$target` attribute set.
   If you are dealing with `bootstrapFiles` upload you probably already have it.

2. Add your new target to `pkgs/stdenv/linux/make-bootstrap-tools-cross.nix`.
   This will add a new hydra job to `nixpkgs:cross-trunk` jobset.

3. Wait for a hydra to build your bootstrap tarballs.

4. Add your new target to `maintainers/scripts/bootstrap-files/refresh-tarballs.bash` around `CROSS_TARGETS=()`.

5. Add your new target to `pkgs/stdenv/linux/default.nix` and follow standard bootstrap seed update procedure above.

## Bootstrap files job definitions

There are two types of bootstrap files:

- natively built `stdenvBootstrapTools.build` hydra jobs in [`nixpkgs:trunk`](https://hydra.nixos.org/jobset/nixpkgs/trunk#tabs-jobs) jobset.
  Incomplete list of examples is:

  * `aarch64-unknown-linux-musl.nix`
  * `i686-unknown-linux-gnu.nix`

  These are Tier 1 hydra platforms.

- cross-built by `bootstrapTools.build` hydra jobs in [`nixpkgs:cross-trunk`](https://hydra.nixos.org/jobset/nixpkgs/cross-trunk#tabs-jobs) jobset.
  Incomplete list of examples is:

  * `mips64el-unknown-linux-gnuabi64.nix`
  * `mips64el-unknown-linux-gnuabin32.nix`
  * `mipsel-unknown-linux-gnu.nix`
  * `powerpc64le-unknown-linux-gnu.nix`
  * `riscv64-unknown-linux-gnu.nix`

  These are usually Tier 2 and lower targets.

The `.build` job contains `/on-server/` subdirectory with binaries to be uploaded to `tarballs.nixos.org`.
The files are uploaded to `tarballs.nixos.org` by writers to `S3` store.

Chunks
5bc4139f (1st chunk of `maintainers/scripts/bootstrap-files/README.md`)
Title: Nixpkgs Bootstrap Files: Update and New Target Procedures
Summary
Bootstrap files in `nixpkgs` are crucial seed binaries (e.g., `bootstrap-tools`, `busybox`) enabling package builds without external dependencies. Sourced from Hydra, they are uploaded to `tarballs.nixos.org` by `@lovesegfault`. Updating these files involves running `refresh-tarballs.bash` locally for a target, testing the build, then submitting a pull request to update tarballs, tagging testers and `@lovesegfault` for upload. To add a new target, first configure a new Hydra job by adding the target to `lib/systems/examples.nix` and `pkgs/stdenv/linux/make-bootstrap-tools-cross.nix`. After Hydra builds the tarballs, integrate the target into `maintainers/scripts/bootstrap-files/refresh-tarballs.bash` and `pkgs/stdenv/linux/default.nix`, then follow the update procedure. Bootstrap files originate from native `stdenvBootstrapTools.build` jobs (Tier 1) or cross-built `bootstrapTools.build` jobs (Tier 2+) on Hydra, with uploadable binaries in the `/on-server/` subdirectory.