-
Notifications
You must be signed in to change notification settings - Fork 257
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
[WIP / RFC] New audio backend API #79
base: master
Are you sure you want to change the base?
Conversation
Quick question - is it possible to use the new backend API while still using ui-console? I'm guessing sooner or later mupen64plus-ae would stop using ui-console, but just wondering if there are easy ways to test in the transition. |
For now ui console is not updated to use this new API, but I'm working on it :) |
@@ -439,7 +440,7 @@ SOURCE = \ | |||
$(SRCDIR)/pi/pi_controller.c \ | |||
$(SRCDIR)/pi/sram.c \ | |||
$(SRCDIR)/plugin/emulate_game_controller_via_input_plugin.c \ | |||
$(SRCDIR)/plugin/emulate_speaker_via_audio_plugin.c \ | |||
$(SRCDIR)/plugin/audio_backend_compat.c \ |
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.
Is it silly to have a distinct folder plugin
and backend
? As the new backend approach is supposed to take away the concept of plugin, I just ask.
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.
I put the audio_backend_compat in the plugin folder because it is related to plugins, and will also go away when plugins are dropped.
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.
Ok! Sorry for the bad idea. ^^'
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.
Don't worry about asking questions even if you think they are "bad idea".
I'm am not perfect and I make mistake very often, so I'm glad someone look at my work and question it. That way if I have overlooked something I can correct it. Otherwise if it's not a mistake on my part, I can justify why I did it that way, so it helps other to understand my work.
I was thinking about how I woud handle other backends (game_controller input, rumble, ...) and I think it is not good if I have to add a specific library function for each different backends, even more if they all just take a pointer to a backend as parameter. CoreSetBackend(enum backend_type type, void* backend_ptr); enum backend_type For BACKEND_AI_AUDIO, the void* would be expected to be a pointer to a struct m64p_audio_backend, for BACKEND_Px_GAME_CONTROLLER it would be struct m64p_gc_backend, and so on. This way, I can add later other backends easily : just add a m64p_xxxx_backend struct and a BACKEND_XXXX entry in the backend_type enum. Plus for frontends it would be easier if we present them a unified way of setting their backends. What do you think ? Edit: It seems that given the prototype of CoreSetBackend, I could just extend the CoreDoCommand API with new commands (SET_AI_AUDIO_BACKEND, SET_P1_GAME_CONTROLLER, ...) instead of adding another function. |
Obviously not as typesafe, but much easier to maintain/expand during all the refactorings. Sounds good to me. We can always make typesafe CoreSetFooBackend() later once the dust settles, if there ever becomes a need. Interesting that you allow different backends for each player's controller, but now that I think of it you might as well. Cool... |
Come to think of it, I might as well start implementing a native front-end for mupen64plus-ae now. I would basically implement it from the ground up with barebones capability (no cheats, no fancy options, etc.) to test the new backend APIs as they come. @bsmiles32 @richard42 Rather than (or in addition to?) tracking the core API evolution in |
The libretro port now uses this new audio interface. libretro/mupen64plus-libretro@f000eeb Nice thing about this is that I now no longer have to go through the Zilmar audio plugin function pointers, so this new audio API aligns pretty well with what is needed for making the libretro port more upstream friendly. I made a custom audio backend for libretro and moved all of the audio code that libretro needs (including the audio resamplers) to mupen64plus-core/src/plugin/audio_libretro. We can later look at starting to move parts of libretro's code upstream piece by piece. |
@twinaphex : The porting you did is good, but I would have put the libretro audio backend in the libretro folder instead of core/plugins. edit: You can also get rid of: |
|'''<tt>backend</tt>''' Pointer to a structure (defined in [[Mupen64Plus v2.0 headers#m64p_types.h|m64p_types.h]]) containing pointers to the Front-end's audio backend functions. | ||
|- | ||
|Requirements | ||
|The Mupen64Plus library must already be intialized before calling this function. |
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.
initialized (intialized)
In the documentation, the Usage cell's formatting is pretty bad, and the Prototype cell is merged with other markup. See http://www.mediawiki.org/wiki/Help:Tables for more on how to format MediaWiki tables. |
@bsmiles32 : I would bump the minor number of the FRONTEND_API_VERSION returned by the core's PluginGetVersion function. Also, you can add a version number to the m64p_audio_backend struct. This will allow future changes. |
Okay, I fixed some documentation errors. Thanks for the corrections :) @richard42 : for frontend API version you mean 2.1.2 or 2.2.0 ? In an earlier comment I proposed a more generic backend setup approach which would be suitable to use for the game_controller and rumble backends for instance. I either proposed :
What's your opinion on that ? |
The frontend api version number could go up to either 2.1.2 or 2.2.0; it's a matter of personal choice. You are right that it is redundant to have a version number in the audio_backend struct, but there is an advantage to having more granular versioning in this way. As an example, the function pointer struct for the video extension API contains a "number of functions" parameter which serves this same purpose. Putting a version number in this struct allows the code in the core and frontend which handle this audio backend feature to deal with compatibility using only this single struct; they don't need access to the API version info which may be in a different part of the code. Also, it would be easier in the future to extend the api by bumping up the version number in the struct, rather than bumping up the API version number and dealing with everything that is required for that. In the end it will work either way; it's sort of a matter of personal preference, but I think it would be less work overall to put a version # in the struct. Regarding the more generic backend setup, I think either option is fine. I kind of prefer the 2nd option (through CoreDoCommand) as well |
updated:
|
@bsmiles32 What ever happened with this? |
What advantages does this API offers over the current one if there are any? Does it implies at performance improvements? if so, I'll be supporting this API, otherwise if it brings performance decrease instead, I won't be supporting this API. (If it doesn't brings any performance changes, I am fine too). |
The API change for the audio plugin/backend should not have a performance impact. The primary advantages of the new API will be: better integration with the front-end (for non-SDL platforms), and proper integration with the speed throttling mechanism for smoother frame rates and no audio drop-outs. |
This PR introduces a new "audio backend API" which should replace (when mature) the existing audio plugin mecanism.
Frontends that want to use this API should call the CoreSetAudioInterfaceBackend function (before starting emulation)
with a valid pointer to a m64_audio_backend structure.
See documentation for explanation of this structure and intended usage.
For now, usage of the API is optionnal, and therefore frontends are not required to use it.
In this case the core will use the audio plugin to emit sound.
However we encourage frontends writers to consider this new API over the audio plugin mecanism.
Feedback
@richard42 :
How should I reflect version change in the core (ie which number to bump if any) ?
In case I need to change this API later (for instance when we implement a fully accurate the AI) what would be the best course of action ?
Is my documentation good enough ? I'm not a native english speaker, so if you find mistakes please let me know so that I correct them.
@ frontend writers :
Would this API be convenient to work with ?