On Tue, 2014-02-04 at 19:04 -0300, jprvita at gmail.com wrote: > From: Jo?o Paulo Rechi Vita <jprvita at openbossa.org> > > --- > src/modules/bluetooth/hfaudioagent-ofono.c | 29 +++++++++++++++++++++++++++-- > 1 file changed, 27 insertions(+), 2 deletions(-) > > diff --git a/src/modules/bluetooth/hfaudioagent-ofono.c b/src/modules/bluetooth/hfaudioagent-ofono.c > index 423e42a..fa8af94 100644 > --- a/src/modules/bluetooth/hfaudioagent-ofono.c > +++ b/src/modules/bluetooth/hfaudioagent-ofono.c > @@ -506,7 +506,10 @@ static DBusMessage *hf_audio_agent_release(DBusConnection *c, DBusMessage *m, vo > > static DBusMessage *hf_audio_agent_new_connection(DBusConnection *c, DBusMessage *m, void *data) { > DBusMessage *r; > - const char *sender; > + const char *sender, *card; > + int fd; > + uint8_t codec; > + hf_audio_card *hfac; > hf_audio_agent_data *hfdata = data; > > pa_assert(hfdata); > @@ -517,7 +520,29 @@ static DBusMessage *hf_audio_agent_new_connection(DBusConnection *c, DBusMessage > return r; > } > > - r = dbus_message_new_error(m, "org.ofono.Error.NotImplemented", "Operation is not implemented"); > + if (dbus_message_get_args(m, NULL, > + DBUS_TYPE_OBJECT_PATH, &card, > + DBUS_TYPE_UNIX_FD, &fd, > + DBUS_TYPE_BYTE, &codec, > + DBUS_TYPE_INVALID) == FALSE) { > + pa_assert_se(r = dbus_message_new_error(m, "org.ofono.Error.InvalidArguments", "Invalid arguments in method call")); > + return r; > + } > + > + if ( !(hfac = pa_hashmap_get(hfdata->hf_audio_cards, card)) ) { Extra spaces around the if condition. > + pa_log_warn("New audio connection on unknown card %s (fd=%d, codec=%d)", card, fd, codec); > + pa_assert_se(r = dbus_message_new_error(m, "org.ofono.Error.InvalidArguments", "Unknown card")); > + return r; > + } else > + pa_log_debug("New audio connection on card %s (fd=%d, codec=%d)", card, fd, codec); I think we should check that hfac is in an expected state, i.e. not already playing. Also the codec value needs to be validated. > + > + hfac->fd = fd; > + hfac->codec = codec; > + hfac->transport->state = PA_BLUETOOTH_TRANSPORT_STATE_PLAYING; > + pa_hook_fire(pa_bluetooth_discovery_hook(hfdata->discovery, PA_BLUETOOTH_HOOK_TRANSPORT_STATE_CHANGED), hfac->transport); It would be good to have pa_bluetooth_transport_set_state() that would fire the hook. -- Tanu