-
Notifications
You must be signed in to change notification settings - Fork 193
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Audio clock synchronization issue #451
Comments
bluealsa-aplay makes no attempt to adjust for clock drift. If the clock on your soundcard is really so far different from the bluetooth controller clock then either constant underruns or dropped a2dp codec frames are inevitable. What I don't understand is how the dmix plugin and/or the rate plugin can cause such rate errors, since both are driven by the hardware clock of the underlying soundcard. If the soundcard is consuming exactly 480 frames per 10ms from its ring buffer, then the rate plugin will consume exactly 441 frames per 10ms from its buffer. There will of course be some increase in jitter (as seen by the application, but not the soundcard), but that will not affect the rate that frames are consumed over any period greater than 10ms. Also, given that A2DP latency is at least 100ms (or 40ms for so-called "low latency" codecs), and sometimes greater than 300ms, what is the expected benefit of running the soundcard with such a low period time? If you increase the period time to 20ms or 100ms does that reduce the frequency of dropped bluetooth packets? |
Thank you for your fast response. When I chose a setup with a bigger latency, e.g. 3 periods of 640 samples (13.3 ms) at 48kHz, for resampling 44.1kHz I get a 3 periods with period_size=588. (588 * 48000 / 640 = 44100 Hz). This is the exact wanted sample rate. Markus |
OK, so it seems the rate plugin copies the hw period_time? Thinking about it now I guess that's inevitable as it is event-driven by hw interrupts via poll(). I also guess the real rate is not critical when reading from a file (although pitch will be too low and playtime too long) A hw period size of 64 frames @ 48000Hz gives period time 1.3333333 ms So rate uses the hw period time of 1.333333ms but rounds the number of frames to read in each period down to 58 I think the moral is: don't use the rate plugin with low latency setups! |
Unfortunately yes... |
Here's a simple(-ish) .asoundrc that might be good enough for resampling bluetooth audio:
Might need a bit of refinement, but hopefully you will at least get audio for more that a few seconds from bluealsa-aplay --pcm=myplugdmix |
Thank you for the idea with the pipe aplay. |
Would it make sense to support only samplerate 48000 in bluealsa, or would it break compatibility with clients ? |
The bluetooth spec mandates only the SBC codec for A2DP, and requires that a sink supports both 48kHz and 44.1kHz sample rates, but a source need only support one of them. So for SBC at least, you may find that some devices will not work if your sink does not support both rates. I don't know about other codecs though. |
You can create an option similar to the |
There has been a significant change in the ALSA rate plugin recently that has improved the operation of the ring buffer and may possibly have also reduced, or even eliminated, the rounding error. The HEAD of master branch in alsa-lib is currently broken, but if you build alsa-lib from, say, commit alsa-project/alsa-lib@1a1f0fb you will hopefully see much better accuracy from the rate plugin with small period sizes. The actual commit that seems to have made the difference is alsa-project/alsa-lib@5089358 |
On further testing, I've found that the recent ALSA rate plugin changes have not made any difference to the rounding error in the period size calculation, so I think that for such low period time requirements the only hope is that PR #459 is completed such that bluealsa-aplay can itself compensate for the rate plugin error. That is not ideal as it will inevitably degrade the audio quality, but at least better synchronization should become achievable. For others reading this who do not need such very low latency, I've written a tip on how to avoid the rounding error by carefully selecting the period time, and submitted this as a change to the bluealsa-aplay manual page, PR #492 |
With thanks to @mb-arturia for the tip on rate plugin rounding errors, the latest update to the |
Hi !
I use bluez-alsa on an embedded ARM system and it works really well with a2dp-sink mode and bluealsa-aplay when it can use the real samplerate clock of the DAC, even at low latency (period_time <2ms, 3 periods).
But when I use it with a sampleclock that is not exact, but some 100 Hz lower, there is a bufferization that grows until getting dropped RTP packets (e.g message "Missing RTP packet: 53662 != 53657" after some time, and then every ~2 seconds)
I have this case when I use a dmix pcm device (forcing 48kHz samplerate and low latency), and the alsa samplerate plug to do the resampling from 44100 Hz to 48kHz. In this case the alsa resampling resulting clock is not exactly 44100 HZ: It is rather below 44000 Hz.
My question:
How can the clocks and the data flow be synchronized ?
Is there a min sampleclock precision necessary ?
Thank you in advance
Markus
The text was updated successfully, but these errors were encountered: