2021-02-05 08:52:51 +01:00
|
|
|
{ config, lib, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.hardware.i2c;
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
options.hardware.i2c = {
|
2022-08-28 21:18:44 +02:00
|
|
|
enable = mkEnableOption (lib.mdDoc ''
|
2021-02-05 08:52:51 +01:00
|
|
|
i2c devices support. By default access is granted to users in the "i2c"
|
|
|
|
group (will be created if non-existent) and any user with a seat, meaning
|
|
|
|
logged on the computer locally.
|
2022-08-28 21:18:44 +02:00
|
|
|
'');
|
2021-02-05 08:52:51 +01:00
|
|
|
|
|
|
|
group = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
default = "i2c";
|
2022-07-28 23:19:15 +02:00
|
|
|
description = lib.mdDoc ''
|
2021-02-05 08:52:51 +01:00
|
|
|
Grant access to i2c devices (/dev/i2c-*) to users in this group.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
|
|
|
|
boot.kernelModules = [ "i2c-dev" ];
|
|
|
|
|
|
|
|
users.groups = mkIf (cfg.group == "i2c") {
|
|
|
|
i2c = { };
|
|
|
|
};
|
|
|
|
|
|
|
|
services.udev.extraRules = ''
|
|
|
|
# allow group ${cfg.group} and users with a seat use of i2c devices
|
|
|
|
ACTION=="add", KERNEL=="i2c-[0-9]*", TAG+="uaccess", GROUP="${cfg.group}", MODE="660"
|
|
|
|
'';
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
meta.maintainers = [ maintainers.rnhmjoj ];
|
|
|
|
|
|
|
|
}
|