Re: Switching between SBC and MPEG audio on headsets

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

 



Hi Luiz,

On 3/15/2011 1:21 PM, Luiz Augusto von Dentz wrote:
Hi Brian,

On Tue, Mar 15, 2011 at 4:41 PM, Brian Gix<bgix@xxxxxxxxxxxxxx>  wrote:
On 3/15/2011 12:29 PM, Luiz Augusto von Dentz wrote:

Hi,

On Tue, Mar 15, 2011 at 2:01 PM, Johan Hedberg<johan.hedberg@xxxxxxxxx>
  wrote:

Hi Arun,

On Tue, Mar 15, 2011, Arun Raghavan wrote:

I've been trying to set up PulseAudio to be able to switch the A2DP sink
dynamically between SBC and MPEG modes. I've got this working now [1],
but I
did face one problem on the bluez side. When sending a reconfigure
request, the
request always goes to the SEID that was used previously (=>    always to
the SBC
SEID). Trying to reconfigure for MPEG therefore results the headset
returning
an error. I'm not very familiar with how this is supposed to work, but
the
patch following this mail seems to work (I can now switch back and forth
between SBC and MPEG modes). It basically forces figuring out what
remote SEP
to talk to while reconfiguring.

Is this the right approach?

I'm not sure about the places where you set the value to NULL, but the
place in close_cfm which you remove isn't acceptable as such. It was
originally created to fix the issue reported in this thread:
http://marc.info/?l=linux-bluetooth&m=129190286303247&w=2

Only a fix which doesn't break the use-case reported there can be
accepted upstream. FWIW, the commit that introduced the fix is de96fcd8.

Also the solution should consider a transition and not dropping the
stream completely before configuring the other, otherwise errors may
cause a complete disconnect just to switch between endpoints. Actually
I would suggest configuring both endpoint since the beginning so that
we only need to suspend/resume to switch between them, but I don't
think many headsets would be able to handle this situation.


I think most headsets will not support this because it would require an
extra L2CAP connection to be maintained.

I don't think there is much of a big deal with closing the first endpoint
relationship prior to configuring the next, becuase the AVDTP signaling
channel will keep the underlying ACL connection open. Headsets I have worked
on in the past would reject a SET_CONFIG if an existing local/remote SEID
relationship already existed, not only for the extra resources required to
maintain the extra L2CAP channel, but also because the SET_CONFIG is when
the hw resources are reserved and configured for the actual PCM data stream.

And assuming that the ACL doesn't get dropped, the critical re-setup time is
probably most bounded by the underlying hw reconfiguration, and not so much
by the few extra small ACL pkts that need to be exchanged.

The problem is that the audio routing is broken if the new stream
configuration fails, and even if sbc stream is configured latter it
may not be recovered and some audio maybe lost of rerouted to the
speakers which I believe is not the best experience for users.

Also we only need another connection in case of AVDTP_Open is sent,
this sound more a limitation of some implementation than a avdtp/a2dp
problem, the problem with disconnect is that if the stream setup fails
the session reference is dropped and the session is released (avdtp
signalling) so right now we have no means to hold the ACL link if
nothing else is connected e.g. hfp, we could in theory fix this by
having a setup which revert to the last configuration if the new one
fails but I fear this would required a special API to applications be
able to tells us when this is necessary.


I agree that it would be a limitation of the implementation and not the specification to not allow multiple endpoints to be configured simultaneously. However many of these headsets are designed on resource constrained platforms, and it is perfectly allowable for them within the specification to reject a second endpoint configuration due to insufficient resources.

And although you could configure two endpoints simultaneously without opening up both of their streaming L2CAP channels, as soon as you made the first switch, the second streaming channel would be open. A suspended streaming channel is still open and consuming resources. The only way to recover those resources is to issue CLOSE, which then requires another SET_CONFIG before it could be opened again.

I suppose you could close the channel, and then set up the configuration again while streaming to the 2nd, so that it is ready to be opened for the switch-back.


--
Brian Gix
bgix@xxxxxxxxxxxxxx
Employee of Qualcomm Innovation Center, Inc.
Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum
--
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