Steam/Game-specific troubleshooting

From ArchWiki

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 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.

  • ProtonDB crowdsourced Linux compatibility reports.
  • are we anti cheat yet A comprehensive and crowd-sourced list of games using anti-cheats and their compatibility with GNU/Linux or Wine/Proton.

Common steps

OpenSSL 1.0 setup

This article or section is out of date.

Reason: The linked bug report is from 2017, are there still games affected? (Discuss in Talk:Steam/Game-specific troubleshooting)

Some Steam games are built against OpenSSL 1.0. (FS#53618)

Install lib32-openssl-1.0AUR 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, for example:

/etc/gdm/custom.conf
WaylandEnable=false

And restart the login manager before continuing.

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 pipewire-alsa. 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.

tcmalloc.cc error in Source 1 games

If games such as like Counter-Strike Source, Portal, Team Fortress 2 crash at startup with the following error:

src/tcmalloc.cc:278] Attempt to free invalid pointer 0x9e13ad0 
~/.local/share/Steam/steamapps/common/Team Fortress 2/hl2.sh: line 72:  6280 Aborted                 (core dumped) ${GAME_DEBUGGER} "${GAMEROOT}"/${GAMEEXE} "$@"

Install lib32-gperftoolsAUR, and point the crashing game to the proper library using:

LD_PRELOAD=/usr/lib32/libtcmalloc_minimal.so

From this steam community post.

Crash with Unity games

Games using Unity, e.g. Papers Please, Vampire Survivors, expect PulseAudio to be installed and will quietly crash with SIGSEGV on running if it is not installed. You can also use PipeWire with pipewire-pulse.

Low FPS and bad performance with Source engine games

Usually encountered when running games like Counter-Strike Source with kernel 5.19 or higher, they will run at something like 30fps, with painful performance.[1][2]

A workaround is adding the split_lock_detect=off kernel parameter.

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.

Note: The game tends to crash or disfunction in windowed mode. It may be advisable to run it in full screen mode.

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.

Note: The game does accept .dll mods if installing mods. However, this requires an override for your Proton prefix. Use Protontricks to access winecfg for the prefix 7 Days is using, go to libraries, and add winhttp as an override. This at least works for Harmony DLL mods.

Age of Wonders 3

If game fails to start at launch you'll need to create a pthread_yield.so file. Do the following in a text editor:

extern int sched_yield(void);

int pthread_yield()
{
	return sched_yield();
}

Then save file as a pthread_yield.c then issue following command in terminal in the directory that has the file:

gcc -m32 -shared -fPIC pthread_yield.c -o pthread_yield.so

Copy pthread_yield.so in the AOW3 game folder and then edit the AoW3Launcher.sh file and add the following:

export LD_PRELOAD="pthread_yield.so"

Do this at the bottom of the file but before exec ./AoW3Launcher after this the game should then launch as normal.

Alien Isolation

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'

Append ./lib/x86_64 to your LD_LIBRARY_PATH.[3]

Missing libcrypt.so.1

Install the package libxcrypt-compat. [4]

Amnesia: The Dark Descent

Dependencies: [5]

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 <install_dir>/game/lib64/libSDL2-2.0.so.0, the linker will fall back to using the up-to-date version from /usr/lib.

Amnesia: Rebirth

If you encounter a popup with Fatal Error: Fmod could not be initialized!! on startup which immediately closes the game and you are using pipewire, install these packages if they are not already: pulseaudio-alsa, lib32-libpulse 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 GAME/AndYetItMovesSteam.sh and surround ${BASH_SOURCE[0]} in the following line with double quotes.

ayim_dir="$(dirname "$(readlink -f ${BASH_SOURCE[0]})")"

Anomaly Warzone Earth

Leave fullscreen

There are no in-game settings for this, but fullscreen can be toggled with Alt+Enter

Infinite loading

Create file loadfix.c 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 LD_PRELOAD=$LD_PRELOAD:./loadfix.so %command%

Gamepad not working

You have to enable keyboard control and map gamepad to keys.

Config for Steam: steam://controllerconfig/91200/1498735506

Aquaria

Mouse pointer gets stuck in one direction

If the mouse pointer gets stuck in one direction, make sure GAME/usersettings.xml contains <JoystickEnabled on="0" />.

If that does not fix the issue, try unplugging any joysticks or joystick adapter devices you have plugged in.

ARK: Survival Evolved

Game does not start, displays text window with unreadable text

Run the game with MESA_GL_VERSION_OVERRIDE=4.0 MESA_GLSL_VERSION_OVERRIDE=400.

Gray water

Download the TheCenter map and copy Water_DepthBlur_MIC.uasset from that map into TheIsland as described here[dead link 2024-07-30 ⓘ].

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 LD_PRELOAD=/usr/lib/libopenal.so.1

Crash on joining a game

Set steam to 'offline mode' and try again

Audiosurf 2

error. unable to load song <filename> ,came back with zero duration

If you get this in your log, install pulseaudio-alsa.

BADLAND: Game of the Year Edition

Refer to #Missing libcurl.so.4 or version CURL_OPENSSL_3 not found.

Barony

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.

BATTLETECH

Game freezes after opening studio credits (opening cinematic does not play)

