2011-01-13 14:52:36 +00:00
|
|
|
From d205c2e05061a3f3502cccd0b157348cdc6e1071 Mon Sep 17 00:00:00 2001
|
2010-09-14 12:53:54 +00:00
|
|
|
From: Lennart Poettering <lennart@poettering.net>
|
|
|
|
Date: Wed, 21 Jul 2010 19:20:44 +0200
|
2011-01-13 14:52:36 +00:00
|
|
|
Subject: [PATCH 2/3] systemd: install systemd unit files
|
2010-09-14 12:53:54 +00:00
|
|
|
|
|
|
|
This also enables bus activation for bluetoothd, but only if systemd is
|
|
|
|
running. Only if that's the case we can make sure in a race-free fashion
|
|
|
|
that bluetoothd is not started twice at the same time.
|
|
|
|
---
|
|
|
|
Makefile.am | 21 ++++++++++++++++++---
|
|
|
|
configure.ac | 9 +++++++++
|
|
|
|
scripts/.gitignore | 1 +
|
|
|
|
scripts/bluetooth.service.in | 12 ++++++++++++
|
|
|
|
scripts/org.bluez.service | 5 +++++
|
|
|
|
5 files changed, 45 insertions(+), 3 deletions(-)
|
|
|
|
create mode 100644 scripts/.gitignore
|
|
|
|
create mode 100644 scripts/bluetooth.service.in
|
|
|
|
create mode 100644 scripts/org.bluez.service
|
|
|
|
|
|
|
|
diff --git a/Makefile.am b/Makefile.am
|
2010-12-01 15:35:13 +00:00
|
|
|
index 6044082..3ed5bcc 100644
|
2010-09-14 12:53:54 +00:00
|
|
|
--- a/Makefile.am
|
|
|
|
+++ b/Makefile.am
|
2010-12-01 15:35:13 +00:00
|
|
|
@@ -346,7 +346,8 @@ endif
|
2010-09-14 12:53:54 +00:00
|
|
|
CLEANFILES += $(rules_DATA)
|
|
|
|
|
|
|
|
EXTRA_DIST += scripts/bluetooth.rules \
|
|
|
|
- scripts/bluetooth-hid2hci.rules scripts/bluetooth-serial.rules
|
|
|
|
+ scripts/bluetooth-hid2hci.rules scripts/bluetooth-serial.rules \
|
|
|
|
+ scripts/bluetooth.service.in scripts/org.bluez.service
|
|
|
|
|
|
|
|
if PCMCIA
|
|
|
|
udevdir = $(libexecdir)/udev
|
2010-12-01 15:35:13 +00:00
|
|
|
@@ -354,6 +355,20 @@ udevdir = $(libexecdir)/udev
|
2010-09-14 12:53:54 +00:00
|
|
|
dist_udev_SCRIPTS = scripts/bluetooth_serial
|
|
|
|
endif
|
|
|
|
|
|
|
|
+if HAVE_SYSTEMD
|
|
|
|
+systemdsystemunit_DATA = \
|
|
|
|
+ scripts/bluetooth.service
|
|
|
|
+
|
|
|
|
+scripts/bluetooth.service: scripts/bluetooth.service.in
|
|
|
|
+ @$(SED) -e "s|\@sbindir\@|$(sbindir)|" $< >$@
|
|
|
|
+
|
|
|
|
+dbussystemservicesdir = $(datadir)/dbus-1/system-services
|
|
|
|
+
|
|
|
|
+dbussystemservices_DATA = \
|
|
|
|
+ scripts/org.bluez.service
|
|
|
|
+
|
|
|
|
+endif
|
|
|
|
+
|
|
|
|
EXTRA_DIST += doc/manager-api.txt \
|
|
|
|
doc/adapter-api.txt doc/device-api.txt \
|
|
|
|
doc/service-api.txt doc/agent-api.txt doc/attribute-api.txt \
|
2010-12-01 15:35:13 +00:00
|
|
|
@@ -378,9 +393,9 @@ pkgconfigdir = $(libdir)/pkgconfig
|
2010-09-14 12:53:54 +00:00
|
|
|
|
|
|
|
pkgconfig_DATA = bluez.pc
|
|
|
|
|
|
|
|
-DISTCHECK_CONFIGURE_FLAGS = --disable-udevrules --enable-attrib
|
|
|
|
+DISTCHECK_CONFIGURE_FLAGS = --disable-udevrules --enable-attrib --with-systemdsystemunitdir=
|
|
|
|
|
|
|
|
-DISTCLEANFILES = $(pkgconfig_DATA)
|
|
|
|
+DISTCLEANFILES = $(pkgconfig_DATA) scripts/bluetooth.service
|
|
|
|
|
|
|
|
MAINTAINERCLEANFILES = Makefile.in \
|
|
|
|
aclocal.m4 configure config.h.in config.sub config.guess \
|
|
|
|
diff --git a/configure.ac b/configure.ac
|
2011-01-13 14:52:36 +00:00
|
|
|
index b4c2482..a807830 100644
|
2010-09-14 12:53:54 +00:00
|
|
|
--- a/configure.ac
|
|
|
|
+++ b/configure.ac
|
2010-10-27 18:04:10 +00:00
|
|
|
@@ -56,5 +56,14 @@ if (test "${enable_capng}" = "yes"); then
|
|
|
|
AC_DEFINE(HAVE_CAPNG, 1, [Define to 1 if you have capabilities library.])
|
2010-09-14 12:53:54 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
+# systemd
|
|
|
|
+
|
|
|
|
+AC_ARG_WITH([systemdsystemunitdir],
|
2010-09-23 11:57:29 +00:00
|
|
|
+ AS_HELP_STRING([--with-systemdsystemunitdir=DIR], [Directory for systemd service files]),
|
|
|
|
+ [],
|
|
|
|
+ [with_systemdsystemunitdir=$($PKG_CONFIG --variable=systemdsystemunitdir systemd)])
|
2010-09-14 12:53:54 +00:00
|
|
|
+AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir])
|
|
|
|
+AM_CONDITIONAL(HAVE_SYSTEMD, [test -n "$with_systemdsystemunitdir"])
|
|
|
|
+
|
2010-10-27 18:04:10 +00:00
|
|
|
AC_OUTPUT(Makefile scripts/bluetooth.rules doc/version.xml
|
2010-09-14 12:53:54 +00:00
|
|
|
src/bluetoothd.8 bluez.pc)
|
|
|
|
diff --git a/scripts/.gitignore b/scripts/.gitignore
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000..4b9f765
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/scripts/.gitignore
|
|
|
|
@@ -0,0 +1 @@
|
|
|
|
+bluetooth.service
|
|
|
|
diff --git a/scripts/bluetooth.service.in b/scripts/bluetooth.service.in
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000..f95b0b0
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/scripts/bluetooth.service.in
|
|
|
|
@@ -0,0 +1,12 @@
|
|
|
|
+[Unit]
|
|
|
|
+Description=Bluetooth Manager
|
|
|
|
+After=syslog.target
|
|
|
|
+
|
|
|
|
+[Service]
|
|
|
|
+Type=dbus
|
|
|
|
+BusName=org.bluez
|
|
|
|
+ExecStart=@sbindir@/bluetoothd -n
|
|
|
|
+StandardOutput=syslog
|
|
|
|
+
|
|
|
|
+[Install]
|
|
|
|
+WantedBy=bluetooth.target
|
|
|
|
diff --git a/scripts/org.bluez.service b/scripts/org.bluez.service
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000..2a3b057
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/scripts/org.bluez.service
|
|
|
|
@@ -0,0 +1,5 @@
|
|
|
|
+[D-BUS Service]
|
|
|
|
+Name=org.bluez
|
|
|
|
+Exec=/bin/false
|
|
|
|
+User=root
|
|
|
|
+SystemdService=bluetooth.service
|
|
|
|
--
|
2010-12-01 15:35:13 +00:00
|
|
|
1.7.3.2
|
2010-09-14 12:53:54 +00:00
|
|
|
|