GameMode is a new daemon/lib combo for Linux that will allow you to optimize your PC for gaming. It’s not magic, it won’t suddenly make your Linux games suddenly get better performance, but it’s something that can help.
You might have seen a message box pop up with some more recent Linux ports from Feral Interactive, one that tells you that your current CPU governor is not optimised—like this:
When games end up waiting on the GPU, some CPU performance governors may downclock the CPU and then up it again later, which can result in performance problems. GameMode, as it is right now, is to help you with that. Curious about it and wanting to know a little more direct from the developers, Feral agreed to answer some quick questions I had about it:
1) Can you give us a rundown on what exactly GameMode is and why Linux gamers might need it?
“GameMode is a daemon/library combo for Linux, written in C, which allows games to request that a set of optimisations be temporarily applied to the host OS. These optimisations improve the performance of the game.
To apply these optimisations, some of our games require that users manually swap the CPU governor using sudo privileged commands. We've had some feedback from people saying that they'd prefer not to have to do so much setup in order to get the best performance from their game. Further to this, some users voiced concerns about the increased energy usage that might result from leaving the CPU in a higher power usage mode.
By automatically applying these optimisations when the game is running and removing them when it isn't, GameMode saves users the trouble of having to tinker. It also ensures that the CPU is restored to a more efficient state when they've finished playing.”
2) You say it is "intended to be expanded beyond just CPU governor states", what extras did you have in mind?
“A lot of good ideas have been put forward by beta testers, including de-activating tools like f.lux, swapping KWin from OpenGL to xrender, and changing users' chat client status to "Playing X". GameMode is Open Source, so pull requests, or forks with features like these are welcome.”
3) To be clear for our readers, is this something that will ship built-in with Feral games and will users have to do any manual steps to enable it?
“GameMode won't ship with the games; since it's open source, users will need to install it themselves using the steps on GitHub. The tool will only need to be installed once, and will work with all future Linux titles released by Feral.
It will also work with previously released games, provided users adjust their launch options on Steam.”
It’s currently under a “BSD 3-Clause License (Revised)” license and you can find out more on GitHub. It’s certainly going to be interesting to see how this project evolves over time, could end up being something extremely useful. It already made its way to the AUR for Arch users.
Once you've installed it using their instructions, you can then tell any game to use it by doing this command:
LD_PRELOAD=/usr/\$LIB/libgamemodeauto.so ./game
You can also add it as a Steam launch option for each of your games like so:
LD_PRELOAD=$LD_PRELOAD:/usr/\$LIB/libgamemodeauto.so %command%
If you wish to know what current CPU governor is in use, you can run this command in terminal:
cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
I actually had pre-announcement access to it and testing it has given me some good early results. Obviously this will be game and hardware dependent and yes, all tests were done over multiple runs to ensure it wasn't a fluke.
Testing it with F1 2017 for example, gave these FPS results:
That might not look like a big difference, however, behind the FPS results are the frame timings:
Without Game Mode | With Game Mode | |
---|---|---|
Min Frame Time | 10.32ms | 10.03ms |
Average Frame Time | 13.31ms | 11.88ms |
Max Frame Time | 19.36ms | 16.02ms |
As you can see, it has helped to reduce frame timings while increasing the overall framerate, so using GameMode (or manually using performance mode) can have an impact resulting in a smoother game. Using GameMode instead of doing it manually, does have the benefit of your CPU reverting to a more power efficient mode afterwards of course.
Testing Deus Ex: Mankind Divided was a slightly different story, as it always gave a better minimum FPS score when using GameMode, but the average and maximum showed little difference—certainly still worth it though! As for frame timings, the built-in benchmark doesn't give them.
Company of Heroes 2 is similar to Deux Ex with the benchmark mode only giving FPS scores. During my testing, both in the benchmark mode and actually playing it, the difference was noticable when using GameMode—with it being much smoother overall:
Again, to stress, your results will depend on your hardware and it's no different to manually changing your CPU governor to performance—for now (until they do more with it), although it does bring it back down to powersave or ondemand automatically which is nice.
Rise of the Tomb Raider will be the first game from Feral to have support for it integrated, so you won't need to give it any special launch options. However, you still need to install the tool yourself.
It’s great to see Feral Interactive do more open source projects, as they already have their game launcher scripts up on GitHub too.
Quoting: JahimselfMicrosoft must be like WTF!! They have million dollars (if not billion) of ressource to make a game mode that is slower than normal mode, and a small but well trained team of porter release an open source that actually works as intended!
That's not correct. Feral themselves claimed that Windows thread scheduler is way smarter when it comes to games.
Meant: What feral is doing with their tool does windows out of the box and that for years not just recently with the game mode.
Windows game mode just helps on bloated machines. But it doesn't give a benefit to high end desktops.
That this tool is achieving such big differences in performance is actually just showing how bad the Linux kernel is optimized for games.
I guess feral will show us the first game with superior performance on Linux vs. Windows. Im really excited.
Quoting: mike44Good but I would prefer not to install anything. Could we simply run a command before and after playing?
I found a simple suid program on the net, which I just had to change a bit to do the right things.
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
setuid( 0 );
system( "echo performance | sudo tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor" );
return 0;
}
and to set it back to powersave:
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
setuid( 0 );
system( "echo powersave | sudo tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor" );
return 0;
}
BUT... I forgot to install "cpufrequtils" package which the script uses to perform its governor selection. Thanks to this article I've fixed this issue.
Noting that Debian 9 doesn't seem to have the indicator-cpufreq package which some Ubuntu users have mentioned on this thread.
Quoting: Nevertheless...
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
setuid( 0 );
system( "echo performance | sudo tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor" );
return 0;
}
...
Couldn't you do the same with something like
sudo sh -c 'echo powersave | tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor'
Does it have to be compiled C code?
Quoting: wvstolzingQuoting: Nevertheless...
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
setuid( 0 );
system( "echo performance | sudo tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor" );
return 0;
}
...
Couldn't you do the same with something like
sudo sh -c 'echo powersave | tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor'
Does it have to be compiled C code?
Yes you could. But you had to provide your password before you start your game and after you quit it. You can't setuid a bash script, so a binary helps there.
Quoting: NeverthelessYou can't setuid a bash script, so a binary helps there.
I wasn't aware of that; that's good to know, thanks.
## In sudoers, edited with visudo
myuser ALL = (ALL) NOPASSWD: /usr/local/bin/mysudocommand
Last edited by Ketil on 10 April 2018 at 8:22 pm UTC
Quoting: KetilYou can setup sudo to work without password for certain commands even if they are written in bash. I prefer that over setuid.
## In sudoers, edited with visudo
myuser ALL = (ALL) NOPASSWD: /usr/local/bin/mysudocommand
Yeah I was about to ask whether you could define a Cmnd_Alias for a shell script in sudoers to then add a NOPASSWD exception; but this approach seems to be even simpler. Does it have to come at the end of the sudoers file though?
... sorry about the off-topic spam, though.
Last edited by wvstolzing on 10 April 2018 at 8:27 pm UTC
Quoting: NanobangYou're welcome. You may also wanna check AnanicyQuoting: Sputnik_tr_02I have been using cpufreq for this. If you are on ubuntu just install cpufrequtils and indicator-cpufreq then reboot, now you can see a tray icon for cpufreq and you can switch between modes at any time with a single click.
Thank you, thank you, thank you. I installedindicator-cpufreq
just now and, wow, what a difference it makes gaming!
That service allows you to control process priority of any processes. You can add any process to the config files (.rules) and set a profile (types) for it and it automatically sets the priority when the process is executed, it has premade profiles for games and such. Every bit helps i guess.
Quoting: Comandante ÑoñardoQuoting: ShmerlThey were asked multiple times, why they never worked on games that aren't Steam exclusives, but Feral never gave any sensible answer.
Actually, they gave an answer to sbolokanov:
https://www.gamingonlinux.com/articles/feral-interactive-to-show-off-rise-of-the-tomb-raider-on-linux-next-week-live-on-twitch.11543/comment_id=118863
Very interesting, and from it, it sounds like they can decide where to release, unlike many said before? Then why not on GOG?
See more from me