[pulseaudio-discuss] [PATCH v3 2/2] bluetooth: module-bluetooth-policy initial commit
Tanu Kaskinen
tanuk at iki.fi
Tue May 29 04:47:38 PDT 2012
On Tue, 2012-04-03 at 17:18 +0200, Frédéric Dalleau wrote:
> diff --git a/src/modules/bluetooth/module-bluetooth-policy.c b/src/modules/bluetooth/module-bluetooth-policy.c
> new file mode 100644
> index 0000000..8f1682b
> --- /dev/null
> +++ b/src/modules/bluetooth/module-bluetooth-policy.c
> @@ -0,0 +1,112 @@
> +/***
> + This file is part of PulseAudio.
> +
> + Copyright 2006 Lennart Poettering
> + Copyright 2009 Canonical Ltd
> + Copyright (C) 2012 Intel Corporation
> +
> + PulseAudio is free software; you can redistribute it and/or modify
> + it under the terms of the GNU Lesser General Public License as published
> + by the Free Software Foundation; either version 2.1 of the License,
> + or (at your option) any later version.
> +
> + PulseAudio 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 Lesser General Public License
> + along with PulseAudio; if not, write to the Free Software
> + Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
> + USA.
> +***/
> +
> +#ifdef HAVE_CONFIG_H
> +#include <config.h>
> +#endif
> +
> +#include <pulse/xmalloc.h>
> +
> +#include <pulsecore/core.h>
> +#include <pulsecore/source-output.h>
> +#include <pulsecore/source.h>
> +#include <pulsecore/core-util.h>
> +
> +#include "module-bluetooth-policy-symdef.h"
> +
> +PA_MODULE_AUTHOR("Frédéric Dalleau");
> +PA_MODULE_DESCRIPTION("When an A2DP source is added, load module-loopback");
> +PA_MODULE_VERSION(PACKAGE_VERSION);
> +PA_MODULE_LOAD_ONCE(TRUE);
> +
> + struct userdata {
Cosmetic: Space before "struct".
> + pa_hook_slot *source_put_slot;
> +};
> +
> +/* When a source is created, loopback default the source to default sink */
Typo: "default the source" -> "the default source".
> +static pa_hook_result_t source_put_hook_callback(pa_core *c, pa_source *source, void* userdata) {
> + const char *s;
> + const char *role;
> + char *args;
> +
> + pa_assert(c);
> + pa_assert(source);
> +
> + /* Don't want to run during startup or shutdown */
> + if (c->state != PA_CORE_RUNNING)
> + return PA_HOOK_OK;
Why not during startup?
> +
> + /* Only consider bluetooth sinks and sources */
> + s = pa_proplist_gets(source->proplist, PA_PROP_DEVICE_BUS);
> + if (!s)
> + return PA_HOOK_OK;
> +
> + if (!pa_streq(s, "bluetooth"))
> + return PA_HOOK_OK;
> +
> + /* Restrict to A2DP profile (sink role) */
> + s = pa_proplist_gets(source->proplist, "bluetooth.protocol");
> + if (!s)
> + return PA_HOOK_OK;
> +
> + if pa_streq(s, "a2dp_source")
> + role = "music";
> + else {
> + pa_log_debug("Profile %s cannot be selected for loopback", s);
> + return PA_HOOK_OK;
> + }
> +
> + /* Load module-loopback */
> + args = pa_sprintf_malloc("source=\"%s\" source_dont_move=\"true\" sink_input_properties=\"media.role=%s\"", source->name, role);
> + (void) pa_module_load(c, "module-loopback", args);
> + pa_xfree(args);
> +
> + return PA_HOOK_OK;
> +}
> +
> +int pa__init(pa_module*m) {
> + struct userdata *u;
> +
> + pa_assert(m);
> +
> + m->userdata = u = pa_xnew(struct userdata, 1);
> +
> + /* A little bit later than module-rescue-streams... */
> + u->source_put_slot = pa_hook_connect(&m->core->hooks[PA_CORE_HOOK_SOURCE_PUT], PA_HOOK_LATE+20, (pa_hook_cb_t) source_put_hook_callback, u);
The comment is bogus (it's bogus also in module-switch-on-connect).
module-rescue-streams doesn't use the PA_CORE_HOOK_SOURCE_PUT hook at
all. Use PA_HOOK_NORMAL as the priority if you don't have any reason to
use anything else.
--
Tanu
More information about the pulseaudio-discuss
mailing list