Try installing libbsd (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.

Beat Cop

"BeatCop.x86_64" is not responding

Run BeatCop.x86 instead of BeatCop.x86_64.

Binding of Isaac: Rebirth

No sound

Note: This also helps with Never Alone (Kisima Ingitchuna) and No Time to Explain.

Prepend /usr/lib to LD_LIBRARY_PATH.

Adjust the audio levels in the game options.

BioShock Infinite

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.

Block'hood

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 RenderSystem_GL.so with one from Debian's repositories. To do that download this deb file, and extract it with dpkg:

$ dpkg -x libogre-*.deb outdir

Now replace GAME/lib/32/RenderSystem_GL.so with the one extracted from the .deb 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.

Borderlands 2

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 Ctrl 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 setkeycodes 0x1d 56 (as root) to map Ctrl to Alt before starting the game and setkeycodes 0x1d 29 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 /usr/lib/ssl, which is where Ubuntu stores them. Arch however uses /etc/ssl. To resolve the problem, run the game with SSL_CERT_DIR=/etc/ssl/certs.

Game crashes nearly instantly

The game crashes in libopenal directly after launch.

Possible solution 0: Run the game with the -nostartupmovies 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 steam-native-runtime 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 wmname 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 steam_appid.txt in the game directory containing 261640. This should resolve the issue and let you start the game directly from the game directory. If that does not work, try using the steam-native-runtime.

Celeste

Steam overlay is missing text

Add the following launch option (as documented in this issue):

-gldevice:Vulkan

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

Cities in Motion 2

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 FS#35039 is available here (replace /etc/fonts/conf.d/10-scale-bitmap-fonts.conf).

Cities Skylines

Game not starting

If you set $XDG_DATA_HOME to something other than $HOME/.local/share, Cities Skylines will put some files in $XDG_DATA_HOME/Paradox Interactive and some hard-coded in ~/.local/share/Paradox Interactive. Unset the Variable to fix this issue.

Textures not rendering properly

Run the game with UNITY_DISABLE_GRAPHICS_DRIVER_WORKAROUNDS=yes.

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 mono.

Cities Skylines II

Unlike the predecessor, no Linux version exists, so tick the box to force usage of Proton Experimental.

Transparent road textures, invisible buildings and graphical artefacts

To fix these major graphical issues on a system with an AMD GPU, launch Steam using RADV instead of AMDVLK, as explained on the Vulkan page.

Civilization V

Run the game with LD_PRELOAD=/usr/lib32/libopenal.so.1 %command%.[6] If libopenal.so.1 is not in /usr/lib32, you may need to install lib32-openal after making sure multilib is enabled.

For old versions of PulseAudio (<12.0), use LD_PRELOAD='./libcxxrt.so:/usr/$LIB/libstdc++.so.6:/usr/lib32/libopenal.so.1' %command%.[7]

If you are experiencing heavy lag (less than 1fps) or the game crashes on startup, try adding the following paths to LD_PRELOAD: '/usr/$LIB/libgcc_s.so.1 /usr/$LIB/libxcb.so.1 /usr/$LIB/libgpg-error.so ./libcxxrt.so /usr/lib32/libstdc++.so.6 /usr/lib32/libopenal.so.1'.[8][dead link 2021-05-17 ⓘ]

Stuttering sound with PulseAudio

See PulseAudio/Troubleshooting#Laggy sound.

Segfault with high core count CPU

The Linux port of Civ V experiences a bug which induces segfaults when running on a CPU with >8 logical cores. This includes many common CPUs, especially Ryzen 7 and i7 series parts. To diagnose this problem, check the output of dmesg:

dmesg | grep -E "Civ5XP.*segfault"

One solution is to run taskset -c 0-7 steam steam://rungameid/8930, which limits the number of cores that the game can access[9]. It is convenient to run this in the launch options:

LD_PRELOAD=/usr/lib32/libopenal.so.1 taskset -c 0-7 %command%

Another solution is to set MaxSimultaneousThreads to 16 in config.ini, which is stored in the game directory.[10]

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 ciopfsAUR.

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.

Steam Overlay not working

An invisible Steam Overlay can be fixed by preloading the overlay renderer in the launch options:

LD_PRELOAD='/home/USERNAME/.local/share/Steam/ubuntu12_32/gameoverlayrenderer.so' %command%

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:

  1. Download the libtbb2 deb-package from the Ubuntu archive.
  2. Unpack libtbb.so.2 from libtbb2_4.2_20130725-1.1ubuntu1_i386.deb/data.tar.xz/usr/lib 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:

  1. Run the game with LD_PRELOAD='./libtbb.so.2'.

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

Although there is a native #Civilization VI Linux version, many users report better performance with the #Civilization VI Windows version.

Civilization VI Linux version

Either run with steam-native, launch option LD_PRELOAD='/usr/lib/libfreetype.so.6:/usr/lib/libbrotlicommon.so.1:/usr/lib/libbrotlidec.so.1' %command%, 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 [11]. Some versions of the game also seem to require adding SDL_VIDEODRIVER=x11 and will otherwise refuse to start with an error message that reads "An unrecoverable error has occurred, and Civilization VI cannot continue."

This article or section is out of date.

Reason: The OpenSSL 1.0 package has been dropped, is this game still affected? (Discuss in Talk:Steam/Game-specific troubleshooting)

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:

  1. Immediate segfault on start, before any windows get created
  2. The game creates ~/.local/share/aspyr-media/Sid Meier's Civilization VI/AppOptions.txt
  3. The string AppHost::BugSubmissionPackager::BugSubmissionPackager appears in the backtrace output when running the game under gdb
    1. To run under gdb, first launch a shell and change into the game directory.
    2. Then echo 289070 > steam_appid.txt (otherwise the game will not launch outside of Steam itself)
    3. Then run something like gdb -ex run -ex bt -ex quit --args ./Civ6 ./Civ6
    4. 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 ~/.local/share/aspyr-media/Sid Meier's Civilization VI/AppOptions.txt and change the line reading EnableBugCollection 1 to EnableBugCollection 0.

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: xrandr --output XWAYLAND4 --primary

Launcher window is huge (wrong scaling)

If the launcher window is huge (sometimes bigger than the screen), then the scaling is wrong. Add QT_AUTO_SCREEN_SCALE_FACTOR=0 to the launch options and on next start the launcher should be usable.

Launcher unable to load page

The launcher often shows errors like Error loading page. It is possible to bypass the launcher by editing the games startup configuration ~/.local/share/Steam/steamapps/common/Sid Meier's Civilization VI/Civ6 and changing the line ./GameGuide/Civ6 to ./Civ6Sub.

Civilization VI Windows version

To play the Windows version of Civ VI, first you must force Proton usage. Then, you need to bypass the launcher which is buggy through proton. To skip the launcher, right click on the game, click Properties, and set the following Launch options:

eval $( echo "%command%" | sed "s/2KLauncher\/LauncherPatcher.exe'.*/Base\/Binaries\/Win64Steam\/CivilizationVI.exe'/" )

The Clockwork Man

Requires lib32-libidn (pulled in by steam-native-runtime).

Company of Heroes 2

Make sure you have lib32-gconfAUR[broken link: package not found] installed.

Missing libpcre.so.3 and libidn.so.11

Like with #Alien Isolation you need to symlink /usr/lib/libpcre.so to GAME/lib/arch/libpcre.so.3, as well as /usr/lib/libidn.so to GAME/lib/arch/libidn.so.11, otherwise the game will fail to start.

Cossacks 3

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=2in the launch options.

Counter-Strike: Source (CS:S)

Invisible symbols, special characters and cyrillic letters

Check #Squares or invisible symbols, special characters and cyrillic letters in Source-based games

Counter-Strike: Global Offensive (CS:GO)

Game can't launch and crash with black screen

CSGO not running on my Arch

This problem was found after the kernel update to 5.17: the game does not start properly.

A possible workaround is to change ~/.local/share/Steam/steamapps/common/Counter-Strike Global Offensive/csgo/panorama/videos, rename it to videos.bak, then add -novid 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

csgo-osx-linux issue #60

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

csgo-osx-linux issue #594

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 wmctrl 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

csgo-osx-linux issue #45

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. [12] If it still doesn't work, turn off "Raw Input" in the in-game settings.

Brightness slider not working

Install xorg-xrandr and run xrandr to find out the name of your connected display output.

Edit GAME/csgo.sh 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

csgo-osx-linux issue #573

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 alsa_input.):

$ 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

Some texts are missing or mis-positioned

Generate the en_US.UTF-8 locale will solve the problem.

Stuck on map loading "Initializing World"/"Loading Resources" with AMD Radeon RX 6000 series

csgo-osx-linux issue #2801

When using the amdgpu driver, some users [13] experience a problem with map loading taking longer than one minute and being stuck on "Initializing World" or "Loading Resources". You can try the following workaround:

Create the file

/etc/udev/rules.d/70-amdgpu-mclk.rules
KERNEL=="card0", SUBSYSTEM=="drm", DRIVERS=="amdgpu", ATTR{device/power_dpm_force_performance_level}="manual", ATTR{device/pp_dpm_mclk}="1 2 3"

This disables the lowest memory clock state "0".

Activate immediately with:

# udevadm control --reload && udevadm trigger

Creeper World 3: Arc Eternal

Game does not start

The factual accuracy of this article or section is disputed.

Reason: Would this not be fixed by using native versions instead of the Steam runtime? (Discuss in Talk:Steam/Game-specific troubleshooting)

Search for Player.log (might be in ~/.config/unity3d/Knuckle Cracker LLC/Creeper World 3/)

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 /usr/lib, /usr/lib32, ~/.steam/steam/ubuntu12_32/steam-runtime/i386/usr/lib/i386-linux-gnu/, ~/.steam/steam/ubuntu12_32/steam-runtime/amd64/usr/lib/x86_64-linux-gnu/.

CrossCode

If FontConfig Errors on Start

...
Fontconfig error: "/etc/fonts/fonts.conf", line 6: invalid attribute 'translate'
Fontconfig error: "/etc/fonts/fonts.conf", line 6: invalid attribute 'selector'
Fontconfig error: "/etc/fonts/fonts.conf", line 7: invalid attribute 'xmlns:its'
Fontconfig error: "/etc/fonts/fonts.conf", line 7: invalid attribute 'version'
Fontconfig warning: "/etc/fonts/fonts.conf", line 9: unknown element "description"
Fontconfig warning: "/etc/fonts/conf.d/10-hinting-slight.conf", line 4: unknown element "its:rules"
Fontconfig warning: "/etc/fonts/conf.d/10-hinting-slight.conf", line 5: unknown element "its:translateRule"
Fontconfig error: "/etc/fonts/conf.d/10-hinting-slight.conf", line 5: invalid attribute 'translate'
Fontconfig error: "/etc/fonts/conf.d/10-hinting-slight.conf", line 5: invalid attribute 'selector'
Fontconfig error: "/etc/fonts/conf.d/10-hinting-slight.conf", line 6: invalid attribute 'xmlns:its'
Fontconfig error: "/etc/fonts/conf.d/10-hinting-slight.conf", line 6: invalid attribute 'version'
Fontconfig warning: "/etc/fonts/conf.d/10-hinting-slight.conf", line 8: unknown element "description"
Fontconfig warning: "/etc/fonts/conf.d/10-scale-bitmap-fonts.conf", line 4: unknown element "its:rules"
Fontconfig warning: "/etc/fonts/conf.d/10-scale-bitmap-fonts.conf", line 5: unknown element "its:translateRule"
...

Download the latest version of nwjs from here and extract its contents into your CrossCode directory, overwriting the files.

Be sure to rename nw 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 --disable-gpu to the launch options (as documented in this steam post).

Crusader Kings II

No audio

SDL uses PulseAudio by default, so to use it with ALSA you need to set the SDL_AUDIODRIVER=alsa environment variable.

Oddly sized starting window

You can make full screen mode the default by setting fullscreen=yes in ~/.paradoxinteractive/Crusader Kings II/settings.txt.

DLCs not detected

If the DLC tab in the launcher is not selectable, rename the DLC 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 onetbb.

Crypt of the NecroDancer

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 pulseaudio-alsa.

Game doesn't launch at all (Wayland)

On Wayland, it's currently (as of May 2024) necessary to add SDL_VIDEODRIVER=x11 to your launch options. If you haven't added any launch options, also add %command% at the end of your launch options. Game should launch normally.

The Curious Expedition

Game stuck on loading screen

The Electron shipped with this game is too old for Arch Linux.

Install electron and run the game with electron resources/app.asar.

Death Road To Canada

No music

Prepend /usr/lib to LD_LIBRARY_PATH.

Deus Ex: Mankind Divided

This article or section is out of date.

Reason: The OpenSSL 1.0 package has been dropped, is this game still affected? (Discuss in Talk:Steam/Game-specific troubleshooting)

Follow #OpenSSL 1.0 setup.

Requires libidn11 & librtmp0.

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%

If the game will not activate and you are running systemd-resolved and Proton, follow Steam/Troubleshooting#Games running with Proton 5.13+ have no Internet connectivity.

Dirt

This article or section is out of date.

Reason: The OpenSSL 1.0 package has been dropped, is this game still affected? (Discuss in Talk:Steam/Game-specific troubleshooting)

Follow #OpenSSL 1.0 setup.

Dirt Rally

Run the beta version: right click on the game, then Properties… > Betas, enter the code: "feraldirtsupport" and click Check Code, finally, choose feral_support_branch as the version.

To use the native libraries, installing gconfAUR and libldap24AUR is required.

If you use Wayland, start the game with SDL_VIDEODRIVER=x11. Similarly, if you use PipeWire, start the game with SDL_AUDIODRIVER=pulseaudio - other backends might also work, but the default one does not.

Due to changes in how linking works, the game might not properly load its bundled dependencies. To fix this, you can either run the game with LD_LIBRARY_PATH="GAME/lib/x86_64/" or symlink the libraries from GAME/lib/x86_64/* to GAME/lib/*.[14]

The game may also segfault if you use an AMD Zen 3 or newer CPU. To fix this you can hack together a small shared library to replace the mprotect function and make sure the allocated memory has the PROT_READ access flag.[15]. Here is an example:

$ cat game.c
#include <sys/mman.h>
#include <unistd.h>
#include <sys/syscall.h>

int mprotect(void *addr, size_t len, int prot) {
  if (prot == PROT_EXEC) {
    prot |= PROT_READ;
  }
  return syscall(__NR_mprotect, addr, len, prot);
}

You can then compile the library and move the shared object to the game libraries:

$ gcc game.c -shared -o game.so
$ mv game.so GAME/lib/

After that you can add LD_PRELOAD=game.so to the game launch options.

Divinity: Original Sin - Enhanced Edition

Game does not start when using Bumblebee optirun or primusrun

Edit GAME/runner.sh 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[dead link 2024-10-12 ⓘ].

Workaround[16][dead link 2024-07-30 ⓘ] (see step by step guide[dead link 2024-10-12 ⓘ])

Get the following file: https://bugs.freedesktop.org/attachment.cgi?id=125302[dead link 2024-10-12 ⓘ] and rename it to divos-hack.c

Then execute

$ gcc -s -O2 -shared -fPIC -o divos-hack.{so,c} -ldl

Copy the divos-hack.so 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: ./DDLC.sh # %command%

Don't Starve Together

If you get a crash on start in libX11.so.6.4.0, 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 XGetICValues() 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: -gl

For Vulkan: -vulkan

In-game font is unreadable

Run the game with MESA_GL_VERSION_OVERRIDE=2.1.

Error with libpangoft2

  1. Install the pango package.
  2. Remove libpango-1.0.so and libpangoft2-1.0.so in GAME/game/bin/linuxsteamrt64.
  3. If you are using Bumblebee add LD_PRELOAD="libpthread.so.0 libGL.so.1" __GL_THREADED_OPTIMIZATIONS=1 optiru 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

See GitHub Dota 2 issue #11

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 pulseaudio-alsa 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 [17], [18].

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-dejavu, ttf-liberation and ttf-ms-fontsAUR.

See GitHub Steam issue #1688

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%

Dying Light

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 STEAM_RUNTIME=0 set. (However, even with STEAM_RUNTIME=0 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 STEAM_RUNTIME=0, 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.

Empire Total War

Weird unreadable fonts

Open ~/.local/share/feral-interactive/Empire/preferences, then find UsePBOSurfaces and change it from 1 to 0.

Euro Truck Simulator 2

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 lib32-glu.

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.

For the King

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.

FTL: Faster than Light

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 GAME/data/ 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 GAME/data/amd64/lib. 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 GAME/data/x86/lib.

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 Dev Tycoon

Game does not start

You might get an error about missing libudev.so.0.

Run the game with LD_PRELOAD=/usr/lib/libudev.so.1.

Garry's Mod

Game does not start

When an error about a missing client.so 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 libgconf-2.so.4, install lib32-gconfAUR[broken link: package not found].

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

This article or section is out of date.

Reason: The OpenSSL 1.0 package has been dropped, is this game still affected? (Discuss in Talk:Steam/Game-specific troubleshooting)

Follow #OpenSSL 1.0 setup.

GRID Autosport

This article or section is out of date.

Reason: The OpenSSL 1.0 package has been dropped, is this game still affected? (Discuss in Talk:Steam/Game-specific troubleshooting)

Follow #OpenSSL 1.0 setup.

Black screen when trying to play

Run the game with LC_ALL=C.

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 lib32-libcurl-compat and include 'libcurl.so.4' in your LD_PRELOAD in your shell environment like so:

export LD_PRELOAD=$LD_PRELOAD libcurl.so.4

Hack 'n' Slash

Crashes when trying to load a game

Prepend /usr/lib to LD_LIBRARY_PATH.

Hacker Evolution

Requires lib32-sdl2_mixer.

Half-Life

Invisible text

Half-Life uses microsoft fonts to display text, see Microsoft fonts for ways to install them.

Half-Life 2 and episodes

Cyrillic fonts problem

This problem can be solved by deleting "Helvetica" font.

Hammerwatch

The game does not start via Steam

Prepend /usr/lib to LD_LIBRARY_PATH.

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 /etc/openal/alsoft.conf:

drivers=alsa,pulse

This way, Hammerwatch will use ALSA. This solution was found here.

Harvest: Massive Encounter

Dependencies:

Compatibility

If the game refuses to launch and throws you into a library installer loop, run the Harvest executable instead of the run_harvest script.

Hatoful Boyfriend

Japanese text invisible

Install wqy-microhei and wqy-microhei-lite.

HEARTBEAT

If FontConfig Errors on Start

Follow the same process described in #CrossCode.

HuniePop

Game crashes upon launch

Install lsb-release.

Hyper Light Drifter

The controller does not work

Install lib32-sdl2 and run the game with LD_PRELOAD=libSDL2.so.

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.

Rome Total War Remastered

Slowness of loading screen for open-source drivers

Install vulkan-swrast 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 Impossible Game

Dependencies:

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 ffmpeg-compat-55AUR.

There seem to be problems with the Steam overlay. Try to run the game directly with GAME/TIW_start.sh.

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.

Insurgency

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 alsa-lib.

Game does not start

The game can sometimes segfault due to an incompatibility with the Steam Runtime's libasound.so.2.

Invisible Apartment

Requires qt5-multimedia.

Game does not start

If the game does not run when you launch it via Steam, try to directly run ./ia1 in the game directory.

Joe Danger 2: The Movie

Requires lib32-libpulse.

Compatibility

Game only worked after obtaining from the Humble Bundle directly and lib32-libpulse was installed.

Kerbal Space Program

See Kerbal Space Program.

Killing Floor

Cannot change screen resolution

If trying to modify the resolution in-game crashes your desktop environment, edit ~/.killingfloor/System/KillingFloor.ini:

[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 GAME/System/openal.so.

Back it up, install openal or lib32-openal (if using a 64bit system).

Then symlink the installed system library (/usr/lib32/libopenal.so.1 or /usr/lib/libopenal.so.1) to openal.so.

Left for Dead 2

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 wqy-zenhei or ttf-ms-fontsAUR, or configure a fallback font:

/etc/fonts/local.conf (or ~/.config/fontconfig/fonts.conf)
...
         <match target="pattern">
                <test qual="any" name="family">
                        <string>WenQuanYi Zen Hei</string>
                </test>
                <edit name="family" mode="assign" binding="same">
                        <string>Source Han Sans CN</string>
                </edit>
        </match>
...

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 lib32-glew1.10.

Life is Strange

Requires sdl2_image librtmp0 libidn11 libxcrypt-compat lib32-libxcrypt-compat gconfAUR.

Little Racers STREET

Install sdl2_mixer.

Move/backup GAME/lib64/libSDL2_mixer-2.0.so.0.

Symlink /usr/lib/libSDL2_mixer-2.0.so.0 to GAME/lib64/libSDL2_mixer-2.0.so.0.

The Long Dark

Game does not start

The 64-bit version fails to start. Either use the 32-bit version tld.x86 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.

Grand Theft Auto V

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

Magicka 2

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:

#!/bin/sh
if [ "$*" = "-s link" ]; then
    echo "<paste a smaller subset of the normal output>"
else
    /path/to/your/real/ip "$@"
fi

Mark of the Ninja

Bad sound

Prepend /usr/lib to LD_LIBRARY_PATH.

Metro: Last Light

This article or section is out of date.

Reason: References the AMD Catalyst driver, which has been abandoned for a while. (Discuss in Talk:Steam/Game-specific troubleshooting)

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.

Metro: 2033 Redux

No sound

Install pulseaudio-alsa

No image

Try setting r_fullscreen off in ~/.local/share/Steam/steamapps/common/Metro 2033 Redux/user.cfg.

Middle-earth: Shadow of Mordor

Floating heads

Run the game with __GL_ShaderPortabilityWarnings=0.

Mount & Blade: Warband

Segmentation fault (core dumped) with Wayland

Use Xorg instead, or force the session to use xcb as QT_QPA_PLATFORM.

DLC chooser

Requires building qt5-tools.

Crash on startup

Set launch options to:

LD_LIBRARY_PATH="." %command%

Move or Die

No Sound

Install lib32-libpulse. 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 GAME/run_steam.sh with the following script:

#!/bin/sh
./multiwinia.bin.x86

See [19].

Natural Selection 2

sndio 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 SDL_AUDIODRIVER. For example, SDL_AUDIODRIVER=sndio or SDL_AUDIODRIVER=alsa.

The environment variable SDL_VIDEODRIVER must not be set to wayland. Try setting SDL_VIDEODRIVER to x11 if it still does not work.

No Man's Sky

Black screen at start

Edit ~/Steam/SteamApps/common/No Man's Sky/Binaries/SETTINGS/TKGRAPHICSSETTINGS.MXML and set FullScreen to false and Borderless to true.

White screen at start

If you get a white screen, it may seem like the game has froze, but it has not. Hold down e to continue.

Nuclear Throne

Refer to #Missing libcurl.so.4 or version CURL_OPENSSL_3 not found.

OneShot

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, librt.so.1, libcrypt.so.1 and libcrypto.so.1.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.

Game fails to start on Wayland

Run the game with GDK_BACKEND=x11.

Oxygen Not Included

World generation hangs

This problem occurs with locales that use comas instead of dots to separate decimals.

Set launch options in steam to LANG=C %command%.[20]

Graphics errors, corruption and lines through tiles

This is a result of using the Zink MESA driver. If you have this globally enabled, disable it specifically for this game and launch it normally.

Penumbra: Overture

Dependencies:

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 FullScreen="true" and change it to FullScreen="false", after this the game should start in windowed mode.

Portal 2

Game does not start

Several OpenGL-related errors (such as PROBLEM: You appear to have OpenGL 1.4.0, but we need at least 2.0.0! or libGL error: driver pointer missing) are caused by Portal 2 bundling an old libstdc++ file. This error is especially common with open source Radeon drivers (radeonsi).

A problem with libstdc can be fixed by running the game with LD_PRELOAD='/usr/$LIB/libstdc++.so.6'.

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 ~/.config/fontconfig/fonts.conf:

<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.

Prison Architect

ALSA error when using PulseAudio or Pipewire

The error:

ALSA lib pcm_dmix.c:1018:(snd_pcm_dmix_open) unable to open slave

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:

ps -ef|grep paradoxlauncher

Kill them all, then modify the game startup options as follows:

LD_PRELOAD=/usr/lib64/libc.so %command%

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

No sound

Prepend /usr/lib to LD_LIBRARY_PATH.

In the game, go to the options and set all audio to the proper volume.

Redshirt

Requires lib32-libpulse if you use PulseAudio.

Revenge of the Titans

Requires libxtst and lib32-libxtst.

Rise of the Tomb Raider

Run in an X session.

Game does not start

If running in X session isn't available or is not preferred, another alternative is to do the following:

touch /usr/local/bin/pulseaudio
chmod 755 /usr/local/bin/pulseaudio

And then in the file /usr/local/bin/pulseaudio - you'll need the following

#!/bin/sh

exit 0

After this the game was found to have loaded on Linux according to some game testers.

Risk of Rain

Refer to #Missing libcurl.so.4 or version CURL_OPENSSL_3 not found.

Rock Boshers DX: Directors Cut

Requires lib32-libcaca.

Saints Row: The Third

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 display.ini 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 ResolutionWidth and ResolutionHeight options in the display.ini file. Also, one must set option VerifyResolution = false.

Saints Row IV

Game fails to launch after update to new Nvidia drivers

The factual accuracy of this article or section is disputed.

Reason: General settings not specific to this game (Discuss in Talk:Steam/Game-specific troubleshooting)

Run the game with /usr/lib32/libGLX_nvidia.so 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[dead link 2024-10-12 ⓘ].

A workaround is to run the game with R600_DEBUG=nosb.

Serious Sam 3: BFE

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 ~/.alsoftrc 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 xorg-xrandr.

If the game crashes with the xrandr stacktrace:

Caused by: java.lang.ArrayIndexOutOfBoundsException: 0
at org.lwjgl.opengl.XRandR.findPrimary(XRandR.java:326)
at org.lwjgl.opengl.XRandR.ScreentoDisplayMode(XRandR.java:315)

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: 2560x1440_60.00 should become 2560x1440.

If the game does not move sink input, you can edit the following file to allow sink moves:

~/.alsoftrc
[pulse]
allow-moves=yes

Stick Fight: The Game

If the game does not launch, try appending PROTON_USE_WINED3D=1 %command% to force using WINE direct3D. To do this you must have wine installed.

Songbringer

Launch error with Wayland

Install glfw and run the game with LD_PRELOAD=/usr/lib/libglfw.so.3.

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 ~/.alsoftrc 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

Spacechem

Dependencies:

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 libSDL-1.2.so.0, libSDL_image-1.2.so.0, libSDL_mixer-1.2.so.0 from the game directory.

Splice

Requires glu.

The Stanley Parable

Game will not start

As discussed in the Steam store page, remove bin/libstdc++.so.6 from the game folder.

Shadow Tactics: Blades of the Shogun

Dependencies:

Stardew Valley

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 sdl2.

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):

~/.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"/>

Steel Storm: Burning Retribution

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 -window flag. Then change the resolution in-game.

Stellaris

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

Steam using Proton instead of Linux Runtime

To diagnose, run Steam in a terminal and launch Stellaris. Ignore any errors mentioning "LD_PRELOAD" and look for this error:

/home/me/.local/share/Steam/steamapps/common/Stellaris/dowser.exe: /home/me/.local/share/Steam/steamapps/common/Stellaris/dowser.exe: cannot execute binary file

If you see that error then the solution is to force Steam to use the Linux runtime for Stellaris:

  1. Right-click on Stellaris and select "Properties..."
  2. Select the "Compatibility" tab.
  3. Select "Force the use of a specific Steam Play compatibility tool".
  4. Select "Steam Linux Runtime 1.0 (scout)"
Missing libnss_sss.so.2

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 [21], 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.

Game instantly crashes to desktop on Wayland

Append SDL_VIDEODRIVER=x11 to your launch options.

Launcher is blank

This is a recurring problem on Linux following the Machine Age expansion. If this happens to you, back up all your custom empires and savegames (found in $XDG_DATA_HOME/Paradox Interactive/Stellaris/ and $XDG_DATA_HOME/Steam/userdata/(your_user_ID)/281990/remote/ for cloud saves). If you have no other Paradox games installed, then remove the Paradox Interactive folder underneath $XDG_DATA_HOME/.

If you have other Paradox games installed, then do not remove the entire Paradox folder. Just remove the Stellaris folder and the launcher-v2 folder.

Attempt to run the game again. The launcher should open normally after re-downloading. Once the game launches properly, close the game and put your empires and savegames back in their folders from where you got them.

Stephen's Sausage Roll

No sound

If using native libraries and libpulse is installed, Unity may try to use that library for sound and fail. To test if this is the problem, try removing libpulse or renaming the package files that are named libpulse-simple*. To see which libpulse 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 touch 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}
Note: Only a 0-byte libpulse-simple.so.0 file may be required.

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 noload/ to your LD_LIBRARY_PATH.

Again, this should work because Steam checks for a noload/ directory relative to the game's directory. The dynamic linker should respect the $LD_LIBRARY_PATH variable and fail to load the necessary libpulse files. The game should then fallback to plain ALSA.

Superbrothers: Sword & Sworcery EP

Dependencies:

The game bundles an outdated version of libstdc++ which prevents the game from starting. [22] 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.

Sven Co-op

No sound in-game (FMOD ex error code 60)

If using pipewire, make sure you have installed lib32-pipewire

Tabletop Simulator

CJK characters not showing in game

Install wqy-microhei and wqy-microhei-lite.

Team Fortress 2

As of an update in September 2023, the game will not have the correct version of tcmalloc and will silently crash during launch.

Follow the fix outlined in #tcmalloc.cc error in Source 1 games

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, add this to your autoexec

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 SDL_AUDIODRIVER=alsa (From SteamCommunity).

If it still does not work, you may also need to set the environment variable AUDIODEV. For instance AUDIODEV=Live. Use aplay -l 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 mat_picmip to 2. This spawns multiple threads for texture loading, which may cause more jittering and lag on Linux, especially on alternative kernels. Try setting it to -1, 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: LD_PRELOAD='/usr/$LIB/libSDL2-2.0.so:/usr/lib32/libSDL2-2.0.so' For more information: Terraria Forums[dead link 2021-05-17 ⓘ]

This War of Mine

Game does not start

This happens because of an incompatibility with the newer version of lib32-curl. 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 /usr/lib32/libopenal.so to GAME/libOpenAL.so.

Ticket to Ride

This article or section is out of date.

Reason: lib32-gstreamer0.10-baseAUR is flagged for deletion and does not exist in the multilib-alucryd repository. (Discuss in Talk:Steam/Game-specific troubleshooting)

Dependencies:

As lib32-gstreamer0.10-base is quite hard to build you can use multilib-alucryd repo for this package

The Tiny Bang Story

Missing libGLEW.so.1.6

# ln -s /usr/lib32/libGLEW.so.1.10.0 /usr/lib32/libGLEW.so.1.6

Tomb Raider (2013)

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 steamapps/common/Tomb\ Raider/lib/i686/ 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 linkers search paths then the game should work.


Another alternative to this is to do the following in the Launch options:

LD_LIBRARY_PATH="$HOME/.local/share/Steam/steamapps/common/Tomb Raider/lib/i686:$LD_LIBRARY_PATH" %command%

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):

#include <stdio.h>
#include <errno.h>
#include <ifaddrs.h>

int getifaddrs(struct ifaddrs **ifap) {
   fprintf(stderr, "\n\n\n---------------- dummied out getifaddrs()!\n\n\n");
   *ifap = NULL;
   return 0;
}

void freeifaddrs(struct ifaddrs *ifap) {
   /* do nothing */
}

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%

Torchlight 2

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.

Tower Unite

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 -opengl4 to your launch options, set Ocean Quality to "Potato" and Effects Quality to "Low" in the game settings.

Towns / Towns Demo

Requires Java.

Transistor

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 [23].

Also, check out this thread [24].

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.

Transport Fever 2

Game will not launch

Rename or delete the following files in game directory (~/.steam/steam/steamapps/common/Transport Fever 2) as discussed in [25]

  • libstdc++.so.6
  • libstdc++.so.6.0.25

Trine 2

Sound

The factual accuracy of this article or section is disputed.

Reason: General settings not specific to this game (Discuss in Talk:Steam/Game-specific troubleshooting)

If sound plays choppy, try:

/etc/openal/alsoft.conf
drivers=pulse,alsa
frequency=48000

Resolution

If the game resolution is wrong when using a dual monitor setup and you cannot see the whole window edit ~/.frozenbyte/Trine2/options.txt and change the options ForceFullscreenWidth and ForceFullscreenHeight to the resolution of your monitor on which you want to play the game.

Tropico 5

Blank screen with sound only on startup

Run the game with MESA_GL_VERSION_OVERRIDE=4.0 MESA_GLSL_VERSION_OVERRIDE=400.

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 lib32-pango.

Squares

If squares are shown instead of text, try removing GAME/bin/libpangoft2-1.0.so.0.

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 lsb-release 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.

