2009-11-08 12:01:53 +03:00
|
|
|
{ config, pkgs, ... }:
|
|
|
|
|
|
|
|
with pkgs.lib;
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
###### interface
|
|
|
|
|
|
|
|
options = {
|
|
|
|
|
|
|
|
system.sbin.modprobe = mkOption {
|
|
|
|
internal = true;
|
|
|
|
default = pkgs.writeTextFile {
|
|
|
|
name = "modprobe";
|
|
|
|
destination = "/sbin/modprobe";
|
|
|
|
executable = true;
|
|
|
|
text =
|
|
|
|
''
|
|
|
|
#! ${pkgs.stdenv.shell}
|
2012-08-15 01:09:44 +04:00
|
|
|
export MODULE_DIR=/run/current-system/kernel-modules/lib/modules
|
|
|
|
|
2010-01-27 00:45:13 +03:00
|
|
|
# Fall back to the kernel modules used at boot time if the
|
|
|
|
# modules in the current configuration don't match the
|
|
|
|
# running kernel.
|
|
|
|
if [ ! -d "$MODULE_DIR/$(${pkgs.coreutils}/bin/uname -r)" ]; then
|
2012-07-16 19:30:37 +04:00
|
|
|
MODULE_DIR=/run/booted-system/kernel-modules/lib/modules/
|
2010-01-27 00:45:13 +03:00
|
|
|
fi
|
2011-09-14 22:20:50 +04:00
|
|
|
|
2012-06-15 22:18:26 +04:00
|
|
|
exec ${pkgs.kmod}/sbin/modprobe "$@"
|
2009-11-08 12:01:53 +03:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
description = ''
|
|
|
|
Wrapper around modprobe that sets the path to the modules
|
|
|
|
tree.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
boot.blacklistedKernelModules = mkOption {
|
2013-10-30 20:37:45 +04:00
|
|
|
type = types.listOf types.str;
|
2009-11-08 12:01:53 +03:00
|
|
|
default = [];
|
|
|
|
example = [ "cirrusfb" "i2c_piix4" ];
|
|
|
|
description = ''
|
|
|
|
List of names of kernel modules that should not be loaded
|
|
|
|
automatically by the hardware probing code.
|
|
|
|
'';
|
|
|
|
};
|
2011-09-14 22:20:50 +04:00
|
|
|
|
2009-11-08 12:01:53 +03:00
|
|
|
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
|
|
|
|
<citerefentry><refentrytitle>modprobe.conf</refentrytitle>
|
|
|
|
<manvolnum>5</manvolnum></citerefentry> for details.
|
|
|
|
'';
|
2013-03-12 13:51:45 +04:00
|
|
|
type = types.lines;
|
2009-11-08 12:01:53 +03:00
|
|
|
};
|
2011-09-14 22:20:50 +04:00
|
|
|
|
2009-11-08 12:01:53 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
###### implementation
|
|
|
|
|
2013-11-27 19:54:20 +04:00
|
|
|
config = mkIf (!config.boot.isContainer) {
|
2009-11-08 12:01:53 +03:00
|
|
|
|
2014-01-21 03:29:35 +04:00
|
|
|
environment.etc = [
|
|
|
|
{ source = "${pkgs.kmod-blacklist-ubuntu}/modprobe.conf";
|
|
|
|
target = "modprobe.d/ubuntu.conf";
|
|
|
|
}
|
2009-11-08 12:01:53 +03:00
|
|
|
{ source = pkgs.writeText "modprobe.conf"
|
|
|
|
''
|
|
|
|
${flip concatMapStrings config.boot.blacklistedKernelModules (name: ''
|
|
|
|
blacklist ${name}
|
|
|
|
'')}
|
|
|
|
${config.boot.extraModprobeConfig}
|
|
|
|
'';
|
2011-11-01 19:39:30 +04:00
|
|
|
target = "modprobe.d/nixos.conf";
|
2014-01-21 03:29:35 +04:00
|
|
|
}
|
|
|
|
];
|
2009-11-08 12:01:53 +03:00
|
|
|
|
2012-06-15 22:18:26 +04:00
|
|
|
environment.systemPackages = [ config.system.sbin.modprobe pkgs.kmod ];
|
|
|
|
|
2010-09-13 19:41:38 +04:00
|
|
|
system.activationScripts.modprobe =
|
|
|
|
''
|
|
|
|
# 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 ${config.system.sbin.modprobe}/sbin/modprobe > /proc/sys/kernel/modprobe
|
|
|
|
'';
|
2011-09-14 22:20:50 +04:00
|
|
|
|
2013-09-24 01:03:21 +04:00
|
|
|
environment.variables.MODULE_DIR = "/run/current-system/kernel-modules/lib/modules";
|
2012-03-21 02:02:27 +04:00
|
|
|
|
2009-11-08 12:08:50 +03:00
|
|
|
};
|
2009-11-08 12:01:53 +03:00
|
|
|
|
2009-11-08 12:08:50 +03:00
|
|
|
}
|