python312Packages.tencentcloud-sdk-python: 3.0.1291 -> 3.0.1292 (#369707)
[NixPkgs.git] / nixos / modules / system / boot / loader / external / external.md
blob4f5b559dfc40d2b397057caeb11ea719356efe32
1 # External Bootloader Backends {#sec-bootloader-external}
3 NixOS has support for several bootloader backends by default: systemd-boot, grub, uboot, etc.
4 The built-in bootloader backend support is generic and supports most use cases.
5 Some users may prefer to create advanced workflows around managing the bootloader and bootable entries.
7 You can replace the built-in bootloader support with your own tooling using the "external" bootloader option.
9 Imagine you have created a new package called FooBoot.
10 FooBoot provides a program at `${pkgs.fooboot}/bin/fooboot-install` which takes the system closure's path as its only argument and configures the system's bootloader.
12 You can enable FooBoot like this:
14 ```nix
15 { pkgs, ... }: {
16   boot.loader.external = {
17     enable = true;
18     installHook = "${pkgs.fooboot}/bin/fooboot-install";
19   };
21 ```
23 ## Developing Custom Bootloader Backends {#sec-bootloader-external-developing}
25 Bootloaders should use [RFC-0125](https://github.com/NixOS/rfcs/pull/125)'s Bootspec format and synthesis tools to identify the key properties for bootable system generations.