Steam/Game-specific troubleshooting
Introduction
See Steam/Troubleshooting first.
This page assumes familiarity with the Steam#Directory structure, Steam#Launch options, environment variables, the Steam runtime and shared libraries. The GAME
pseudo-variable is used to refer to a game's directory. When the text reads "run the game with FOO=bar
" it is implied that you either update your launch options or run the game from the command-line with the environment variable.
Contributing
- Use "game directory" or the
GAME
pseudo-variable to refer to a game's directory. - Link bug reports and sources of workarounds.
Other sources
The following links offer even more fixes and tweaks for various games which would otherwise exceed this article's purpose:
For games running with Proton, you can check the ProtonDB which lists a lot of useful user reports for specific games. You can filter searched reports by Linux distribution and by hardware. Users also describe if they had to apply tweaks.
Common steps
OpenSSL 1.0 setup
Some Steam games are built against OpenSSL 1.0. (FS#53618)
Install lib32-openssl-1.0-hardenedAUR and run the game with LD_LIBRARY_PATH=/usr/lib/openssl-1.0
.
Missing libcurl.so.4 or version CURL_OPENSSL_3 not found
Install lib32-libcurl-compat and run the game with LD_PRELOAD=libcurl.so.3
.
Steam Link
Currently Steam Link does not work with Wayland. You will only see a blank screen or even flickering when connecting to a Steam host running on Wayland. So you have to disable Wayland in /etc/gdm/custom.conf:
WaylandEnable=false
And reboot before trying again.
Squares or invisible symbols, special characters and cyrillic letters in Source-based games
Any special character may produce a square or an empty space mark in the game, main menu and game console. In practice, any characters other than latin ones are not working. The problem is that Bitstream Vera Sans
is configured as the system primary default font for latin sans-serif fonts.
First, make sure that per-user font customization files are enabled, i.e. the following file exist:
/etc/fonts/conf.d/50-user.conf
Next, create fonts.conf
file in your fontconfig directory with the following content or if the file already exist, append only the alias section to the file:
~/.config/fontconfig/fonts.conf
<?xml version="1.0"?> <!DOCTYPE fontconfig SYSTEM "fonts.dtd"> <fontconfig> <alias> <family>sans-serif</family> <prefer> <family>DejaVu Sans</family> <family>Verdana</family> <family>Arial</family> <family>Albany AMT</family> <family>Luxi Sans</family> <family>Nimbus Sans L</family> <family>Nimbus Sans</family> <family>Helvetica</family> <family>Lucida Sans Unicode</family> <family>BPG Glaho International</family> <family>Tahoma</family> </prefer> </alias> </fontconfig>
PipeWire & FMOD
If you are using PipeWire and do not have any sound in games utilising FMOD as an audio backend then you may require . Such games include Project Zomboid, Don't Starve, and Unrailed.
You will see similar to the following in your logs if this affects you.
[00:00:01]: FMOD Error: An invalid object handle was used. [00:00:10]: FMOD Error: Can't play event dontstarve/HUD/click_mouseover: An invalid object handle was used.
Games
7 Days To Die
If the game crashes on start, add the following to Steam launch options:
LD_PRELOAD="libpthread.so.0 libGL.so.1" __GL_THREADED_OPTIMIZATIONS=1 %command% -force-glcore
If the game does not recognize your screen's resolution, launch the game with Game Launcher and check the Unity screen selector option to correct the resolution. This will give you a GUI in which you can select the correct screen when the game is started.
If that does not help try running the game in 32-bit mode by checking the respective option in the Game-engine in the launcher options.
It will help the game performance if the GLCore option is checked in launcher options.
Missing libpcre.so.3 and libidn.so.11
$ ln -s /usr/lib/libpcre.so 'GAME/lib/x86_64/libpcre.so.3' $ ln -s /usr/lib/libidn.so 'GAME/lib/x86_64/libidn.so.11'
Gamepad not working
The version of libSDL2 shipped with the game seems to be out-of-date and may not support your gamepad yet. Simply remove or rename , the linker will fall back to using the up-to-date version from /usr/lib.
Amnesia: Rebirth
If you encounter a popup with on startup which immediately closes the game and you are using , install these packages if they are not already: , alsa-firmware, and lib32-alsa-plugins. Reboot and re-open the game.
And Yet It Moves
Dependencies:
Game does not start
When the game refuses to launch and prints one of the following error messages:
readlink: extra operand ‘Yet’
Try 'readlink --help' for more information.
This script must be run as a user with write priviledges to game directory
Open and surround in the following line with double quotes.
ayim_dir="$(dirname "$(readlink -f ${BASH_SOURCE[0]})")"
Leave fullscreen
There are no in-game settings for this, but fullscreen can be toggled with
Infinite loading
Create file next to the game executable: src
#define _GNU_SOURCE #include <dlfcn.h> #include <semaphore.h> #include <stdio.h> #include <time.h> #include <unistd.h> static int (*_realSemTimedWait)(sem_t *, const struct timespec *) = NULL; int sem_timedwait(sem_t *sem, const struct timespec *abs_timeout) { if (abs_timeout->tv_nsec >= 1000000000) { //fprintf(stderr, "to: %lu:%lu\n", abs_timeout->tv_sec, abs_timeout->tv_nsec); ((struct timespec *)abs_timeout)->tv_nsec -= 1000000000; ((struct timespec *)abs_timeout)->tv_sec++; } return _realSemTimedWait(sem, abs_timeout); } __attribute__((constructor)) void init(void) { _realSemTimedWait = dlsym(RTLD_NEXT, "sem_timedwait"); }
Compile with gcc -m32 -o loadfix.so loadfix.c -ldl -shared -fPIC -Wall -Wextra
Launch with
Gamepad not working
You have to enable keyboard control and map gamepad to keys.
Config for Steam:
Mouse pointer gets stuck in one direction
If the mouse pointer gets stuck in one direction, make sure GAME/usersettings.xml
contains .
If that does not fix the issue, try unplugging any joysticks or joystick adapter devices you have plugged in.
Game does not start, displays text window with unreadable text
Run the game with .
Gray water
Download the TheCenter map and copy from that map into TheIsland as described here.
Ragnarok uses TheIsland's texture, so the same procedure fixes the issue on Ragnarok as well.
Segmentation fault on startup
Caused by the games packaged libopenal. Use system libopenal to solve the segfault by running the game with with
Crash on joining a game
Set steam to 'offline mode' and try again
error. unable to load song <filename> ,came back with zero duration
If you get this in your log, install .
BADLAND: Game of the Year Edition
Refer to #Missing libcurl.so.4 or version CURL_OPENSSL_3 not found.
Broken/Incorrect Textures
Use the following launch options:
LD_PRELOAD="$LD_PRELOAD ./libSDL2-2.0.so.0 ./libSDL2_ttf-2.0.so.0 ./libSDL2_image-2.0.so.0" %command%
The issue is caused by a newer version of SDL than what the game bundles, this workaround simply has the game use the bundled libraries instead, as described here.
Game freezes after opening studio credits (opening cinematic does not play)
Try installing (as suggested in the Paradox forums).
Game does not start
Try deleting BATTLETECH/BattleTech_Data/plugins/x86_64/libc.so.6
, this should make the game run again.
"BeatCop.x86_64" is not responding
Run instead of .
No sound
Prepend to .
Adjust the audio levels in the game options.
Game launching on wrong monitor in fullscreen mode
Add the following launch option:
--eon_force_display=1
Various more fixes and tweaks can be found here
Audio crackling
Change the launch options to
PULSE_LATENCY_MSEC=60 %command%
Discussion on the variable can be found in Proton issue #1209. Lower values maintain lower audio latency but crackling may still occur; higher values are more likely to eliminate crackling but allow for higher audio latency.
BLACKHOLE
Refer to #Missing libcurl.so.4 or version CURL_OPENSSL_3 not found.
Black Mesa
Install lib32-gperftoolsAUR for 32bit version of libtcmalloc_minimal.so.4 which is needed Source.
White screen on startup
When launched the game may only display a white screen with no interface and no way to play the game. Add "-screen-fullscreen 0" to launch options.
The Book of Unwritten Tales
Dependencies:
If the game does not start, uncheck: Properties > Enable Steam Community In-Game.
The game is known to segfault when opening the settings and possibly during or before playing. A workaround from the Steam discussions is to replace the game's with one from Debian's repositories. To do that download this deb file, and extract it with :
$ dpkg -x libogre-*.deb outdir
Now replace GAME/lib/32/RenderSystem_GL.so
with the one extracted from the package.
BRAIN/OUT
If the game does not start with error message saying "invalid app configuration". Change directory to game folder:
$ cd ~/.steam/steam/steamapps/common/BrainOut/
Run game directly:
$ java -jar brainout-steam.jar
You need to have steam running in the background.
The Book of Unwritten Tales: The Critter Chronicles
See #The Book of Unwritten Tales.
To prevent the game from crashing at the end credits, change the size of the credits image as described here.
Migrating saves from other platforms
Borderlands 2 does not support cross-platform Steam Cloud syncing, you have to manually copy the files between platforms. Save locations can be found here. Make sure your user can access the files.
Using Ctrl Key
Borderlands 2 does not allow the key to be used by default. The game seems to be accessing keycodes and not keysyms, therefore xmodmap has no affect. A workaround is using setkeycodes to map the Ctrl-scancode to some other key, as described in Map scancodes to keycodes#Using setkeycodes. I use (as root) to map Ctrl to Alt before starting the game and to restore the default.
Logging into SHiFT
Out of the box you will not be able to log into SHiFT since the game expects certificates to be in , which is where Ubuntu stores them. Arch however uses . To resolve the problem, run the game with .
Game crashes nearly instantly
The game crashes in libopenal directly after launch.
Possible solution 0: Run the game with the flag. It no longer crashes in libopenal with a general protection error.
Possible solution 1: As of lib32-openal version 1.18.0-1, the game crashes instantly. The possible solutions are to downgrade lib32-openal to 1.17.2-1, or to start the game with LD_PRELOAD='$HOME/.steam/root/ubuntu12_32/steam-runtime/i386/usr/lib/i386-linux-gnu/libopenal.so.1'
.
In case there are messages like this in the terminal:
[ 671.617205] Borderlands2[2772]: segfault at 0 ip (null) sp 00000000ff9a462c error 14 in Borderlands2[8048000+235a000]
The following change may help (source):
LD_PRELOAD='./libcxxrt.so:/usr/$LIB/libstdc++.so.6' %command%
Possible solution 2: Launch steam as steam-native
as described in #Steam native runtime. If the game still fails to launch even after installing the meta package, then you might be missing some libraries. You can find those missing libraries as described in #Debugging shared libraries.
Borderlands: The Pre-Sequel
See #Borderlands 2.
Keyboard not working
This can occur with certain window managers e.g. dwm. Try a different window manager, or install and run:
$ wmname LG3D
see Java#Impersonate another window manager for more information.
Not starting via Steam
If the game appears as Running, then syncs and closes when you launch it from Steam, try creating a in the game directory containing . This should resolve the issue and let you start the game directly from the game directory. If that does not work, try using the .
Chaos Engine
Set your launch options to:
LD_PRELOAD="/usr/lib32/libpng16.so.16" %command%
If such error is seen in terminal output of steam-native:
/home/$USER/.local/share/Steam/steamapps/common/Chaos engine/TheChaosEngineSteam: /home/$USER/.local/share/Steam/steamapps/common/Chaos engine/lib/libz.so.1: version `ZLIB_1.2.9' not found (required by /usr/lib32/libpng16.so.16) /home/$USER/.local/share/Steam/steamapps/common/Chaos engine/TheChaosEngineSteam: /home/$USER/.local/share/Steam/steamapps/common/Chaos engine/lib/libz.so.1: version `ZLIB_1.2.3.4' not found (required by /usr/lib32/libpng16.so.16)
Then link the system libz.so:
cd ~/.local/share/Steam/steamapps/common/Chaos\ engine/lib mv libz.so.1 libz.so.1.old ln -s /lib/libz.so.1
Dialog boxes fail to display properly
You will not be able to read or see anything, and you will have this in your logs:
Fontconfig error: "/etc/fonts/conf.d/10-scale-bitmap-fonts.conf", line 69: non-double matrix element Fontconfig error: "/etc/fonts/conf.d/10-scale-bitmap-fonts.conf", line 69: wrong number of matrix elements
Workaround for the bug is available here (replace ).
Game not starting
If you set to something other than , Cities Skylines will put some files in and some hard-coded in ~/.local/share/Paradox Interactive
.
Unset the Variable to fix this issue.
Textures not rendering properly
Run the game with .
Game crashes in loading screen when Node Controller or Intersection Marking tool are enabled in Content Manager
If the game crashes with one or both of the above mods enabled when loading a save or starting a new game but works fine with both mods disabled, install .
Civilization V
For old versions of PulseAudio (<12.0), use .
If libopenal.so.1
is not in , you may need to install after making sure multilib is enabled.
If you are experiencing heavy lag (less than 1fps) or the game crashes on startup, try adding the following paths to LD_PRELOAD: .
Stuttering sound with PulseAudio
Game crashes seconds after loading a map
If you have a CPU with more than 8 threads (such as AMD Ryzen), set to 16
in in game directory.
Alternatively, you can limit the number of threads the game uses by adding to the launch options:
Game crashes after intro video with "Unable to load texture (LoadingBaseGame.dds)" / configuration reset at startup
The issue is a result of the game calling some file in a case-insensitive manner.
The solution is either to install the game on a case-insensitive file system like VFAT, or on a mount point for .
It is not enough the game is in a case-insensitive filesystem, but also the configuration/data directory at "~/.local/share/Aspyr/Sid Meier's Civilization 5" needs to be in a case-insensitive filesystem or mount point. If the data directory is in a case-sensitive filesystem, the game will not work correctly and symptoms such as configuration getting constantly reset can be observed.
Game crashes on startup with an error in libpulsecommon-12.0.so"
Run the game with
Steam Overlay not working
If the Steam Overlay does not show up simply add
LD_PRELOAD='/home/USERNAME/.local/share/Steam/ubuntu12_32/gameoverlayrenderer.so' %command%
to the launch options in the properties of the game in Steam.
Crashes during __memcpy_ssse3
This appears to be a memory alignment bug that can be corrected by compiling the libraries with -mstackrealign. GDB can also be used to run it as-is with the following launch options: LD_PRELOAD=/usr/lib/libcurl.so.4 /bin/gdb -windows -batch -return-child-result -nx -eval-command="run" -exec=%command%
Civilization: Beyond earth
If you are getting an instant crash/close upon launch, make sure you have the following packages installed:
You also need an older version of lib32-tbb which provides libtbb.so.2. To get this:
- Download the libtbb2 deb-package from the Ubuntu archive.
- Unpack from into the game directory.
Note that if you have a globally installed 32-bit libtbb.so.2, you will need to run the game with:
- Run the game with .
To force it to use this version. This version also resolves crashes with the following backtrace:
#0 0x08b71d06 in FireGrafix::DynamicsLock<Graphics::BuildingSkinnedDataDynamicConsts>::DynamicsLock(Graphics::SurfaceSet**, FireGrafix::SurfaceSetPoolAllocator*, unsigned short) () #1 0x08c25ffc in cvLandmarkVisSystem::cvLandmarkVisDynamicConstantUpdaterSS::HandleBuildingShaderSkinned(Graphics::FGXShaderPackageInstanceView*, FireGrafix::FGXModelNode*, FGXVector4*) () #2 0x08c25f34 in cvLandmarkVisSystem::cvLandmarkVisDynamicConstantUpdaterSS::UpdateNode(Graphics::FGXShaderPackageInstanceView*, FireGrafix::FGXModelNode*, FGXVector4*) () #3 0x08c25e2c in FireGrafix::FGXModelRenderByNodeSSExample_Shadow<cvLandmarkVisSystem::cvLandmarkVisDynamicConstantUpdaterSS, 2, FireGrafix::FGXModelRenderEndSuperclass>::RenderNode(unsigned int*, FireGrafix::FGX_SPIV_GENERIC*, FireGrafix::FGXModelNode*, FGXVector4*) () #4 0x08c24ff5 in cvLandmarkVisSystem::LandmarkRenderJob::Execute(unsigned int) () #5 0x093d26d9 in Platform::JobTask::execute() () #6 0xf749f3c0 in ?? () from /usr/lib32/libtbb.so.2 #7 0xf7497551 in ?? () from /usr/lib32/libtbb.so.2 #8 0xf7495fc3 in ?? () from /usr/lib32/libtbb.so.2 #9 0xf7491b7e in ?? () from /usr/lib32/libtbb.so.2 #10 0xf7491db7 in ?? () from /usr/lib32/libtbb.so.2 #11 0xf78f4346 in start_thread () from /usr/lib32/libpthread.so.0 #12 0xf7716026 in clone () from /usr/lib32/libc.so.6
Civilization VI
Either run with steam-native, launch option , and go to Properties > Compatibility, check "Force the use of a specific Steam Play compatiblity tool" and select "Steam Linux runtime".
If you are using Wayland, you might need to also set QT_QPA_PLATFORM=xcb
, as the game's launcher uses a version of Qt which only supports Xorg (see Wayland#Qt), another way is to replace the bundled Qt with one provided by Arch Linux . Some versions of the game also seem to require adding and will otherwise refuse to start with an error message that reads "An unrecoverable error has occurred, and Civilization VI cannot continue."
Follow #OpenSSL 1.0 setup.
Ensure that Steam Workshop mods are disabled as certain ones may cause issues following loading.
Steam Overlay not working
Since the introduction of the new launcher, the steam overlay does not work in this game. To get it working again, simlpy skip the launcher as described in #Launcher unable to load page.
If Segfault Immediately on Start
This is a strange corner case which happens infrequently at best (and the prerequisites for reproducing it are unknown), but the crash would look like this:
- Immediate segfault on start, before any windows get created
- The game creates
- The string appears in the backtrace output when running the game under
- To run under , first launch a shell and change into the game directory.
- Then (otherwise the game will not launch outside of Steam itself)
- Then run something like
- The relevant info towards the end of the output should look like this:
Thread 3 "Civ6" received signal SIGSEGV, Segmentation fault. [Switching to Thread 0x7fffe5d06700 (LWP 12315)] 0x000000000201121e in AppHost::BugSubmissionPackager::BugSubmissionPackager(unsigned long, String::BasicT<Platform::StaticHeapAllocator<5, 0>, (String::Encoding)4> const&, String::BasicT<Platform::StaticHeapAllocator<5, 0>, (String::Encoding)0> const&, AppHost::ModuleVersionInfo const&) () #0 0x000000000201121e in AppHost::BugSubmissionPackager::BugSubmissionPackager(unsigned long, String::BasicT<Platform::StaticHeapAllocator<5, 0>, (String::Encoding)4> const&, String::BasicT<Platform::StaticHeapAllocator<5, 0>, (String::Encoding)0> const&, AppHost::ModuleVersionInfo const&) () #1 0x000000000200c796 in AppHost::_INTERNAL::SetupFXSPlatform(AppHost::AppEnvironment const*, AppHost::AppOptions*) () #2 0x000000000200fea0 in AppHost::RunApp(int, char**, AppHost::Application*) () #3 0x000000000200f9bc in AppHost::RunApp(char*, AppHost::Application*) () #4 0x0000000001112d98 in WinMain () #5 0x00000000010bdab0 in ?? () #6 0x00000000010bfb31 in ThreadHANDLE::ThreadProc(void*) () #7 0x00007ffff473e08a in start_thread () from /usr/lib/libpthread.so.0 #8 0x00007ffff38f747f in clone () from /usr/lib/libc.so.6
If all of that is the case for you, the fix is pretty simple. Edit and change the line reading EnableBugCollection 1
to .
Presumably this fix will prevent any automated bug reports from reaching Aspyr, should you encounter crashes/bugs in the future, but it will at least let the game launch properly.
If Crash with Error "undefined symbol FT_Done_MM_Var"
If the game crashed with:
./GameGuide/Civ6: symbol lookup error: /usr/lib/libfontconfig.so.1: undefined symbol: FT_Done_MM_Var
The solution is to set launch options to:
LD_PRELOAD=/usr/lib/libfreetype.so.6 %command%
If the game ends up being a grey-color blank screen
The solution is to disable mods.
If the computer becomes irresponsive after "Loading" screen
This may be caused by amdgpu driver crash due to insuffcient video memory. If running an integrated graphics (eg. AMD Renoir), try allocating more memory in your BIOS.
Multi-monitor and wayland: mismatched resolution
Wayland does not define a primary monitor, so the game will show the available resolutions of an arbitrary monitor; it may not have the same size and the mouse may be off. A solution is to set an XWayland monitor as primary.
To find the list of XWayland monitors: xrandr --listmonitors
To set (eg) the XWAYLAND4 monitor as the primary:
Launcher window is huge (wrong scaling)
If the launcher window is huge (sometimes bigger than the screen), then the scaling is wrong. Add to the launch options and on next start the launcher should be usable.
Launcher unable to load page
The launcher often shows errors like . It is possible to bypass the launcher by editing the games startup configuration and changing the line to .
If FontConfig Errors on Start
Download the latest version of nwjs from here and extract its contents into your CrossCode directory, overwriting the files.
Be sure to rename to CrossCode
after.
This solution was documented to work with CrossCode 1.2 and nwjs 0.41.2 and is based on this steam post
Crash during startup : X server probably went away
If the game crashes on startup, with the logs ending with a line like the following:
[19142:19142:0315/222104.782993:ERROR:chrome_browser_main_extra_parts_x11.cc(62)] X IO error received (X server probably went away)
Add to the launch options (as documented in this steam post).
Deus Ex: Mankind Divided
Follow #OpenSSL 1.0 setup.
Requires & .
Also if you use Bumblebee set your launch options to:
LD_PRELOAD="$LD_PRELOAD:libpthread.so.0:libGL.so.1" __GL_THREADED_OPTIMIZATIONS=1 optirun %command%
The Clockwork Man
Requires (pulled in by steam-native-runtime).
Company of Heroes 2
Make sure you have installed.
Missing libpcre.so.3 and libidn.so.11
Like with #Alien Isolation you need to symlink to , as well as to , otherwise the game will fail to start.
No sound
Use the steam-runtime, e.g. set the launch options to:
~/.steam/root/ubuntu12_32/steam-runtime/run.sh %command%
Flashing screen with primus
Set PRIMUS_SYNC=2
in the launch options.
Invisible symbols, special characters and cyrillic letters
Check #Squares or invisible symbols, special characters and cyrillic letters in Source-based games
Game can't launch and crash with black screen
This problem was found after the kernel update to 5.17: the game does not start properly.
A possible workaround is to change , rename it to , then add to the startup parameters. The game will lose the background of the main game interface, but can run normally.
Game starts on the wrong screen
If it happens, go into fullscreen windowed or windowed mode and drag the window to the correct monitor. Then go back into fullscreen, the game should now be on the correct monitor.
Cannot reach bottom of the screen on menus
If you have a secondary monitor you might have a part of your lower screen you cannot reach in menus. If on Gnome you can try to open the overview (Super key) and drag the game to the other monitor and back.
If you are not on Gnome or dragging the window back and forth did not work you can try to install and run this command, where X and Y is the offset of the window and H and W is the size.
wmctrl -r "Counter-Strike: Global Offensive - OpenGL" -e 0,X,Y,H,W
Example: SecondaryMonitor: on the left 2560x1600, GamingMonitor: on the right 2560x1440).
wmctrl -r "Counter-Strike: Global Offensive - OpenGL" -e 0,2560,0,1600,1200
Here X and Y is 0,2560 to move the window to the monitor on the right and H and W 1600,1200 is set to match the in-game resolution.
Sound is played slightly delayed
See PulseAudio/Troubleshooting#Laggy sound for a possible solution.
Mouse not working in-game
If your mouse works in the main menu but not in-game, run the game with SDL_VIDEO_X11_DGAMOUSE=0
.
If it still doesn't work, turn off "Raw Input" in the in-game settings.
Brightness slider not working
Install and run to find out the name of your connected display output.
Edit and add the following lines (adapt output_name):
# gamma correction xrandr --output output_name --gamma 1.6:1.6:1.6 # play with values if required STATUS=42 while [$STATUS -eq 42]; do ... done # restore gamma xrandr --output output_name --gamma 1:1:1 exit $STATUS
Microphone not working
CS:GO uses the default PulseAudio sound device ignoring what is configured in Steam settings.
First find out the source name of your microphone (it should start with ):
$ pacmd list-sources
Then set the default device (change the name accordingly):
$ pacmd set-default-source device_name
Also lower the microphone level to 60% otherwise you will get some nasty background noise and you will be difficult to understand (change the name accordingly):
$ pacmd set-source-volume device_name 0x6000
Mouse is unrensponsive or moves slowly
Set launch options to:
vblank_mode=0 %command%
Works with almost any other game.
Game crashes on startup with game controller plugged in
- The solution is to add
-nojoy
to the launch options: csgo-osx-linux issue #1757
- Another solution: delete startup video: csgo-osx-linux issue #2659
Some texts are missing or mis-positioned
Generate the locale will solve the problem.
Game does not start
Search for Player.log (might be in )
If it says somewhere in Player.log
FMOD failed to get number of drivers ... An error occured that was not supposed to. Contact support.
Unity is probably having problem with some pulse audio libraries.
Remove or rename all instances of libpulse-simple* files in , , , .
No audio
SDL uses PulseAudio by default, so to use it with ALSA you need to set the environment variable.
Oddly sized starting window
You can make full screen mode the default by setting in ~/.paradoxinteractive/Crusader Kings II/settings.txt
.
DLCs not detected
If the DLC tab in the launcher is not selectable, rename the directory in the game directory to dlc
.
Game takes ages to start
If you are using a nvidia graphics card, make sure you have enabled the DRM kernel mode setting.
Game does not start at all
If the game stopped launching after Patch 3.3 (when the game became 64-bit only), install .
Crashes after splash screen
The following error occurs if launching Steam from the terminal.
FMOD ERROR: UpdateFMOD SystemUpdate: This command failed because System::init or System::setDriver was not called.
This error is solved by installing .
Game stuck on loading screen
The Electron shipped with this game is too old for Arch Linux.
Install and run the game with .
No music
Prepend to .
Dirt
Follow #OpenSSL 1.0 setup.
Dirt Rally
Prepend to your , otherwise the game will fail to start.
To use the native libraries, installing is required, as explained in an issue on Feral Interactive's GitHub.
Game does not start when using Bumblebee optirun or primusrun
Edit to use primusrun:
LD_LIBRARY_PATH="." primusrun ./EoCApp
Game does not work with mesa
It is a known bug and they have no intention of fixing it, see the bug.
Workaround (see step by step guide)
Get the following file:
https://bugs.freedesktop.org/attachment.cgi?id=125302
and rename it to divos-hack.c
Then execute
$ gcc -s -O2 -shared -fPIC -o divos-hack.{so,c} -ldl
Copy the to the game folder.
For GOG version, go to the said game folder and run Divinity with the following command
$ allow_glsl_extension_directive_midshader=true LD_PRELOAD="divos-hack.so" ./runner.sh
For steam, open a console, change to the divinity directory with
$ cd ~/.steam/steam/steamapps/common/Divinity Original Sin Enhanced Edition
Launch steam and got o the preferences of the game, and open the "Set Launch Options" dialogue. There, put the following
allow_glsl_extension_directive_midshader=true LD_PRELOAD="divos-hack.so:$LD_PRELOAD" %command%
Then just start the game.
Doki Doki Literature Club
Linux version is shipped with the Windows version, but can only be installed with Steam Play.
Native version can be started with this launch option:
Don't Starve Together
If you get a crash on start in , the problem is likely a bug in SDL1.3. Unfortunately, DST is statically linked and we cannot use LD_PRELOAD
to replace libSDL with something newer. The bug has been reported to the developer, but a possible workaround is to patch to not crash when it is incorrectly given a null parameter.
Dota 2
Dependencies:
Install/Set RADV as default Vulkan application
Valve recommend RADV (Mesa) is used instead of AMDVLK (AMD), see Vulkan to install and set default.
Switch between OpenGL and Vulkan (recommended)
Under the game launch options add the following flags:
For OpenGL:
For Vulkan:
In-game font is unreadable
Run the game with MESA_GL_VERSION_OVERRIDE=2.1
.
Error with libpangoft2
- Install the package.
- Remove and in .
- If you are using Bumblebee add to your launch options.
The game does not start
If you run the game from the terminal and, although no error is shown, try disabling: Steam > Settings > In-Game > Enable Steam Community In-Game.
Apparently the game #The Book of Unwritten Tales has the same problem. It also describes a workaround that is untested in Dota 2.
Game runs on the wrong screen
Game does not start with libxcb-dri3 error message
After a recent Mesa update, Dota 2 stopped working. The error message is:
SDL_GL_LoadLibrary(NULL) failed: Failed loading libGL.so.1: /usr/lib32/libxcb-dri3.so.0: undefined symbol: xcb_send_fd
Game has no audio
This might happen because Dota 2 is trying to output through ALSA, which has already been taken over by PulseAudio. Try installing and setting in-game audio output to 'Default'.
Steam overlay
Steam distributes a copy of libxcb which is incompatible with the latest xorg libxcb. See , .
Clear or disable shader cache for troubleshooting purposes
To clear shader cache delete delete the 570 (Dota's app ID) folder under the steam shadercache directory e.g.
/home/gaben/steam/steamapps/shadercache/
To disable shader cache add the following to dota's launch options:
-vulkan_disable_steam_shader_cache
Chinese tips and player names not shown
The Chinese characters in tips and player names are displayed as block characters.
The problem is caused by the font packages: , ttf-liberation and .
Chinese input method problem
Dota2 is compatible with IBus.
Devil Daggers
Refer to #Missing libcurl.so.4 or version CURL_OPENSSL_3 not found.
Drox Operative
If the game fails to start with "Couldn't find Database/database.dbl!", manually extract the assets. assets003.zip will overwrite some files from the previous files.
$ cd "~/.steam/root/steamapps/common/Drox Operative/Assets" $ unzip assets00[123].zip
Dungeon Souls
For AMD cards this game crashes on launch, unless you start it like this:
R600_DEBUG=mono %command%
Game crashes on startup
The game runs with the Steam setting "Force the use of a specific Steam Play compatibility tool" > "Steam Linux Runtime"
Dynamite Jack
Requires lib32-sdlAUR.
Sound Issues
When running on 64-bit Arch Linux, there may be "pops and hisses" when running Dynamite Jack. This could be caused by not having set. (However, even with set, the game may still sometimes start with this issue. Exiting and restarting the game seems to make the problem go away.)
Game does not start
If running steam with the , Dynamite Jack may have a problem starting. Check the steam error messages for this message:
/home/$USER/.steam/root/steamapps/common/Dynamite Jack/bin/main: error while loading shared libraries: libSDL-1.2.so.0: cannot open shared object file: No such file or directory
Install lib32-sdlAUR from multilib and Dynamite Jack should start up.
Weird unreadable fonts
Open , then find and change it from 1 to 0.
Shows only a black screen
Select safe mode when the game starts up.
Firewatch
If Firewatch starts but does not show anything try running Steam with
`STEAM_RUNTIME_PREFER_HOST_LIBRARIES=0 steam`
Football Manager 2014
This game will not run when installed on an XFS or reiserfs filesystem. Workaround is to install on an ext4 filesystem.
FORCED
Requires .
This game has 32-bit and 64-bit binaries. For some reason, Steam will launch the 32-bit binary even on 64-bit Arch Linux. When manually launching the 64-bit binary, the game starts, but cannot connect to Steam account, so you cannot play. So install 32-bits dependencies, and launch the game from Steam.
With steam-native
Starts with black page. Requires to be told to use the libSDL2 shipping with Steam
Add to Steam launch options for game:
LD_PRELOAD=~/.local/share/Steam/ubuntu12_32/steam-runtime/amd64/usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0 %command%
Note however, that this disables the Steam overlay as a side effect.
With steam-runtime
It works out of the box.
For the full experience, run FTK via steam-runtime instead of steam-native.
Compatibility
After installation, FTL may fail to run due to a 'Text file busy' error (characterised in Steam by your portrait border going green then blue again). The easiest way to mend this is to just reboot your system. Upon logging back in FTL should run.
The Steam overlay in FTL does not function as it is not a 3D accelerated game. Because of this the desktop notifications will be visible. If playing in fullscreen, therefore, these notifications in some systems may steal focus and revert you back to windowed mode with no way of going back to fullscreen without relaunching. The binaries for FTL on Steam have no DRM and it is possible to run the game without Steam running, so in some cases that may be optimum - just ensure that you launch FTL via the launcher script in rather than the FTL binary in the $arch directory.
Problems with open-source video driver
FTL may fail to run if you are using an opensource driver for your video card. There are two solutions: install a proprietary video driver or delete (rename if you are unsure) the library "libstdc++.so.6" inside . This is if you are using a 64bit system. In case you are using a 32bit system you have to remove (rename) the same library located into .
Artifacts when launching, Problems with openGL
Using the open source drivers, ATI for radeon cards, the game can display artifacts on screen. Run the game with MESA_GL_VERSION_OVERRIDE=3.0 %command%
Game does not start
You might get an error about missing .
Run the game with LD_PRELOAD=/usr/lib/libudev.so.1
.
Game does not start
When an error about a missing appears, try the following:
$ cd ~/.steam/root/steamapps/common/GarrysMod/bin/ $ ln -s libawesomium-1-7.so.0 libawesomium-1-7.so.2 $ ln -s ../garrysmod/bin/client.so ./
If the error mentions a missing library for , install .
Opening some menus causes the game to crash
Most menus work fine, but ones with checkboxes (LAN multiplayer, mounted games list) do not work at all. This is a bug in the menu code.
If you prefer the default menu style and do not mind a hacky solution: Simon311 has written code with instructions to fix it.
If you do not care for the default menu style and want a more stable but feature-incomplete solution, Facepunch developer robotboy655 has written a new menu.
Game crashes after attempting to join server
While in the process of joining a server, downloading resources, etc, the game seems to hang and after a while, perhaps during the "sending client info" portion the game crashes, usually without any error messages. Error does not give much information, however, the process for Garry's mod is killed.
This issue arises more often when joining servers with many addons like DarkRP servers specifically.
The problem seems to correlate with a weak GPU and the game is timing out from the server, so if the GPU is the problem, lowering the graphics settings to the minimum should fix the problem.
The problem seems to be related to RAM usage, once you hit around 2GB of RAM used, the game will crash. Servers with many addons have much more RAM usage, and lowering graphics settings to the minimum lowers RAM usage and mitigates crashes.
Using the experimental x86-64 branch may help mitigate this issue, however keep in mind that some addons may return errors while using this branch.
Gods will be watching
Follow #OpenSSL 1.0 setup.
GRID Autosport
Follow #OpenSSL 1.0 setup.
Black screen when trying to play
Run the game with .
Guns of Icarus Online
If you encounter problems, check out the error log:
~/.config/unity3d/Muse Games/GunsOfIcarusOnline/Player.log
version `CURL_OPENSSL_4' not found (required by /usr/lib/libdebuginfod.so.1)
Install the package and include 'libcurl.so.4' in your LD_PRELOAD in your shell environment like so:
export LD_PRELOAD=$LD_PRELOAD libcurl.so.4
Crashes when trying to load a game
Prepend to .
Hacker Evolution
Requires .
Invisible text
Half-Life uses microsoft fonts to display text, see Microsoft fonts for ways to install them.
Cyrillic fonts problem
This problem can be solved by deleting "Helvetica" font.
The game does not start via Steam
Prepend to .
No sound
Hammerwatch opens with a popup: "Sound Error" -- "Could not initialize OpenAL, no sounds will be played. Try updating your OpenAL drivers."
OpenAL, which Hammerwatch uses, defaults to PulseAudio. To change that, add the following line to :
drivers=alsa,pulse
This way, Hammerwatch will use ALSA. This solution was found here.
Compatibility
If the game refuses to launch and throws you into a library installer loop, run the executable instead of the script.
Japanese text invisible
Install and .
If FontConfig Errors on Start
Follow the same process described in #CrossCode.
Game crashes upon launch
Install .
The controller does not work
Install and run the game with .
See the following Steam Community discussions:
It is suggested to run the next_update branch to get new fixes, there however currently is a libcurl segfault keeping it from starting without special workarounds.
Missing libcurl.so.4 or version CURL_OPENSSL_3 not found
Refer to #Missing libcurl.so.4 or version CURL_OPENSSL_3 not found.
Slowness of loading screen for open-source drivers
Install and then change the renderer option in the game launcher to llvmpipe after a system restart.
Once done the loading screen scene would then be fixed and should load up as normal for open-source drivers.
Imperator: Rome
Paradox Launcher freezes or crashes after start. Set your launch options to:
LD_PRELOAD=/usr/lib/libc.so.6 %command%
Screen freezes every ~3 seconds. Run the following command:
sudo chmod o-rx /dev/input/
After playing, undo it with:
sudo chmod o+rx /dev/input/
The Inner World
Requires java-commons-codecAUR for sound support.
Bringing up the inventory or main menu
Hold the tab key.
Cutscenes
The game has cutscenes. It starts directly with a cutscene before you start the actual game in the backyard. To see these cutscenes you need to use Oracle's Java instead of the OpenJDK.
Furthermore you need the package .
There seem to be problems with the Steam overlay. Try to run the game directly with .
Note that cutscenes open in a new window. So pay attention to that and switch to the new window to enjoy the movies.
See the Steam Forums for details.
Game does not start
Set the following launch option
LD_PRELOAD='/usr/$LIB/libstdc++.so.6:/usr/$LIB/libgcc_s.so.1:/usr/$LIB/libxcb.so.1:/usr/$LIB/libgpg-error.so' %command%
Interloper
Requires .
Game does not start
The game can sometimes segfault due to an incompatibility with the Steam Runtime's .
Invisible Apartment
Requires .
Game does not start
If the game does not run when you launch it via Steam, try to directly run in the game directory.
Joe Danger 2: The Movie
Requires .
Compatibility
Game only worked after obtaining from the Humble Bundle directly and was installed.
Kerbal Space Program
See Kerbal Space Program.
Cannot change screen resolution
If trying to modify the resolution in-game crashes your desktop environment, edit :
[WinDrv.WindowsClient] WindowedViewportX=width WindowedViewportY=height FullscreenViewportX=width FullscreenViewportY=height MenuViewportX=width MenuViewportY=height [SDLDrv.SDLClient] WindowedViewportX=width WindowedViewportY=height FullscreenViewportX=width FullscreenViewportY=height MenuViewportX=width MenuViewportY=height
Windowed mode
Uncheck fullscreen in the options menu, and press Ctrl+g
to stop mouse capturing.
Stuttering sound
KillingFloor comes with its own OpenAL library .
Back it up, install or lib32-openal (if using a 64bit system).
Then symlink the installed system library ( or ) to openal.so
.
Missing Chinese font
L4D2 looks for the WenQuanYi font to render Chinese text with. You can either install a package that provides the font, such as or , or configure a fallback font:
Game Light Too Dark
Reasons of too dim in-game environment light varies, one of which is dedicated GPU is not employed.
According to multiple steam guide, please run this game using Nvidia GPU with 32-bit libraries support.
Lethal League
Requires .
Life is Strange
Requires gconfAUR.
Little Racers STREET
Install .
Move/backup .
Symlink to .
Game does not start
The 64-bit version fails to start. Either use the 32-bit version in the game directory or start the 64-bit version like so:
LD_PRELOAD=~/.steam/root/ubuntu12_32/steam-runtime/amd64/usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0 ./tld.x86_64
Game starts, but some overlay text is missing and cutscenes shows black screen
In addition to the command above, add the following to the Steam launch command:
-screen-fullscreen 0 -screen-width WIDTH_PIXELS -screen-height HEIGHT_PIXELS
For example, if you have a screen resolution of 1280x720 and are launching the x64 version from the terminal (within the directory which contains the binaries), the full command would be:
LD_PRELOAD=~/.steam/root/ubuntu12_32/steam-runtime/amd64/usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0 ./tld.x86_64 -screen-fullscreen 0 -screen-width 1280 -screen-height 720
and from Steam, the complete game launch options would be:
LD_PRELOAD=~/.steam/root/ubuntu12_32/steam-runtime/amd64/usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0 %command% -screen-fullscreen 0 -screen-width 1280 -screen-height 720
Cutscenes are still black
Turn off Vertical Sync in the Display options, and/or set POST FX to Low in the Quality options, and/or turn global Quality options down a notch.
Cursor disappears
Go to Options > Controls, and set mouse locking to unlocked.
The options is visible only if you are navigating using your (invisible) mouse. It will not show up when navigating with a controller. One solution is to go to Options -> Controls with a controller before switching to the mouse and trying to blindly it the setting.
Game crashes in Online
If you experience crashes in GTA Online (e.g. when creating a new character), set these launch options:
PROTON_NO_ESYNC=1 WINEDLLOVERRIDES=winedbg.exe=d %command%
Graphical Issues using a NVIDIA GPU
Try launch options: -force-glcore42 -force-clamped
Indefinitely stuck at start
The game does not start if the output of the command "ip -s link" is longer than 4096 characters. That is because, in the function bitsquid::network_info(char*), where they query the networking information, they do not handle that case correctly. See this picture for reference. It was reported to upstream (Pieces Interactive) but Magicka 2 does not seem to be maintained anymore.
A dirty fix is to wrap your ip binary, as such:
Bad sound
Prepend to .
Metro: Last Light
The game does not allow you to change its resolution on a multi-monitor setup on GNOME with the AMD Catalyst drivers. A temporary workaround is to disable the side monitors. Jason over at unencumbered by facts managed to get it working with his multi-monitor setup using a single display server, he however is using Nvidia.
No sound
Install
No image
Try setting r_fullscreen off
in ~/.local/share/Steam/steamapps/common/Metro 2033 Redux/user.cfg
.
Floating heads
Run the game with .
Segmentation fault (core dumped) with Wayland
Use Xorg instead.
DLC chooser
Requires building .
Crash on startup
Set launch options to:
LD_LIBRARY_PATH="." %command%
No Sound
Install . Remove file "Move or Die/Love/linux32/libogg.so.0"
Multiwinia
Requires lib32-openal.
Crash on startup
If Multiwinia crashes on startup on X64 systems, force launching the 32-bit executable by replacing with the following script:
Natural Selection 2
is required, furthermore, you must also execute $ ln -s /usr/lib/libsndio.so x64/libsndio.so.6.1
within the root of the NS2 directory. This is because NS2 uses an older outdated version of sndio, but it is still compatible with the new version, thankfully.
For a more minimal solution, one can attempt to set the audio driver used through the environment variable . For example, or .
The environment variable must not be set to wayland
.
Try setting to if it still does not work.
Black screen at start
Edit ~/Steam/SteamApps/common/No Man's Sky/Binaries/SETTINGS/TKGRAPHICSSETTINGS.MXML
and set to and to .
White screen at start
If you get a white screen, it may seem like the game has froze, but it has not. Hold down to continue.
Nuclear Throne
Refer to #Missing libcurl.so.4 or version CURL_OPENSSL_3 not found.
Game fails to start
This problem occurs because the game use outdated libraries. Go to the game directory and remove libdrm.so.2, libGLdispatch.so.0, libstdc++.so.6 and librt.so.1. Those files usually have an equivalent already installed on the system.
File _______ will not run
The executable _______ may fail when run from the Documents folder. It also exists in the game directory and will run from there.
World generation hangs
This problem occurs with locales that use comas instead of dots to separate decimals.
Windowed mode
There is no in-game option to change to the windowed mode, you will have to edit ~/.frictionalgames/Penumbra/Overture/settings.cfg
to activate it.
Find and change it to , after this the game should start in windowed mode.
Game does not start
Several OpenGL-related errors (such as or ) are caused by Portal 2 bundling an old libstdc++ file. This error is especially common with open source Radeon drivers ().
A problem with libstdc can be fixed by running the game with .
Resolution too low
When the game starts with a resolution so low that you cannot reach the game settings,
run the game in windowed mode using the -windowed
flag.
Missing non Latin font
The phenomenon is no menu in Portal. Portal and Portal2 use Helvetica, add the following lines to :
<match target="pattern"> <test qual="any" name="family"> <string>Helvetica</string> </test> <edit name="family" mode="assign" binding="same"> <string>Source Han Sans CN</string> </edit> </match>
You can replace "Source Han Sans CN" by your favoriate and existing font.
ALSA error when using PulseAudio or Pipewire
The error:
was resolved by installing:
per PulseAudio#ALSA.
Alternatively, if running the game through Steam, you can force the game to be ran through proton, and that can resolve other audio errors.
You can do this by opening the game's properties through steam, and under "general" tick the "Force the use of a specific Steam Play comparability tool", and then select a proton version from the dropdown below
Game only starting in safe mode
If the game does not start, but steam thinks it is running, probably the Paradox launcher has problems running properly.
If this is the case, you will find some processes running in background:
Kill them all, then modify the game startup options as follows:
Eventually, if the above option has not worked, an option to skip it:
./PrisonArchitect %command%
Note: even if we are using another executable to start the game, %command% has to be added at the end of the command to trick Steam.
Project Zomboid
Requires .
No sound
Prepend to .
In the game, go to the options and set all audio to the proper volume.
Redshirt
Requires if you use PulseAudio.
Revenge of the Titans
Requires and .
Rise of the Tomb Raider
Run in an X session.
Risk of Rain
Refer to #Missing libcurl.so.4 or version CURL_OPENSSL_3 not found.
Rock Boshers DX: Directors Cut
Requires lib32-libcaca.
Impossible to save custom display settings
Although game settings menu allows to choose custom display settings, the game may have problems saving them.
In such case, adjust these settings manually in the game's file at:
"${HOME}/.local/share/Steam/steamapps/common/Saints Row the Third/display.ini"
The comments in this file explain well all the settings and acceptable values.
Incorrect screen resolution in game
This can occur when game is launched in a multi-head environment, with some monitors rotated, etc., so the game detects available screen resolutions incorrectly.
In such case, adjust and options in the file. Also, one must set option .
Game fails to launch after update to new Nvidia drivers
Run the game with appended to the LD_PRELOAD
.
Game causes GPU lockup with mesa drivers
Saints Rows IV can cause a GPU lockup when trying to play on certain AMD hardware using open source drivers: Bug 93475.
A workaround is to run the game with .
No audio
Try running:
# mkdir -p /usr/lib/i386-linux-gnu/alsa-lib/ # ln -s /usr/lib32/alsa-lib/libasound_module_pcm_pulse.so /usr/lib/i386-linux-gnu/alsa-lib/
If that does not work, try tweaking as proposed by the Steam community (Serious Sam 3: BFE uses OpenAL to output sound). If you are not using Pulse Audio, you may want to write the following configuration:
~/.alsoftrc
[general] drivers = alsa [alsa] device = default capture = default mmap = true
SJ-19 Learns to Love
If the game crashes at startup with this error in Steam's output:
/home/username/.local/share/Steam/steamapps/common/SJ-19 Learns To Love/sj-19-linux/sj-19-learns-to-love.x86_64: error while loading shared libraries: libsteam_api.so: cannot open shared object file: No such file or directory
Right click the game in steam, select Properties, and set this in Launch Options:
LD_LIBRARY_PATH=./sj-19-linux %command%
Slay the Spire
If the game does not start or crashes at startup, install .
If the game crashes with the xrandr stacktrace:
It is likely due to a known bug in LWJGL. The workaround is to change the xrandr configuration to only contain the resolution (For example: should become 2560x1440
.
If the game does not move sink input, you can edit the following file to allow sink moves:
Stick Fight: The Game
If the game does not launch, try appending to force using WINE direct3D. To do this you must have installed.
Launch error with Wayland
Install and run the game with .
Space Pirates and Zombies
Requires lib32-openal.
No audio
Try running:
# mkdir -p /usr/lib/i386-linux-gnu/alsa-lib/ # ln -s /usr/lib32/alsa-lib/libasound_module_pcm_pulse.so /usr/lib/i386-linux-gnu/alsa-lib/
If that does not work, try tweaking as proposed by the Steam community (Serious Sam 3: BFE uses OpenAL to output sound). If you are not using Pulse Audio, you may want to write the following configuration:
~/.alsoftrc
[general] drivers = alsa [alsa] device = default capture = default mmap = true
Game crash
The shipped x86 version of Spacechem does not work on x64 with the game's own libSDL* files, and crashes with some strange output.
To solve this just remove the three files , , from the game directory.
Splice
Requires glu.
Game will not start
As discussed in the Steam store page, remove from the game folder.
Shadow Tactics: Blades of the Shogun
Dependencies:
Old Pango Version Dependency
Build pango 1.27.1 and copy the libpango* libraries into the game directory as recommended here.
Unable to move or input text
When in game, you are stuck in your bed as you cannot move your character or you cannot enter text into the input fields when starting a new game. This is a bug with the SDL2 lib bundled with the game.
Install .
Modify this config line:
~/.steam/steam/steamapps/common/Stardew\ Valley/MonoGame.Framework.dll.config
<dllmap dll="SDL2.dll" os="linux" cpu="x86-64" target="./lib64/libSDL2-2.0.so.0"/>
To this (the period is removed at the beginning of target):
Start with black screen
The game by default tries to launch in fullscreen mode with a resolution of 1024x768, which does not work on some devices (for example the Samsung Series9 laptop with Intel hd4000 video).
Run the game in windowed mode by using the flag. Then change the resolution in-game.
No window opening, only sound
Happens with some AMD GPU and mesa combination, set multi_sampling=0 in ~/.local/share/Paradox\ Interactive/Stellaris/settings.txt.
On some window managers (eg Xmonad) you should set fullScreen=no.
Immediate crash to desktop
It seems that Stellaris requires a 32bit libnss_sss.so.2 to operate. You can confirm if this is your problem by running
# strace ~/.local/share/Steam/steamapps/common/Stellaris/stellaris 2>&1 | grep sss
and seeing if you get output like
# openat(AT_FDCWD, "/usr/lib32/tls/i686/sse2/libnss_sss.so.2", O_RDONLY|O_LARGEFILE|O_CLOEXEC) = -1 ENOENT (No such file or directory)
If this is indeed your problem, download the libnss-sss package from Ubuntu's repository , extract the libnss_sss.so.2 from the downloaded package, and place it at ~/.local/share/Steam/steamapps/common/Stellaris. The game should now load properly.
No sound
If using native libraries and is installed, Unity may try to use that library for sound and fail. To test if this is the problem, try removing or renaming the package files that are named . To see which files are relevant, run:
$ pacman -Qql libpulse | grep /usr/lib/libpulse-simple
/usr/lib/libpulse-simple.so /usr/lib/libpulse-simple.so.0 /usr/lib/libpulse-simple.so.0.1.0
If renaming any of those files works for you, you can proceed with the following instructions (revert any renaming you just did). Browse to the game's directory:
$ cd "$HOME/.steam/root/steamapps/common/Stephen's Sausage Roll"
And create a sub-directory that we can use to hold 0-byte look-alike library files:
$ mkdir noload/
Use to create 0-byte versions of the above files that we want the dynamic linker to skip, e.g.:
$ touch noload/{libpulse-simple.so,libpulse-simple.so.0,libpulse-simple.so.0.1.0}
After you have created these 0-byte files, you can now attempt to run the game binary directly, telling the dynamic linker to use our 0-byte files:
$ LD_LIBRARY_PATH="noload/:$LD_LIBRARY_PATH" ./Sausage.x86_64
If everything works up to this point, prepend to your .
Again, this should work because Steam checks for a directory relative to the game's directory. The dynamic linker should respect the variable and fail to load the necessary files. The game should then fallback to plain ALSA.
Superbrothers: Sword & Sworcery EP
Dependencies:
- if you use PulseAudio
The game bundles an outdated version of libstdc++ which prevents the game from starting. The following can be observed when you run Steam and S&S from the terminal:
libGL error: unable to load driver: i965_dri.so libGL error: driver pointer missing libGL error: failed to load driver: i965 libGL error: unable to load driver: i965_dri.so libGL error: driver pointer missing libGL error: failed to load driver: i965 libGL error: unable to load driver: swrast_dri.so libGL error: failed to load driver: swrast
To solve this problem remove GAME/lib/libstdc++.so.6*
. After that the game will use the libstdc++ from Steam.
System Shock 2
You get these errors when running it with the native client:
C:\windows\system32\winedevice.exe: symbol lookup error: /usr/lib32/libX11.so.6: undefined symbol: xcb_wait_for_reply64 C:\windows\system32\wineboot.exe: symbol lookup error: /usr/lib32/libX11.so.6: undefined symbol: xcb_wait_for_reply64
Just delete or rename the libxcb library it got shipped with:
mv /mnt/olhdd/steam/steamapps/common/SS2/lib/libxcb.so.1{,.old} mv /mnt/olhdd/steam/steamapps/common/SS2/lib/libxcb.so.1.1.0{,.old}
Game will not launch
If you encounter the game not launching do the following:
Cut & Paste libsteam_api.so from the "SS2/Bin" folder within the main steam common folder and transfer it to "SS2" main game folder not the sub folder "SS2/bin"
After Cut & Paste put LD_PRELOAD='/usr/$LIB/libxcb.so.1' %command% into the Launch options
Once all of these have been implemented the game should work after hitting play on steam.
Resolution fix
You may encounter some resolution problems with this game on steam not working properly in full screen mode. Do the following:
Open cam.cfg in the SS2 folder you may have to search for it via the search mode while in the game folder:
Place game_screen_size 1024 768 or game_screen_size 1920 1080 depending on your resolution & put game_full_screen 1 into bottom of the cam.cfg file.
Then go to cam_ext.cfg and next to the display setting place a simi-colon prefix next to the use_d3d_display option so it should be like this ;use_d3d_display it should then properly not go off-screen and should stay full screen within the active main screen.
CJK characters not showing in game
Install and .
Team Fortress 2
Requires .
HRTF setup
Assuming HRTF (head-related transfer function) has been properly set up in the operating system, HRTF will not be enabled unless you disable the original processing. To do so, use
dsp_slow_cpu 1
For best results, also change the following:
snd_spatialize_roundrobin 1 dsp_enhance_stereo 0 snd_pitchquality 1
Loading screen freeze
If you are a non-English (speaking) user, you have to enable "en_US.UTF-8" in the locale.gen! Generate a new locale after that.
No audio
It happens if there is no PulseAudio in your system. If you want to use ALSA, you need to launch Steam or the game directly with (From SteamCommunity).
If it still does not work, you may also need to set the environment variable AUDIODEV. For instance . Use to list the available sound cards.
Slow loading textures
If you are using Chris' FPS Configs or any other FPS config, you may have set to . This spawns multiple threads for texture loading, which may cause more jittering and lag on Linux, especially on alternative kernels. Try setting it to , the default.
"Invalid color format" Error at loading screen on integrated Intel Atom/BayTrail HD Graphics
Add the following to the game startup options:
-force_vendor_id 0x10DE -force_device_id 0x1180
These options deceive the game engine that we are having a Nvidia GPU, not Intel/AMD.
Wrong mouse sensitivity
TF2 ships with an old version of libSDL2.so. Following mastercomfig's guide helps using the Steam Runtime instead of using the bundled libSDL2 version and updates the Steam Runtime by using the Distribution shipped version.
Terraria
See the KNOWN ISSUES & WORKAROUNDS section of the release announcement.
Input Issues
The symptoms of this problem are: When moving after standing still, your character seems to vary their speed, if wearing running boots they do not activate. When jumping with an item for double jumping sometimes you double jump even if you just jumped once. Going up/down ropes seems slow/choppy.
The solution is to preload the system SDL2 libraries: For more information: Terraria Forums
Game does not start
This happens because of an incompatibility with the newer version of . To fix the problem , set your launch options to:
LD_PRELOAD=./libcurl.so.4 %command%
Sound glitches with Steam native
The bundled libOpenAL
might not work correctly, try symlinking to .
Ticket to Ride
Dependencies:
As lib32-gstreamer0.10-base is quite hard to build you can use alucryd-multilib repo for this package
Missing libGLEW.so.1.6
# ln -s /usr/lib32/libGLEW.so.1.10.0 /usr/lib32/libGLEW.so.1.6
Game immediately closes
Tomb Raider has a very heavy amount of dependency on the Steam runtime, the easiest solution is to just run it using the runtime.
If this does not solve the problem, look up the shared library dependencys of the main executable. Go into your steam folder and do
$ ldd steamapps/common/Tomb\ Raider/bin/TombRaider | grep found
Note all missing librarys and try installing them from the standard repositories and the AUR. If after that you are still missing librarys you can search on the web for them and download corresponding packaged .rpm x86 (32bit) files and extract them into to provide the missing librarys. Run ldd again and see whether you have all the necessary librarys installed. If there are no more missing librarys and the added librarys are of the correct version, architecture and 32/64bit word length and are placed on one of the the linkers search paths then the game should work.
Steam Controller not working in-game
If your Steam Controller is correctly recognized and paired but still not working in-game try the following:
- In Steam, non Big Screen, go to Settings > Account > Beta participation > Change... and in the dropdown select box select Steam Beta Update
- Restart Steam
- Go to Big Screen and start Tomb Raider
Correctly recognized means you can control the desktop mouse and Steam in Big Picture mode and the controller is shown in the Big Picture settings.
Failed to Initialize Direct3D
This can happen when switching monitors.
You need to manually edit the preferences file (found in ~/.local/share/feral-interactive/Tomb Raider/) and change the ExclusiveFullscreen option to 0. After this you should be able to successfully start the game (after which you may exit and revert that option to a 1 to restore fullscreen).
Stuck at the start menu
Tomb Raider for Linux will not start if there are any active VPNs that use TUN devices. This is because it makes incorrect assumptions about the return value of getifaddrs()
. The only reason it calls getifaddrs()
is to get the MAC address for a Version 1 UUID, and fall back to a different algorithm if getifaddrs()
returns no interfaces at all.
One optional solution for such a situation is listed down below, which fixes assumptions made by Tomb Raiders about the output of getifaddrs()
(see tomb_raider_vpn_fix/releases for the original code):
Compile it using
$ gcc -m32 -fPIC -shared file_name.c -o file_name.so -ldl -Wall
Then use the following launch option:
env LD_PRELOAD=$LD_PRELOAD:path/to/file_name.so %command%
Libfreetype/libfontconfig Incompatibility
If you are experiencing issues with launching games such as Torchlight 2 or Civilization IV, it could be due to using a newer libfontconfig than the game currently supports.
Right click the game in Steam, and set the following as its launch option:
LD_PRELOAD=/usr/lib/libfreetype.so.6 %command%
then attempt launching the game.
Alternately, re-naming or deleting these 2 files will force it to use your system's libraries:
Torchlight 2/game/lib/libfreetype.so.6 Torchlight 2/game/lib64/libfreetype.so.6
Locale incompatibility
Some users report that Torchlight 2 does not work if you do not have en_US.UTF8 in your locale.
Double check you have generated the locale needed in Steam Installation Requirements.
Graphical Glitches
This is a known issue, and it occurs because the shaders had not been ported to Linux yet by the developers. To minimize glitches and make the game playable add to your launch options, set Ocean Quality to "Potato" and Effects Quality to "Low" in the game settings.
Towns / Towns Demo
Requires Java.
Crash on launch / FMOD binding crash / audio issues
Run the game with:
LD_PRELOAD='/usr/lib/libstdc++.so.6:/usr/lib/libgcc_s.so.1:/usr/lib/libxcb.so.1:/usr/lib/libasound.so.2'
Otherwise, run the game via shell and set up proper audio device for FMOD, as discussed in .
Transmissions: Element 120
Dependencies:
Troubleshooting
Make sure you have all libraries installed. Above the standard set required by Steam runtime, the game requires few additional ones. The typical error message that indicates that is
AppFramework : Unable to load module vguimatsurface.so!
To find missing dependencies go into the game directory and run:
LD_LIBRARY_PATH=bin ldd bin/vguimatsurface.so
Look for entries that say not found.
Game will not launch
Rename or delete the following files in game directory (~/.steam/steam/steamapps/common/Transport Fever 2) as discussed in
- libstdc++.so.6
- libstdc++.so.6.0.25
Fullscreen
Game crashes if started in fullscreen mode, but starts in windowed mode. After start the window can be set to fullscreen (borderless window) if your window manager supports this. steam forum
Colors
If colors are wrong with FOSS drivers (r600g at least), try to run the game in windowed mode, rendering will be corrected. (bug report)
Sound
If sound plays choppy, try:
Resolution
If the game resolution is wrong when using a dual monitor setup and you cannot see the whole window edit and change the options and ForceFullscreenHeight
to the resolution of your monitor on which you want to play the game.
Crash on start in libX11.so.6.3.0
gdb may report a crash in XGetICValues(), probably due to a bug in SDL1.3; fortunately SDL2.0 is compatible with trine 2, so just force it and see if it works by modifying the steam launch options (or by script/commandline if using the drm free version).
Blank screen with sound only on startup
Run the game with .
Unbound: Worlds Apart
If your controller does not work, try selecting the game in your inventory, click the gear icon on the right, then Properties, Controller, and select Disable Steam Input in the dropdown.
Unity of Command
Requires .
Squares
If squares are shown instead of text, try removing .
No audio
If you get this error:
ALSA lib dlmisc.c:254:(snd1_dlobj_cache_get) Cannot open shared library /usr/lib/i386-linux-gnu/alsa-lib/libasound_module_pcm_pulse.so
Try running:
# mkdir -p /usr/lib/i386-linux-gnu/alsa-lib/ # ln -s /usr/lib32/alsa-lib/libasound_module_pcm_pulse.so /usr/lib/i386-linux-gnu/alsa-lib/
Unity3D
Games based on the Unity3D engine, like War For The Overworld or Pixel Piracy may need the package to understand that they run on Linux and work properly.
Locale settings
Games made in C# often have a problem with some locales (e.g. Russian, German) because developers do not specify locale-agnostic number formatting. This can result in some game screens loading only partially, problems with online features or other bugs.
To work around this, run the game with .
Affected games: FORCED, Gone Home, Ichi, Nimble Quest, Syder Arcade.
Unity 5 sound problems
The sound system in Unity 5 changed and to be able to play games created with it you must most likely install and run PulseAudio.
Another solution is to disable the Steam runtime: in the launch options for the game, write this:
Another solution is to prevent Unity from trying to use pulseaudio using package from the AUR. Once it is installed, use the following as launch options :
Affected games: Kerbal Space Program, SUPERHOT, ClusterTruck
Game launching on wrong monitor in fullscreen mode
Unity games that do not support monitor selection will most likely launch the game on a wrong monitor.
The problem is that Unity games write the default parameter to the game config file.
This will lead to the game launching on a non-primary monitor.
When changing to value into <pref name="UnitySelectMonitor" type="int">0</pref>
for the according game, the game will start on the correct (primary) monitor.
A Unity game config file usually resides in .
Affected games: Cities: Skylines, Tabletop Simulator, Assault Android Cactus, Wasteland 2, Tyranny, Beat Cop.
Be aware that some games do not support setting that parameter, it will simply be ignored. This is the case for Pillars of Eternity, Kentucky Route Zero, Sunless Sea.
Chinese/Japanese/Korean display bug
Install and . Then
#fc-cache -fv
Game does not respond
Add the following line to your launch options :
SDL_DYNAMIC_API=/usr/lib/libSDL2-2.0.so %command%
No window opens on Wayland
Unrest
Requires .
Volgarr the Viking
Delete the directory in the game directory to get rid of the libGL errors.
No audio
If there is no audio after launching the game, install .
Launcher fails to auto-close
When running through Steam a startup option must be set or the War Thunder Launcher will not auto-close when the game exits. Doing so will prevent it from being reported as the running game on the Steam Community, and more importantly running up CPU and RAM usage in the background. Put in the Launch Options/Parameters of War Thunder on Steam.
Warhammer 40,000: Dawn of War II
Dependencies:
The start script does not point to the right direction of .
To fix it open GAME/DawnOfWar2.sh
and replace the following lines:
with:
Wasteland 2
If Wasteland 2 immediately exits when you try to launch it there may not be enough system file descriptors available. To increase the descriptor limit edit /etc/security/limits.conf and add the line:
* hard nofile 524288
Then reboot for the new limit to take effect, Wasteland 2 should now launch and this setting might also fix other games.
Worms W.M.D
The game includes several workarounds in the script, however these may not work and it is easy to get the game running without this script.
First, try running the game directly from its game directory using . If you get a "No such file or directory" error about libcurl-gnutls, install . If the game crashes after playing the intro movies, add the Steam Runtime dbus libraries to the game's library directory:
$ ln -s ~/.steam/steam/ubuntu12_32/steam-runtime/amd64/lib/x86_64-linux-gnu/*dbus* ~/.steam/steam/steamapps/common/WormsWMD/lib
Now the game should run using the default "Play Worms W.M.D" option. See also Steam community discussions and .
On some systems there are terrain bugs where holes in terrain are not rendered properly and worms can fall through terrain unexpectedly. These bugs can make the game unplayable in many situations and there is no known fix for them.
Witcher 2: Assassin of Kings
Dependencies:
Game does not start
The game will not start with SDL set to use wayland. You can have only the game run in x11 by adding the following launch options in steam:
$ SDL_VIDEODRIVER=x11 %command%
If the game does not run, enable error messages:
$ LIBGL_DEBUG=verbose ./witcher2
Wizardry 6: Bane of the Cosmic Forge
Requires DOSBox.
To fix the crash at start, open GAME/dosbox_linux/launch_wizardry6.sh
and:
- comment the line
- change the beginning of the line starting with to
Changing resolution
To change the game resolution edit the Graphics display section in . For example:
<!-- Graphics display -->
<param name="screen_width" value="1680" />
<param name="screen_height" value="1050" />
<param name="color_depth" value="0" />
<param name="fullscreen" value="true" />
<param name="ui_inset" value="10" />
Game crashes on startup
The game may crash on startup because it is linked to libz version 1.2.9, while the latest version of this library in Arch Linux is higher. The following message in the terminals appears in this case:
./X3TC_config: lib/libz.so.1: version 'ZLIB_1.2.9' not found (required by /usr/lib32/libpng16.so.16
Renaming or removing lib/libz.so.1 may help.
Game crashes on startup
The game may crash on startup because it is linked to the shadergl function of the game. Do the follow in the .../steamapps/common/X Rebirth/shadergl/shaders/common.fh file.
--- ./common.fh.orig +++ ./common.fh
@@ -574 +574 @@ - /* OUT_COLOR.rgb *= 0.0001; OUT_COLOR.rgb += half3(specstr);/**/ \ + /* OUT_COLOR.rgb *= 0.0001; OUT_COLOR.rgb += half3(specstr);*/ \
@@ -622 +622 @@ - /* OUT_COLOR.rgb *= 0.0001; OUT_COLOR.rgb += LightColor.xyz/ 10;/**/ \ + /* OUT_COLOR.rgb *= 0.0001; OUT_COLOR.rgb += LightColor.xyz/ 10;*/ \
After this workaround is implemented the game should load as normal.
XCOM
Dependencies:
- (required to enable keyboard functionality in-game)
Hangs on startup
If you are running a hybrid graphics system, try:
__GL_THREADED_OPTIMIZATIONS=0 primusrun %command%
Graphical glitches on Intel HD
XCOM: Enemy Unknown may not recognize the SDL2 shared libraries shipped with the Steam runtime. Check if the binary finds all required files and install missing packages if necessary (sdl2 and ).
Unable to start with steam native
needs which is not avaliable in arch repos, loading it from steams runtime seems to work.
LD_PRELOAD="$HOME/.local/share/Steam/ubuntu12_32/steam-runtime/usr/lib/x86_64-linux-gnu/libgconf-2.so.4" %command%