[pulseaudio-discuss] [PATCH v2] bluetooth: ofono: Use Acquire method if available

Luiz Augusto von Dentz luiz.dentz at gmail.com
Wed May 10 13:08:21 UTC 2017


Hi Georg,

On Mon, May 8, 2017 at 9:28 PM, Georg Chini <georg at chini.tk> wrote:
> On 08.05.2017 10:37, Luiz Augusto von Dentz wrote:
>>
>> From: Luiz Augusto von Dentz <luiz.von.dentz at intel.com>
>>
>> Attempt to use Acquire method if available falling back to Connect in
>> case it fails.
>> ---
>>   src/modules/bluetooth/backend-ofono.c | 59
>> +++++++++++++++++++++++++----------
>>   1 file changed, 43 insertions(+), 16 deletions(-)
>>
>> diff --git a/src/modules/bluetooth/backend-ofono.c
>> b/src/modules/bluetooth/backend-ofono.c
>> index 6e9a366..d098402 100644
>> --- a/src/modules/bluetooth/backend-ofono.c
>> +++ b/src/modules/bluetooth/backend-ofono.c
>> @@ -150,6 +150,46 @@ static int socket_accept(int sock)
>>       return 0;
>>   }
>>   +static int card_acquire(struct hf_audio_card *card) {
>> +    pa_bluetooth_transport *t = card->transport;
>> +    DBusMessage *m, *r;
>> +    DBusError err;
>> +
>> +    if (card->connecting)
>> +        return -EAGAIN;
>> +
>> +    /* Try acquiring the stream first */
>> +    dbus_error_init(&err);
>> +    pa_assert_se(m = dbus_message_new_method_call(t->owner, t->path,
>> "org.ofono.HandsfreeAudioCard", "Acquire"));
>> +    r =
>> dbus_connection_send_with_reply_and_block(pa_dbus_connection_get(card->backend->connection),
>> m, -1, &err);
>> +    if (!r) {
>> +        if (!pa_streq(err.name, DBUS_ERROR_UNKNOWN_METHOD)) {
>> +            pa_log_error("Failed to acquire %s: %s", err.name,
>> err.message);
>> +            return -1;
>> +        }
>> +    } else if ((dbus_message_get_args(r, NULL,
>> +                         DBUS_TYPE_UNIX_FD, &card->fd,
>> +                         DBUS_TYPE_BYTE, &card->codec,
>> +                         DBUS_TYPE_INVALID) == true)) {
>> +        return card->fd;
>> +    } else
>> +        return -1;
>> +
>> +    /* Fallback to Connect as this might be an old version of ofono */
>> +    card->connecting = true;
>> +
>> +    dbus_error_init(&err);
>> +    pa_assert_se(m = dbus_message_new_method_call(t->owner, t->path,
>> "org.ofono.HandsfreeAudioCard", "Connect"));
>> +    r =
>> dbus_connection_send_with_reply_and_block(pa_dbus_connection_get(card->backend->connection),
>> m, -1, &err);
>> +    if (!r)
>> +        return -1;
>> +
>> +    if (card->connecting)
>> +        return -EAGAIN;
>> +
>> +    return card->fd;
>> +}
>> +
>>   static int hf_audio_agent_transport_acquire(pa_bluetooth_transport *t,
>> bool optional, size_t *imtu, size_t *omtu) {
>>       struct hf_audio_card *card = t->userdata;
>>       int err;
>> @@ -157,22 +197,9 @@ static int
>> hf_audio_agent_transport_acquire(pa_bluetooth_transport *t, bool opti
>>       pa_assert(card);
>>         if (!optional && card->fd < 0) {
>> -        DBusMessage *m, *r;
>> -        DBusError derr;
>> -
>> -        if (card->connecting)
>> -            return -EAGAIN;
>> -
>> -        card->connecting = true;
>> -
>> -        dbus_error_init(&derr);
>> -        pa_assert_se(m = dbus_message_new_method_call(t->owner, t->path,
>> "org.ofono.HandsfreeAudioCard", "Connect"));
>> -        r =
>> dbus_connection_send_with_reply_and_block(pa_dbus_connection_get(card->backend->connection),
>> m, -1, &derr);
>> -        if (!r)
>> -            return -1;
>> -
>> -        if (card->connecting)
>> -            return -EAGAIN;
>> +        err = card_acquire(card);
>> +        if (err < 0)
>> +            return err;
>>       }
>>         /* The correct block size should take into account the SCO MTU
>> from
>
>
> In general, it looks OK. However, what seems missing are two things which
> are normally
> done from hf_audio_agent_new_connection():
>
> 1) card->transport->codec is not set. Or did you mean to use
> card->transport->codec
> in the dbus_message_get_args() call?

It is there already:

    } else if ((dbus_message_get_args(r, NULL,
                         DBUS_TYPE_UNIX_FD, &card->fd,
                         DBUS_TYPE_BYTE, &card->codec,
                         DBUS_TYPE_INVALID) == true)) {

> 2) pa_bluetooth_transport_set_state() is not called, so the transport state
> is not updated
> properly.
>
> The call to pa_bluetooth_transport_set_state() is a bit of a problem,
> because it is expected
> to be run from the main thread and the transport_acquired() function is
> called from both
> threads. Maybe you need to check if you are in main or I/O thread and either
> call it directly
> or send a message to the main thread.

And none of the existing transport do that anyway, so that perhaps
shall be handled separately as it is not unique to ofono backend.

>
> _______________________________________________
> pulseaudio-discuss mailing list
> pulseaudio-discuss at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/pulseaudio-discuss



-- 
Luiz Augusto von Dentz


More information about the pulseaudio-discuss mailing list