-
Notifications
You must be signed in to change notification settings - Fork 385
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
Major performance increase Audio Fixes #101
Comments
Awesome!! I really gotta get back on this project. First off I want to get upstream compatibility -- hopefully that means getting a bunch of stuff merged -- then I want to see about dynamic linking. Thank you for this! |
You and me both, I really don't want to have all this stuff forked off all over the place. Would be nice to ingest directly from libretro for the most part. |
Might be worth modifying my build script I can also give y'all the bash script I use for my nightly core builds if y'all want. I also do package my own version of emscripten (debian) so its easier for me to manage. Just some suggestions! |
When it comes to the cores we are all on the same page I feel like, it only really gets divergent when it hits the retroarch project where I want pure cores, emulatorjs hooks in and externalizes all functions, and webretro does lighter externalization. Other than that the webretro patches and emulatorjs forks do way more to ensure compatibility with emscripten. |
I got some cycles to go through my cores and a user pointed me back to your cores in linuxserver/emulatorjs#130.
Ethan at EmulatorJS discovered that rwebaudio was blocking the thread and causing slowdowns a bit ago:
libretro/RetroArch#15479
That was one part of the puzzle. Then in later versions of Retroarch ( I am using the current release) they implemented resampling quality along with the playback rate on top of using openal audio. The final missing piece was bumping it down and using 44100 for Chrome and Safari merged here:
libretro/RetroArch#16079
I went ahead and used your instructions to get 99% of the way to a core for the current release with these default setting patched in (great work btw on docs) and this is your current n64 core:
dk-old.mp4
And the new one built with the same logic for mupen but updated retroarch and default audio settings:
dk.mp4
The text was updated successfully, but these errors were encountered: