-
Notifications
You must be signed in to change notification settings - Fork 525
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
Turning off Vsync (again) - could it be partially feasible? #1053
Comments
If we treat it as a debugging feature until a proper solution arrives, we can just go ahead and implement something that doesn't need to be perfect or supported all platforms (eventually I want to replace the fairly useless E.g. there could be a The frame-callback architecture of sokol_app.h itself doesn't care, but some platforms (web?) may not easily support calling the frame callback unthrottled. I think it's important though that each frame callback invocation is paired with a platform-specific 'present' call, that present call might just discard the current framebuffer surface. E.g. I think in DXGI/D3D11 it should be enough to call Lines 6613 to 6623 in 090d544
|
Great! Yes, I totally view this as a debugging feature. In that case, I will start by trying to implement |
Hi, I know this has already been asked, and I fully appreciate that this is a volunteer library maintained by a single developer (thanks so much for that!!!), so this is in no way a demand, just a gentle question.
How feasible would it be to add no-vsync support to sapp only on some platforms (presumably only the ones that can support it easily)? Is the architecture of sapp even compatible with this? I want try to add this myself, if it is architecturally possible.
Why am I even asking for turning off vsync? Primarily because I need a way to estimate how much headroom I have in my rendering. Sure, I can hit 120Hz on my Mac, but I don't know how close I am to the limit. Am I at risk at falling below 120Hz if I render too many objects? I assume others may be in a similar situation.
I have partially solved this by optionally enabling GLFW as an alternative to Sokol for "benchmarking" mode. However this solution doesn't seem to scale well to other platforms. Plus, with the latest features of Sokol not being supported on Mac+OpenGL, I really have to find an alternative for Metal.
One idea that I have been entertaining is to render additional frames to an off-screen surface between v-syncs, and to count them as real frames, but it will be very tricky and possibly not representative.
The text was updated successfully, but these errors were encountered: