-
Notifications
You must be signed in to change notification settings - Fork 128
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
Re-enable and polish IAudioClient3 to achieve lower latencies #740
base: master
Are you sure you want to change the base?
Conversation
I'm in the process of polishing the code and I've already removed many of the test settings as they revealed useless. |
Thanks for working on this! We'd like to ship IAC3 support in Firefox at some point, but haven't had a chance to revisit the issues discovered during the previous rollout attempt. I'll take a look at the changes so far over the next day or so and get back to you with any feedback. |
It's more or less always been a "desirable target", not all backends can ensure this parameter is respected, so I don't think there's any problem here. |
6c79b87
to
b6ea338
Compare
b6ea338
to
99dfdd6
Compare
@kinetiknz don't really want to bother, though it would be cool to know what's your plan with this. If the chances of it getting merged any time soon are small, then I'll consider making a custom branch for Dolphin (as there isn't one now). |
I want to re-enable this, but haven't had time to sit down and look at your code (thanks for working on this, btw!). I've requested the review for myself, so I'll be reminded to look at it, and I'll find some time to do so, hopefully soon. |
I'm sorry. I'm going to ask for an ETA again. If it's still unknown, I'll try to branch this on the dolphin repo. |
Sorry for the trouble. We can probably land something as long as we can keep the current behaviour, so that we can both do QA and experiment in our own timelines. |
I've done a push on a separate branch to run CI, since it runs on Windows since last week: https://github.com/mozilla/cubeb/actions/runs/4863054212. |
Nice. |
I don't think you can do anything. I want to give it a quick run on the Firefox CI, because it's very thorough, but it's having an outage at the moment, and refuses new push, I just about could push #542 before it closed. Does your workload contain a lot of duplex (input+output) streams? It seems like it's easier to have it working well when you're only running one side, but I don't remember exactly what we saw. |
I did not test IAudioClient3 on input, but it's not enabled by default |
fyi - For many users, like me, the entire reason for low latency is for input, so that you can play along with the output by plugging in your electric guitar or keyboard or whatever. With the currently latency that is simply implausible. |
We can merge support for output only, and continue iterating on the input side if need be, we've taken too much time to merge this. Lots of people need only output, lots of people need both -- Firefox needs both, for example, but for if The outage on our CI is resolved, here's the push: https://treeherder.mozilla.org/jobs?repo=try&revision=c46c26bb245374e3acdc24652c271562718bfede. |
All good? Do I need to do anything for this to proceed? |
All good, in the sense that it's green both here, and on the Firefox infra, but that's not real machine with their diverse hardware, drivers and other moving bits. I'm having a final look at the code now. I'm thinking maybe we want to make it a bit more configurable than the current code, I'll take care of that by adding patches on top of your branch. Using flags maybe, Windows only. All that to say that I'm looking into it, I don't think there's much to do but wait, sorry it takes so long. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Generally looks good, I'm going to test run it with a collection of weird devices I have accumulated over the years (but there's a few bank holidays coming up here in France, so likely next week). I'm also wondering if Windows 11 or more recent versions of 10 behave properly with input and output (that would be ideal!).
Thanks a lot in any case for the patch, and sorry for the time it takes...
@padenot is there anything specific you'd still like me to address? |
@padenot sorry to bother again, any updates on this? |
Sorry for the delay. We're almost done with fixing the issues found after merging #542 (on WASAPI, there's still a crash that eludes us), and we're busy fixing two issues on this library: macOS low-latency audio glitches when running duplex streams on specific configurations, and quite a number of crashes on Android. Crashes and existing quality issues take precedence over optimizing existing well functioning code. That said, I've been playing with this a bit more, and it looks like this is behaving better on recent Windows, so it's likely that when we've fixed those two issues on macOS and Android, we'll get this merged. Having so many users with so diverse hardware running Firefox makes even rare bugs important, and I think it's better for everybody to have stable code on the Has this code been running somewhere in production? |
@padenot Nice. No, this code has only been tested by me and a couple of testers online. |
Yeah, that's the real issue with all this. I appeared to work fine on the machine we have, so we shipped it, and the latencies were indeed lower, but it was a train wreck in the field, and we had to disable it in emergency. It was a long time ago though. |
Yeah. I understand, but it was like 4-5 years ago now? There's been years of development by MS, and they should have fixed any bugs with it. |
Yeah, I've been chatting with other folks that are doing real-time audio on Windows and deploy to lots of random systems, and it seems to be that it's in better shape, so I'm hopeful. |
I made this PR for Dolphin (link) and it's currently in testing, though I thought to propise to Mozilla as well, to potentially get some feedback.
This PR re-activates
IAudioClient3
on WASAPI. This allows PCs with Windows 10+ to achieve lower latencies:Microsoft doc
theoretically the latency should be pretty similar to the WASAPI exclusive mode (depending on the device driver), but without its limitations.
If not supported, it will fall back to the classic/old
IAudioClient
audio mode.Most of the code was already there, though Mozilla disabled it because it gave problems with input streams (bug report). For that reason, we are only using it with output streams, and additionally, I have polished the code a lot and added handling of a few edge/error cases that were not acknowledged before.
Chromium has safely used
IAudioClient3
for years, so I have analyzed its implementation, and multiple other open source applications, to find out what might be improved here.One major problem was that the latency set by the user was in samples (48Khz on Dolphin), not in ms, but cubeb failed to convert it for device actual output sample rate, so the latency could have been set to extremely low or high values, which could have made it starve for samples.
Also, cubeb failed to check if the mixer format it generated was fully supported by(This was only partially true)IAudioClient3
, and thus sometimes it wouldn't initialize correctly. I'm not 100% sure about this, but I've been testing this with @eliasreid, who can confirm as his audio device only supports 24bit formats, and cubeb forced 16bit on it and Dolphin produced crackled sounds (it didn't seem to be a latency issue). SeeCHECK_MIXER_FORMAT_SUPPORT
for more.The code is kind of done, but there are quite a few things that could benefit from testing.
I've added some defines at the top of the files, which are all meant for testing, and I think the current configuration is the best, but if something is wrong with your output (or
IAudioClient3
fails to activate).