nixpkgs/doc/packages/steam.section.md
Wolfgang Walther 1dd9c32b18
docs: remove references before 22.11
Stuff that has been in for many years doesn't need to be mentioned
explicitly anymore.
2024-11-17 12:51:09 +01:00

2.2 KiB

Steam

Steam in Nix

Steam is distributed as a .deb file, for now only as an i686 package (the amd64 package only has documentation). When unpacked, it has a script called steam that in Ubuntu (their target distro) would go to /usr/bin. When run for the first time, this script copies some files to the user's home, which include another script that is the ultimate responsible for launching the steam binary, which is also in $HOME.

Nix problems and constraints:

  • We don't have /bin/bash and many scripts point there. Same thing for /usr/bin/python.
  • We don't have the dynamic loader in /lib.
  • The steam.sh script in $HOME cannot be patched, as it is checked and rewritten by steam.
  • The steam binary cannot be patched, it's also checked.

The current approach to deploy Steam in NixOS is composing a FHS-compatible chroot environment, as documented here. This allows us to have binaries in the expected paths without disrupting the system, and to avoid patching them to work in a non FHS environment.

How to play

Use programs.steam.enable = true; if you want to add steam to systemPackages and also enable a few workarounds as well as Steam controller support or other Steam supported controllers such as the DualShock 4 or Nintendo Switch Pro Controller.

Troubleshooting

  • Steam fails to start. What do I do?

    Try to run

    strace steam
    

    to see what is causing steam to fail.

  • Using the FOSS Radeon or nouveau (nvidia) drivers

    • Steam ships statically linked with a version of libcrypto that conflicts with the one dynamically loaded by radeonsi_dri.so. If you get the error:

      steam.sh: line 713: 7842 Segmentation fault (core dumped)
      

      have a look at this pull request.

steam-run

The FHS-compatible chroot used for Steam can also be used to run other Linux games that expect a FHS environment. To use it, install the steam-run package and run the game with:

steam-run ./foo