-
-
Notifications
You must be signed in to change notification settings - Fork 21.5k
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
Wayland: Suspend window after frame timeout or suspend state #87750
Conversation
b57d7d6
to
eb197db
Compare
eb197db
to
d5ce5a6
Compare
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.
@akien-mga does the 1sec timeout cause issues when a window gets toggled in/out of view, especially in regards to audio? I couldn't test it yet. Edit: TBC, even if it did it would probably still cause less problems than ticking at 2000hz, but I wonder if this is something we should be aware of. |
I didn't notice any issue, even after doing some more testing now. In verbose mode, I never saw I tried:
Edit: Actually I found a way to trigger the suspend message, by locking my Plasma session. The audio kept playing fine, and unlocking the session resumed the game fine. I can hear a significant reduction in fan speed/noise when the screen is locked, so it seems to properly throttle things, and then the fans start spinning again when unlocking. I'm not pushing my luck to test Suspend-to-RAM, as it's broken currently on my new laptop on Fedora :P BTW those debug prints should likely be removed eventually:
But I guess they're fine to keep for a bit while debugging things in the new experimental Wayland support. |
You don't trigger it by losing focus, instead by suspending (e.g. hiding) the window. Try to minimize the project for a few seconds or put it behind another window. Basically, as per the comments, the whole engine will stall for one second (we could go as low as 200ms as per OP) once it gets suspended and only then enable low usage mode. That's the dirty heuristic.
All of the verbose logs are enabled by the
Yeah I guess it isn't worth to refine this thing right now as the backend is experimental and we'll need as much data as possible to fix any issue. Worth noting though. |
I still don't seem to trigger that logic when I minimize the window or make it fully covered by another one.
Well we could give 200ms a try and see if anyone reports issues, WDYT? Otherwise I'm fine merging as is and see if anyone runs into issues with that delay. |
A window is considered suspended here when it doesn't get a frame event for one second. A quick search in a I'll test ASAP to confirm whether this works, but I have a feeling that KDE is still ticking minimized windows. Edit: oops missed the second part
Yeah, I think it might be safer. That would bring the threshold up to 5 FPS but it should be very unlikely I think. Let's see, either way we have to test I suppose. I'll also add the print to the macro at this point. |
Indeed I still see |
@akien-mga gotcha. I suppose I'll have to test this a bit more myself on sway, where this behavior happens. Edit: I did some research and it might be related to the fact that KDE supports the new "suspended" state (xdg-shell version 6) while sway does not. Might be a new behavior. I'll investigate further. |
d5ce5a6
to
5b33196
Compare
All right, some updates: I've tested the 1 sec timeout on sway and audio plays properly. I think that, with audio taken out of the equation, we can assume that an application can stall for 1 second without exploding. I've plumbed the new xdg_shell state in for the "native" window handling, although we need to update libdecor if we want to add it for users running godot through it. Because of this, I'm marking this as WIP until everything is in place. Note that recent versions of KDE and Mutter (and probably also hyprland) already support this new state, so hopefully the only big compositor onto which we'll have to rely a lot on timing out is sway (see also the updated PR description). I think we're almost done :D Edit: libdecor is now plumbed too, but this particular state will require some testing. I have no idea how but I'll look if I can test this up too, although I don't know if I have a new enough KDE setup at hand. |
3c5b456
to
2e07dcf
Compare
This is a pretty popular approach that took a while for me to wrap my head around and which only recently got "official" support through an update (xdg_shell version 6), so I think that this is all-in-all a better option than the overkill 2000Hz ticking we have now :P Basically, we wait for a frame event and, if either too much time passes or we get the new `suspended` state, we consider the window as "hidden" and stop drawing, ticking by the low usage rate. This should work great for KDE and Mutter, which support the new state, but not yet for sway, which is still stuck at a very old xdg_shell version and thus falls back to the timeout approach. Be aware that if we rely on timing out the engine will have to stall for the whole timeout, which _could_ be problematic but doensn't seem like it. Further testing is needed. Special thanks go to the guys over at #wayland on OFTC, who very patiently explained me this approach way too many times.
All right, this was faster and simpler than I expected, making this up ready for review again :D Note that I still haven't tested whether the suspend state works as intended as I still haven't had the chance to run this on a proper KDE setup (I'm pretty sure I have one on an external disk though) |
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.
Tested again briefly on KDE, seems to work fine!
Thanks! |
Depends on #88374.
Fixes #87963.
This is a pretty popular approach that took a while for me to wrap my head around and which only recently got "official" support through an update (xdg_shell version 6), so I think that this is all-in-all a better option than the overkill 2000Hz ticking we have now :P
Basically, we wait for a frame event and, if either too much time passes or we get the new
suspended
state, we consider the window as "hidden" and stop drawing, ticking by the low usage rate.This should work great for KDE and Mutter, which support the new state, but not yet for sway, which is still stuck at a very old xdg_shell version and thus falls back to the timeout approach.
Be aware that if we rely on timing out the engine will have to stall for the whole timeout, which could be problematic but doensn't seem like it. Further testing is needed.
Special thanks go to the guys over at #wayland on OFTC, who very patiently explained me this approach way too many times.
FTR, the current timeout is 1 second, but I think that we could go as low as 200ms without any big consequence. Further testing is needed. Edit: Seems to not cause big issues, I think we can keep it like this for now.
Note that the new xdg-shell extension is not implemented in this PR, as I can't really test is as sway doesn't implement it yet.Edit: It is implemented now! Sway still doesn't support it though :(Bugsquad edit: