summaryrefslogtreecommitdiffstats
path: root/nixos
diff options
context:
space:
mode:
authorPeter Hoeg <peter@hoeg.com>2017-04-13 10:48:58 +0800
committerPeter Hoeg <peter@hoeg.com>2017-04-16 16:57:11 +0800
commit99d4ed58616358c71b81370130b3610744370028 (patch)
tree2305302369a937d11bb085fbc5984f17f03741a3 /nixos
parent048114eb4f79f3e125dadee106b454e3d72ccdfc (diff)
bluetooth: use upstream's recommendation for enabling interfaces
bluez no longer recommends spawning "hciconfig <device> up" from a udev rule as the main bluez daemon now supports automatically enabling power for all devices. Reference: http://www.bluez.org/release-of-bluez-5-35/
Diffstat (limited to 'nixos')
-rw-r--r--nixos/modules/services/hardware/bluetooth.nix31
1 files changed, 9 insertions, 22 deletions
diff --git a/nixos/modules/services/hardware/bluetooth.nix b/nixos/modules/services/hardware/bluetooth.nix
index f1fcb4369346..4a8cd86b0b11 100644
--- a/nixos/modules/services/hardware/bluetooth.nix
+++ b/nixos/modules/services/hardware/bluetooth.nix
@@ -6,9 +6,7 @@ let
bluez-bluetooth = pkgs.bluez;
cfg = config.hardware.bluetooth;
-in
-
-{
+in {
###### interface
@@ -32,6 +30,8 @@ in
'';
description = ''
Set additional configuration for system-wide bluetooth (/etc/bluetooth/main.conf).
+
+ NOTE: We already include [Policy], so any configuration under the Policy group should come first.
'';
};
};
@@ -45,7 +45,12 @@ in
environment.systemPackages = [ bluez-bluetooth pkgs.openobex pkgs.obexftp ];
environment.etc = singleton {
- source = pkgs.writeText "main.conf" cfg.extraConfig;
+ source = pkgs.writeText "main.conf" ''
+ [Policy]
+ AutoEnable=${lib.boolToString cfg.powerOnBoot}
+
+ ${cfg.extraConfig}
+ '';
target = "bluetooth/main.conf";
};
@@ -53,29 +58,11 @@ in
services.dbus.packages = [ bluez-bluetooth ];
systemd.packages = [ bluez-bluetooth ];
- services.udev.extraRules = optionalString cfg.powerOnBoot ''
- ACTION=="add", KERNEL=="hci[0-9]*", ENV{SYSTEMD_WANTS}="bluetooth-power@%k.service"
- '';
-
systemd.services = {
bluetooth = {
wantedBy = [ "bluetooth.target" ];
aliases = [ "dbus-org.bluez.service" ];
};
-
- "bluetooth-power@" = mkIf cfg.powerOnBoot {
- description = "Power up bluetooth controller";
- after = [
- "bluetooth.service"
- "suspend.target"
- "sys-subsystem-bluetooth-devices-%i.device"
- ];
- wantedBy = [ "suspend.target" ];
-
- serviceConfig.Type = "oneshot";
- serviceConfig.ExecStart = "${pkgs.bluez.out}/bin/hciconfig %i up";
- };
-
};
systemd.user.services = {