mirror of
https://github.com/NixOS/mobile-nixos.git
synced 2024-12-16 11:43:21 +03:00
initrd: Make bootConfig a tangible internal option
This commit is contained in:
parent
5b3b72870b
commit
3b16a080f7
@ -78,27 +78,7 @@ let
|
|||||||
exec ${optionalString withStrace "${extraUtils}/bin/strace -f"} ${initWrapperRealInit}
|
exec ${optionalString withStrace "${extraUtils}/bin/strace -f"} ${initWrapperRealInit}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
bootConfig = {
|
bootConfigFile = writeText "${device_name}-boot-config" (toJSON config.mobile.boot.stage-1.bootConfig);
|
||||||
device = {
|
|
||||||
inherit (device_config) name;
|
|
||||||
};
|
|
||||||
kernel = {
|
|
||||||
inherit (config.mobile.boot.stage-1.kernel) modules;
|
|
||||||
};
|
|
||||||
|
|
||||||
# Literally transmit some nixos configurations.
|
|
||||||
nixos = {
|
|
||||||
boot.specialFileSystems = config.boot.specialFileSystems;
|
|
||||||
};
|
|
||||||
|
|
||||||
inherit bootFileSystems;
|
|
||||||
|
|
||||||
boot = {
|
|
||||||
inherit (config.mobile.boot.stage-1) fail;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
bootConfigFile = writeText "${device_name}-boot-config" (toJSON bootConfig);
|
|
||||||
|
|
||||||
contents =
|
contents =
|
||||||
(optionals (stage-1 ? contents) (flatten stage-1.contents))
|
(optionals (stage-1 ? contents) (flatten stage-1.contents))
|
||||||
@ -222,14 +202,42 @@ in
|
|||||||
The build system for boot/init will `find -iname '*.rb'` the given paths.
|
The build system for boot/init will `find -iname '*.rb'` the given paths.
|
||||||
";
|
";
|
||||||
};
|
};
|
||||||
|
mobile.boot.stage-1.bootConfig = mkOption {
|
||||||
|
type = types.attrs;
|
||||||
|
default = {};
|
||||||
|
internal = true;
|
||||||
|
description = ''
|
||||||
|
The things being put in the JSON configuration file in stage-1.
|
||||||
|
'';
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
system.build.initrd = "${initrd}/initrd";
|
system.build.initrd = "${initrd}/initrd";
|
||||||
# HACK: as we're using isContainer to bypass some NixOS stuff
|
|
||||||
# See <nixpkgs/nixos/modules/tasks/filesystems.nix>
|
|
||||||
boot.specialFileSystems = {
|
boot.specialFileSystems = {
|
||||||
|
# HACK: as we're using isContainer to bypass some NixOS stuff
|
||||||
|
# See <nixpkgs/nixos/modules/tasks/filesystems.nix>
|
||||||
"/sys" = { fsType = "sysfs"; options = [ "nosuid" "noexec" "nodev" ]; };
|
"/sys" = { fsType = "sysfs"; options = [ "nosuid" "noexec" "nodev" ]; };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
mobile.boot.stage-1.bootConfig = {
|
||||||
|
device = {
|
||||||
|
inherit (device_config) name;
|
||||||
|
};
|
||||||
|
kernel = {
|
||||||
|
inherit (config.mobile.boot.stage-1.kernel) modules;
|
||||||
|
};
|
||||||
|
|
||||||
|
# Literally transmit some nixos configurations.
|
||||||
|
nixos = {
|
||||||
|
boot.specialFileSystems = config.boot.specialFileSystems;
|
||||||
|
};
|
||||||
|
|
||||||
|
inherit bootFileSystems;
|
||||||
|
|
||||||
|
boot = {
|
||||||
|
inherit (config.mobile.boot.stage-1) fail;
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user