-
Notifications
You must be signed in to change notification settings - Fork 127
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
cubeb_jack: Replace all mutexes with atomics #391
Conversation
FWIW: making all variables atomic isn't an equivalent to the use of a single mutex. |
"making all variables atomic isn't an equivalent to the use of a single mutex." I do not make all variables atomic. "It no longer appears to keep consistency between all group of variables." Can you please elaborate, the variables I made atomic are used in such a way that only one thread is allowed to write to one atomic variable and the next time the other thread executes it reads the value so that two threads are never writing to the same variable and getting out of sync. |
What concrete problem does this change solve? The review and maintenance burden of verifying attempts at lock free implementations likely outweighs any benefit we'll ever see from this change, in my opinion. Sorry, but I don't think we will be merging this without an incredibly strong reason to do so. |
It is trying to solve a design problem. The current code is broken. Using mutexes in real time context is a big no. No audio library I am aware of does this. All use lockless buffers implemented through atomics. Some real time audio rules here. The reason the current code works is because the code uses That being said, the current code does seem to work on most machines without hiccups. Or I could at least not find any bug reports about audio glitches. And I understand the effort involved in verifying lockless algorithms. I have written code like this myself. It is a pain. And we do seem to get lucky most of the time as mutex contentions is low. I added some debug symbols. So far I have not been able to hit the insert silence code path. I do wonder how many people do hit that code path from time to time on other hardware and less performant systems though. I am commenting here as I got concerned about the All that being said, this PR is beyond broken. Line 145 of the PR tells me the submitter has no idea how atomics work. A bool is not an atomic. Looking at the rest of the code: it does not seem to solve anything either. It is just the attempt at implementing a mutex through atomics and does not solve anything!? You would need a lockless ring buffer with a reader and a writer thread or something similar. |
@szanni You're completely right. The current code is broken because it has trylocks in the realtime thread. This PR was an attempt to fix it, but as you described, it uses booleans in place of a mutex instead of a lockless ring buffer mechanism. I urge anyone who knows how to fix this to do so, and I will close this PR soon. I don't know how to fix it properly and I also don't have time to spend on it further. |
I do in theory know how to fix this, as I have written push & callback style back ends for alsa, coreaudio, sdl, && If somebody wants to open a bug bounty, I might find the time to write a proper jack back end. I would however recommend just switching Firefox to SDL2.0 as that is battle tested, supports pretty much all platforms imaginable, and is released under the very permissive zlib license. I am not a fan of the SDL API, but at least the library is not broken and the developers seem understand how audio works. @zamaudio maybe close this PR and open up an issue instead lamenting the mutex stuff and linking to this thread? Or I could do that too. And I hope my language wasn't too strong criticising your PR :) |
This patch removes all pthread mutexes in the jack backend, especially that ugly trylock in the realtime audio thread. These are replaced with atomic variables. Passes all tests, although JACK xruns when
test_sanity
is being called in thecubeb.stream_position
test where there are massive 500ms delays.Users note that there is still a bug with Firefox itself that causes cubeb never to shutdown (#390). This can cause xruns on firefox quit until it is fixed. However, this patch should see an improvement over the previous backend code. Partially fixes #154