summaryrefslogtreecommitdiff
path: root/nixos/bootloader.nix
blob: bb807cf32354a1c4273ccd66f3fe922ea0e0d656 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
{ lib, config, ... }: let
	cfg = config.boot._loader;
	usingEfi  = cfg.mode == "efi";
	usingBios = cfg.mode == "bios";
in {
	options.boot._loader = {
		enable = lib.mkEnableOption "enable unified bootloader config";
		loader = lib.mkOption {
			type = lib.types.enum [ "grub" "systemd-boot" ];
			default = "systemd-boot";
			description = "whether to install grub or systemd-boot as the bootloader";
		};
		mode = lib.mkOption {
			type = lib.types.enum [ "efi" "bios" ];
			default = "efi";
			description = "whether to install the bootloader in efi or bios mode";
		};
		grub = {
			biosDevice = lib.mkOption {
				type = lib.types.str;
				description = "device to install grub on";
			};
		};
		memtest86.enable = lib.mkEnableOption "make Memtest86+ available from the bootloader";
	};

	config = lib.mkIf cfg.enable {
		boot.loader = {
			grub = lib.mkIf (cfg.loader == "grub") {
				enable = true;
				efiSupport = usingEfi;
				efiInstallAsRemovable = usingEfi;
				device = if usingBios then cfg.grub.biosDevice else "nodev";
				enableCryptodisk = true;
				memtest86.enable = cfg.memtest86.enable;
			};
			systemd-boot = lib.mkIf (cfg.loader == "systemd-boot") {
				enable = true;
				editor = false;
				memtest86.enable = cfg.memtest86.enable;
			};
			efi = lib.mkIf usingEfi {
				efiSysMountPoint = lib.mkIf (cfg.loader == "grub") "/boot/efi";
				canTouchEfiVariables = true;
			};
		};
	};
}