KWin should go into a benchmark mode when the PTS is run. It should be possible to ship a window specific rule to block compositing for the games of PTS.
This is not only useful for PTS, but would also be quite a nice thing to have for all (known) games. Given that rules might be difficult to update automatically a script might be easier. Maybe there's a way to automatically recognize all wine and steam games?
Wine apps have ClassClass "Wine" - do do all other wine applications (winrar etc. or whatever ppl. use) - notice that not all wine games will trigger a correct fullscreen mode SDL apps are not really detectable but might often (unlike usually wine games) grab the mouse (many games may) in FS mode. Then there are the id games. And their uncountable amount of FOSS variants (using SDL as backend - or not, often even ship two variants - leading to different window props) The Unreal engine. Dosbox, scummvm and other emulators. "Casual" games (pingus, supertux, tuxracer, that bubble timekiller, neverball, some billiard game, ltris, briquolo, armagetron, hedgewars, ...) Strategy games. The lokigame ports. There are certainly n hundred relevant games out there, do you want to ship n hundred rules in case someone has game x installed? What about eg. celestia? It will fit many most game criteria - yet has a menubar ... What about video players? They don't fit the major criteria (GL, no popups) yet might profit a lot when you suspend compositing while watching a movie for 2h - and if it's just battery. A solution might be a GHNS database for such blocking rules (so ppl don't have to run after window properties) issue is that the props might change every now and then... and vary between distro shipped releases It would be _much_ simpler and more robust if apps in question just set the property (also remind the mail from the mutter guys) - or ppl toggle compositing around games :-( -> What about a flag on clients? When entering fullscreen and there's no state break in the next 30secs, just suspend the compositor (doesn't fix issues with two parallel contexts or so but still boosts performance) As soon as there's a state break (ie. a popup shows up, NOTICE that our fullscreen criteria are still wrong) resume compositing and flag the client to not break compositing for its fullscreen state. The rule could accomplish that (ie. you can still have clients block compositing despite the state was broken and you can also enforce not blocking the compositor on this client) Pros compared to current situation: - better game performance than unredirecting - only one flicker on fullscreen browser showing a popup Cons compared to current situation, resp.. remaining question: - what to do with corner action effects? shortcuts for present windows etc. is no big deal -> reactivate the compositor and keep it active but really the very last thing you want to happen while fighting some Mutants is the present windows effect kicking in because the game doesn't grab the mouse and you reached a corner.
That doesn't sound like there's an easy way. Nevertheless I will install a few games and look at the properties. Hopefully the problem also solves itself once the GNOMEs have updated the spec (e.g. Wine implementing the hint already existing in the Windows API).
so I installed as a test openarena and nexiuz. The one uses "ioquake3" the other "darkplaces" as window class Both are SDL games and have problems going to fullscreen.
stupid idea. Let's hope for windows setting the correct hints and let's implement the new hints.
FTR: there's a pending(?) RR to enable FS unredirection only for override redirect windows, claiming the SDL case. -> we could twist the block rule logics for override_redirects (ie.true by default, false by rule)
(In reply to comment #6) > FTR: there's a pending(?) RR to enable FS unredirection https://git.reviewboard.kde.org/r/110088/ Just checked, D3 and Q4 are override redirects, but io* (ioquake etc) is not. Wine games are override_redirect, but not "fullscreen" (but screen-(1,1)) And of course i again forgot that unmanged are not ruled, what doesn't matter since the managed wine window with the proper title (and wine class) is not the "fullscreen" game window ... WAAHHH... :-(