From: Denis Kenzior <denkenz@gmail.com>
To: ofono@ofono.org
Subject: Re: [PATCH 4/6] handsfree-audio: Set the voice setting for outgoing connections
Date: Mon, 19 Aug 2013 12:56:23 -0500 [thread overview]
Message-ID: <52125C47.2080400@gmail.com> (raw)
In-Reply-To: <1376619969-15080-5-git-send-email-vcgomes@gmail.com>
[-- Attachment #1: Type: text/plain, Size: 1606 bytes --]
Hi Vinicius,
On 08/15/2013 09:26 PM, Vinicius Costa Gomes wrote:
> In the AG case, the voice setting needs to be set before we can
> use Transparent SCO mode, which is necessary for Wideband speech
> support.
> ---
> src/handsfree-audio.c | 8 ++++++++
> 1 file changed, 8 insertions(+)
>
> diff --git a/src/handsfree-audio.c b/src/handsfree-audio.c
> index c83086f..d550e6e 100644
> --- a/src/handsfree-audio.c
> +++ b/src/handsfree-audio.c
> @@ -442,6 +442,7 @@ int ofono_handsfree_card_connect_sco(struct ofono_handsfree_card *card)
> {
> GIOChannel *io;
> struct sockaddr_sco addr;
> + struct bt_voice voice;
> int sk, ret;
>
> sk = socket(PF_BLUETOOTH, SOCK_SEQPACKET | O_NONBLOCK | SOCK_CLOEXEC,
> @@ -465,6 +466,13 @@ int ofono_handsfree_card_connect_sco(struct ofono_handsfree_card *card)
> addr.sco_family = AF_BLUETOOTH;
> bt_str2ba(card->remote, &addr.sco_bdaddr);
>
> + memset(&voice, 0, sizeof(voice));
> + voice.setting = codec2setting(card->selected_codec);
> +
> + if (setsockopt(sk, SOL_BLUETOOTH, BT_VOICE, &voice, sizeof(voice)) < 0)
> + ofono_error("Can't set voice settings: %s (%d)",
> + strerror(errno), errno);
> +
Same comment here as for patch 2.
- If we fail to set BT_VOICE and our kernel does not support it, then
printing an error is superfluous.
- If we indeed try to set wideband codec and fail, then continuing with
the connection is kinda bad.
> ret = connect(sk, (struct sockaddr *) &addr, sizeof(addr));
> if (ret < 0 && errno != EINPROGRESS) {
> close(sk);
>
Regards,
-Denis
next prev parent reply other threads:[~2013-08-19 17:56 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-08-16 2:26 [PATCH 0/6] hfp_hf_bluez5: Add support for Transparent SCO Vinicius Costa Gomes
2013-08-16 2:26 ` [PATCH 1/6] bluetooth: Add define for SCO voice settings Vinicius Costa Gomes
2013-08-19 17:59 ` Denis Kenzior
2013-08-16 2:26 ` [PATCH 2/6] handsfree-audio: Add setting SCO air mode Vinicius Costa Gomes
2013-08-19 17:49 ` Denis Kenzior
2013-08-19 18:42 ` Vinicius Costa Gomes
2013-08-16 2:26 ` [PATCH 3/6] handsfree-audio: Add support for detecting Transparent SCO support Vinicius Costa Gomes
2013-08-19 17:55 ` Denis Kenzior
2013-08-19 19:36 ` Vinicius Costa Gomes
2013-08-16 2:26 ` [PATCH 4/6] handsfree-audio: Set the voice setting for outgoing connections Vinicius Costa Gomes
2013-08-19 17:56 ` Denis Kenzior [this message]
2013-08-16 2:26 ` [PATCH 5/6] hfp_hf_bluez5: Handle org.bluez.Profile1.Cancel() Vinicius Costa Gomes
2013-08-16 2:26 ` [PATCH 6/6] hfp_hf_bluez5: Handle org.bluez.Profile1.Release() Vinicius Costa Gomes
2013-08-19 17:57 ` Denis Kenzior
2013-08-19 18:47 ` Vinicius Costa Gomes
2013-08-20 13:51 ` Luiz Augusto von Dentz
2013-08-20 15:41 ` Denis Kenzior
2013-08-21 10:29 ` Luiz Augusto von Dentz
2013-08-21 15:21 ` Denis Kenzior
2013-08-22 14:41 ` Luiz Augusto von Dentz
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=52125C47.2080400@gmail.com \
--to=denkenz@gmail.com \
--cc=ofono@ofono.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.