2020-04-24 23:36:52 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
###### interface
|
|
|
|
|
|
|
|
options = {
|
|
|
|
|
|
|
|
boot.blacklistedKernelModules = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [];
|
|
|
|
example = [ "cirrusfb" "i2c_piix4" ];
|
|
|
|
description = ''
|
|
|
|
List of names of kernel modules that should not be loaded
|
|
|
|
automatically by the hardware probing code.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
boot.extraModprobeConfig = mkOption {
|
|
|
|
default = "";
|
|
|
|
example =
|
|
|
|
''
|
|
|
|
options parport_pc io=0x378 irq=7 dma=1
|
|
|
|
'';
|
|
|
|
description = ''
|
|
|
|
Any additional configuration to be appended to the generated
|
|
|
|
<filename>modprobe.conf</filename>. This is typically used to
|
|
|
|
specify module options. See
|
2020-07-18 16:06:22 +00:00
|
|
|
<citerefentry><refentrytitle>modprobe.d</refentrytitle>
|
2020-04-24 23:36:52 +00:00
|
|
|
<manvolnum>5</manvolnum></citerefentry> for details.
|
|
|
|
'';
|
|
|
|
type = types.lines;
|
|
|
|
};
|
|
|
|
|
2022-01-25 03:21:06 +00:00
|
|
|
boot.initrd.extraModprobeConfig = mkOption {
|
|
|
|
default = "";
|
|
|
|
example =
|
|
|
|
''
|
|
|
|
options zfs zfs_arc_max=1073741824
|
|
|
|
'';
|
|
|
|
description = ''
|
|
|
|
Does exactly the same thing as
|
|
|
|
<option>boot.extraModprobeConfig</option>, except
|
|
|
|
that the generated <filename>modprobe.conf</filename>
|
|
|
|
file is also included in the initrd.
|
|
|
|
This is useful for setting module options for kernel
|
|
|
|
modules that are loaded during early boot in the initrd.
|
|
|
|
'';
|
|
|
|
type = types.lines;
|
|
|
|
};
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
###### implementation
|
|
|
|
|
|
|
|
config = mkIf (!config.boot.isContainer) {
|
|
|
|
|
|
|
|
environment.etc."modprobe.d/ubuntu.conf".source = "${pkgs.kmod-blacklist-ubuntu}/modprobe.conf";
|
|
|
|
|
|
|
|
environment.etc."modprobe.d/nixos.conf".text =
|
|
|
|
''
|
|
|
|
${flip concatMapStrings config.boot.blacklistedKernelModules (name: ''
|
|
|
|
blacklist ${name}
|
|
|
|
'')}
|
|
|
|
${config.boot.extraModprobeConfig}
|
|
|
|
'';
|
2022-01-25 03:21:06 +00:00
|
|
|
environment.etc."modprobe.d/nixos-initrd.conf".text = ''
|
|
|
|
${config.boot.initrd.extraModprobeConfig}
|
|
|
|
'';
|
2020-04-24 23:36:52 +00:00
|
|
|
environment.etc."modprobe.d/debian.conf".source = pkgs.kmod-debian-aliases;
|
|
|
|
|
2022-03-05 16:20:37 +00:00
|
|
|
environment.etc."modprobe.d/systemd.conf".source = "${pkgs.systemd}/lib/modprobe.d/systemd.conf";
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
environment.systemPackages = [ pkgs.kmod ];
|
|
|
|
|
|
|
|
system.activationScripts.modprobe = stringAfter ["specialfs"]
|
|
|
|
''
|
|
|
|
# Allow the kernel to find our wrapped modprobe (which searches
|
|
|
|
# in the right location in the Nix store for kernel modules).
|
|
|
|
# We need this when the kernel (or some module) auto-loads a
|
|
|
|
# module.
|
|
|
|
echo ${pkgs.kmod}/bin/modprobe > /proc/sys/kernel/modprobe
|
|
|
|
'';
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|