Re: [PATCH] android/handsfree: Connect audio when Android framemework expects it

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Marcin,

> There are few cases when framework doesn't call connect_audio method
> from HAL but we should do it internally. Call connect_audio if
> we started dialing or we accepted incoming call. Also if headset
> connects during active call, start SCO connection. We don't have to
> disconnect SCO internally, because Android always call disconect_audio
> when call has finished.
> ---
> android/handsfree.c | 14 +++++++++++++-
> 1 file changed, 13 insertions(+), 1 deletion(-)
> 
> diff --git a/android/handsfree.c b/android/handsfree.c
> index d4dc596..61a9816 100644
> --- a/android/handsfree.c
> +++ b/android/handsfree.c
> @@ -1653,6 +1653,9 @@ static bool disconnect_sco(void)
> 
> static bool connect_audio(void)
> {
> +	if (device.audio_state != HAL_EV_HANDSFREE_AUDIO_STATE_DISCONNECTED)
> +		return false;
> +
> 	/* we haven't negotiated codec, start selection */
> 	if ((device.features & HFP_HF_FEAT_CODEC) && !device.negotiated_codec) {
> 		select_codec(0);
> @@ -1989,6 +1992,8 @@ static void phone_state_dialing(int num_active, int num_held)
> 
> 	if (num_active == 0 && num_held > 0)
> 		update_indicator(IND_CALLHELD, 2);
> +
> +	connect_audio();
> }
> 
> static void phone_state_alerting(int num_active, int num_held)
> @@ -2057,13 +2062,16 @@ static void phone_state_idle(int num_active, int num_held)
> 
> 	switch (device.setup_state) {
> 	case HAL_HANDSFREE_CALL_STATE_INCOMING:
> -		if (num_active > device.num_active)
> +		if (num_active > device.num_active) {
> 			update_indicator(IND_CALL, 1);
> +			connect_audio();
> +		}
> 
> 		if (num_held > device.num_held)
> 			update_indicator(IND_CALLHELD, 1);
> 
> 		update_indicator(IND_CALLSETUP, 0);
> +

lets not add an empty line here. It is fine to go straight to break;

> 		break;
> 	case HAL_HANDSFREE_CALL_STATE_DIALING:
> 	case HAL_HANDSFREE_CALL_STATE_ALERTING:
> @@ -2088,6 +2096,10 @@ static void phone_state_idle(int num_active, int num_held)
> 		update_indicator(IND_CALLSETUP, 0);
> 

Lets remove this empty line.

> 		break;
> +	case HAL_HANDSFREE_CALL_STATE_ACTIVE:
> +		connect_audio();
> +

And this empty line is also not needed.

> +		break;
> 	default:
> 		DBG("unhandled state %u", device.setup_state);
> 		break;

Regards

Marcel

--
To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux