summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2007-04-08 23:13:18 +0000
committerMarcel Holtmann <marcel@holtmann.org>2007-04-08 23:13:18 +0000
commit7558cca5c0bd954dc3db559c0d58ae6e497b13c0 (patch)
tree788dbf1e68739db12abb4bc73a0d15c4d8e66218
parentebfe5886d05091a0d2398182a432241435ae2956 (diff)
Add generic audio service init
-rw-r--r--audio/Makefile.am6
-rw-r--r--audio/headset.c108
-rw-r--r--audio/headset.h25
-rw-r--r--audio/main.c62
4 files changed, 96 insertions, 105 deletions
diff --git a/audio/Makefile.am b/audio/Makefile.am
index cbb27956..fe5931b1 100644
--- a/audio/Makefile.am
+++ b/audio/Makefile.am
@@ -10,10 +10,10 @@ servicedir = $(libdir)/bluetooth
service_PROGRAMS = bluetoothd-service-audio
-bluetoothd_service_audio_SOURCES = manager.h manager.c headset.c
+bluetoothd_service_audio_SOURCES = main.c manager.h manager.c headset.c
bluetoothd_service_audio_LDADD = $(top_builddir)/common/libhelper.a \
- @SBC_LIBS@ @GLIB_LIBS@ @DBUS_LIBS@ @BLUEZ_LIBS@
+ @GLIB_LIBS@ @DBUS_LIBS@ @BLUEZ_LIBS@
endif
if ALSA
@@ -23,7 +23,7 @@ alsa_LTLIBRARIES = libasound_module_pcm_bluetooth.la libasound_module_ctl_blueto
libasound_module_pcm_bluetooth_la_SOURCES = pcm_bluetooth.c
libasound_module_pcm_bluetooth_la_LDFLAGS = -module -avoid-version -export-dynamic
-libasound_module_pcm_bluetooth_la_LIBADD = @ALSA_LIBS@
+libasound_module_pcm_bluetooth_la_LIBADD = @SBC_LIBS@ @ALSA_LIBS@
libasound_module_ctl_bluetooth_la_SOURCES = ctl_bluetooth.c
libasound_module_ctl_bluetooth_la_LDFLAGS = -module -avoid-version -export-dynamic
diff --git a/audio/headset.c b/audio/headset.c
index fcff8174..9e303782 100644
--- a/audio/headset.c
+++ b/audio/headset.c
@@ -1963,78 +1963,11 @@ void audio_manager_free(struct manager *manager)
g_free(manager);
}
-static void sig_term(int sig)
-{
- g_main_loop_quit(main_loop);
-}
+static struct manager *manager = NULL;
-int main(int argc, char *argv[])
+int headset_init(DBusConnection *conn)
{
- uint8_t opt_channel = 12;
- char *opt_bda = NULL;
- char *opt_input = NULL;
- char *opt_output = NULL;
- gboolean register_svc = FALSE;
- bdaddr_t bda;
- struct headset *hs;
- struct manager *manager;
- struct sigaction sa;
- int opt;
-
- while ((opt = getopt(argc, argv, "c:o:i:ds")) != EOF) {
- switch (opt) {
- case 'c':
- opt_channel = strtol(optarg, NULL, 0);
- break;
-
- case 'i':
- opt_input = optarg;
- break;
-
- case 'o':
- opt_output = optarg;
- break;
-
- case 'd':
- enable_debug();
- break;
-
- case 's':
- register_svc = TRUE;
- break;
-
- default:
- printf("Usage: %s -c local_channel [-d] [-o output] [-i input] [bdaddr]\n", argv[0]);
- exit(1);
- }
- }
-
- if (optind < argc && argv[optind])
- opt_bda = argv[optind];
-
- start_logging("audio", "Bluetooth audio service daemon");
-
- memset(&sa, 0, sizeof(sa));
- sa.sa_flags = SA_NOCLDSTOP;
- sa.sa_handler = sig_term;
- sigaction(SIGTERM, &sa, NULL);
- sigaction(SIGINT, &sa, NULL);
-
- sa.sa_handler = SIG_IGN;
- sigaction(SIGCHLD, &sa, NULL);
- sigaction(SIGPIPE, &sa, NULL);
-
- main_loop = g_main_loop_new(NULL, FALSE);
-
- connection = init_dbus(NULL, NULL, NULL);
- if (!connection) {
- error("Connection to system bus failed");
- g_main_loop_unref(main_loop);
- exit(1);
- }
-
- if (register_svc)
- register_external_service(connection, "audio", "Audio service", "");
+ connection = dbus_connection_ref(conn);
manager = audio_manager_new(connection);
if (!manager) {
@@ -2044,40 +1977,15 @@ int main(int argc, char *argv[])
exit(1);
}
- audio_manager_create_headset_server(manager, opt_channel);
-
- if (opt_bda) {
- str2ba(opt_bda, &bda);
- hs = audio_headset_new(connection, &bda);
- if (!hs) {
- error("Connection setup failed");
- dbus_connection_unref(connection);
- g_main_loop_unref(main_loop);
- exit(1);
- }
-
- if (opt_output)
- audio_headset_open_output(hs, opt_output);
- if (opt_input)
- audio_headset_open_input(hs, opt_input);
+ audio_manager_create_headset_server(manager, 12);
- audio_manager_add_headset(manager, hs);
- /* connect */
- hs_connect(hs, NULL);
- }
-
- g_main_loop_run(main_loop);
+ return 0;
+}
+void headset_exit(void)
+{
audio_manager_free(manager);
manager = NULL;
dbus_connection_unref(connection);
-
- g_main_loop_unref(main_loop);
-
- info("Exit");
-
- stop_logging();
-
- return 0;
}
diff --git a/audio/headset.h b/audio/headset.h
new file mode 100644
index 00000000..a87be7e3
--- /dev/null
+++ b/audio/headset.h
@@ -0,0 +1,25 @@
+/*
+ *
+ * BlueZ - Bluetooth protocol stack for Linux
+ *
+ * Copyright (C) 2004-2007 Marcel Holtmann <marcel@holtmann.org>
+ *
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+int headset_init(DBusConnection *conn);
+void headset_exit(void);
diff --git a/audio/main.c b/audio/main.c
index 2f3a1fa0..08194d82 100644
--- a/audio/main.c
+++ b/audio/main.c
@@ -25,16 +25,74 @@
#include <config.h>
#endif
-#include <stdio.h>
-#include <errno.h>
+#include <stdlib.h>
+#include <string.h>
+#include <signal.h>
+
+#include <glib.h>
+
+#include <dbus/dbus.h>
+
+#include "dbus.h"
+#include "logging.h"
#include "manager.h"
+#include "headset.h"
+
+static GMainLoop *main_loop = NULL;
+
+static void sig_term(int sig)
+{
+ g_main_loop_quit(main_loop);
+}
int main(int argc, char *argv[])
{
+ DBusConnection *conn;
+ struct sigaction sa;
+
+ start_logging("audio", "Bluetooth Audio daemon");
+
+ memset(&sa, 0, sizeof(sa));
+ sa.sa_flags = SA_NOCLDSTOP;
+ sa.sa_handler = sig_term;
+ sigaction(SIGTERM, &sa, NULL);
+ sigaction(SIGINT, &sa, NULL);
+
+ sa.sa_handler = SIG_IGN;
+ sigaction(SIGCHLD, &sa, NULL);
+ sigaction(SIGPIPE, &sa, NULL);
+
+ enable_debug();
+
+ main_loop = g_main_loop_new(NULL, FALSE);
+
+ conn = dbus_bus_system_setup_with_main_loop(NULL, NULL, NULL);
+ if (!conn) {
+ g_main_loop_unref(main_loop);
+ exit(1);
+ }
+
audio_init();
+ headset_init(conn);
+
+ if (argc > 1 && !strcmp(argv[1], "-s"))
+ register_external_service(conn, "audio", "Audio service", "");
+
+ g_main_loop_run(main_loop);
+
+ headset_exit();
+
audio_exit();
+ dbus_connection_unref(conn);
+
+ g_main_loop_unref(main_loop);
+
+ info("Exit");
+
+ stop_logging();
+
return 0;
}