The factual accuracy of this article or section is disputed.

Reason: Would this not be fixed with only setting LC_NUMERIC? (Discuss in Talk:Steam/Game-specific troubleshooting)

To work around this, run the game with LC_ALL=C.

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: LD_LIBRARY_PATH="" %command%

Another solution is to prevent Unity from trying to use PulseAudio using pulsenomoreAUR. Once it is installed, use the following as launch options :/usr/bin/pulsenomore %command%

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 <pref name="UnitySelectMonitor" type="int">-1</pref> 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 ~/.config/unity3d/CompanyName/ProductName/prefs.

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 wqy-microhei and wqy-microhei-lite. 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

See Unity3D#No window opens: Desktop is 0 x 0 @ 0 Hz.

Unrest

Requires fluidsynth.

Volgarr the Viking

Delete the lib directory in the game directory to get rid of the libGL errors.

War Thunder

No audio

If there is no audio after launching the game, install pulseaudio-alsa.

Blank screen

If having a green or blank screen on startup, run the game with MESA_GL_VERSION_OVERRIDE=4.1COMPAT. [26][dead link 2023-07-30 ⓘ] [27][dead link 2020-04-03 ⓘ]

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 XMODIFIERS="" %command% in the Launch Options/Parameters of War Thunder on Steam.

Victor Vran

Launch failure

The game might die on launch with the following (or similar) console print:

Auto configuration failed
4034673992:error:25066067:DSO support routines:DLFCN_LOAD:could not load the shared library:dso_dlfcn.c:185:filename(libssl_conf.so): libssl_conf.so: cannot open shared object file: No such file or directory

Add the following line to your launch options :

OPENSSL_CONF=/dev/null %command%

Warhammer 40,000: Dawn of War II

Dependencies:

The start script does not point to the right direction of libasound.so.2.

To fix it open GAME/DawnOfWar2.sh and replace the following lines:

HAS_LSB_RELEASE=$(command -v lsb_release)
if [ -n "${HAS_LSB_RELEASE}" ] && [ "$(lsb_release -c | cut -f2)" = "trusty" ]; then
	LD_PRELOAD_ADDITIONS="/usr/lib/x86_64-linux-gnu/libasound.so.2:${LD_PRELOAD_ADDITIONS}"
fi 

with:

LD_PRELOAD_ADDITIONS="/usr/lib64/libasound.so.2:${LD_PRELOAD_ADDITIONS}"

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.

We Were Here

Stuck on black screen or logo on launch

Add -screen-fullscreen 0 to launch options. [28]

Worms W.M.D

The game includes a script with a minor workaround included in the Run.sh script, however this workaround alone does not usually work. The game seems to be trying to use libraries which depend on out-of date libraries. It also depends on libcurl-gnutls. It is unlikely the game will run on modern systems or be updated again by the developer.

So, editing the script is needed. At the moment (2/2024) the following works on a system, however this may change at any time (edit STEAM_RUNTIME and WORMSWMDINSTALLDIR as required):

Run.sh
#!/bin/bash

export LOGFILE=${HOME}/wormswmd.log

export LC_ALL=C
export LD_LIBRARY_PATH="/usr/lib:/usr/local/lib"

export STEAM_ROOT=~/.steam
export PLATFORM=bin32
export STEAM_RUNTIME=$STEAM_ROOT/$PLATFORM/steam-runtime

export WORMSWMDINSTALLDIR=${HOME}/.steamapps/steamapps/common/WormsWMD


export LD_PRELOAD="$(
        printf "%s " "$WORMSWMDINSTALLDIR"/lib/libQt5*.so* \
                ${HOME}/.steam/steam/ubuntu12_32/steam-runtime/amd64/lib/x86_64-linux-gnu/libdbus-1.so.3 \
                ${HOME}/.steam/steam/ubuntu12_32/steam-runtime/amd64/lib/x86_64-linux-gnu/libdbus-1.so.3.5.8 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/libcurl-gnutls.so.4 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/libidn.so.11 \
                "$STEAM_RUNTIME"/lib/x86_64-linux-gnu/libgcrypt.so.11 \
                "$STEAM_RUNTIME"/lib/x86_64-linux-gnu/libwrap.so.0 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/librtmp.so.0 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/libhogweed.so.4 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/libnettle.so.6 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/libsndfile.so.1 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/libFLAC.so.8 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/libpulse.so.0 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/libjson.so.0 \
                "$STEAM_RUNTIME"/usr/lib/x86_64-linux-gnu/libpulsecommon-1.1.so \
        lib/libicuuc.so.56
)"


chmod a+x ./Worms\ W.M.Dx64
./Worms\ W.M.Dx64 >> $LOGFILE

Now the game should run from Steam using the "Play Worms W.M.D (Run.sh)" option.

You may also try to run Worms W.M.Dx64 directly but this is unlikely to work because of the reasons stated above, or run the script Run.sh from a terminal to see what libraries it is missing currently if the above script is not working for you.

If the game crashes after playing the intro movies, add the Steam Runtime dbus libraries to the game's library directory (but this is already covered by the LD_PRELOAD in the example Run.sh):

$ ln -s ~/.steam/steam/ubuntu12_32/steam-runtime/amd64/lib/x86_64-linux-gnu/*dbus* ~/.steam/steam/steamapps/common/WormsWMD/lib

See also Steam community discussions [29], [30] and [31].

Steam overlay does not seem to work at the moment, possibly the game is still looking for some incompatible libraries.

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:

  1. comment the line export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:./libs
  2. change the beginning of the line starting with exec ./dosbox to exec dosbox

World of Goo

Changing resolution

To change the game resolution edit the Graphics display section in GAME/properties/config.txt. 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" />

X3: Terran Conflict

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.

X Rebirth

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:

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 sdl2_image).

ldd binaries/linux/game.x86_64 

XCOM 2

Unable to start with steam native

needs libgconf-2.so.4 which is not available in arch repositories, 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%

Unable to start needs command line launch option

If having libgconf-2.so.4 in the game folder but the game still doesn't work put the following in the launch options.

LD_LIBRARY_PATH=./lib/x86_64/:../lib/x86_64/ %command% -allowconsole

If the above command on Steam doesn't work for you then its possible that this may work as an alternative.

 LD_LIBRARY_PATH=/usr/lib:$HOME/.local/share/Steam/ubuntu12_32/steam-runtime/amd64/lib/x86_64-linux-gnu/:$HOME/.steam/steam/steamapps/common/XCOM\ 2/lib/x86_64/ %command%