/steam

steam - nonfree

Primary LanguageShell

Moving the Steam client installation
====================================

I often poke around with the client, check folder sizes in my home folder, etc.
Running a du -hs * in my home folder to check how much space my Pictures or
Music folder take it’s very fast. But since the Steam client is installed in a
hidden subdirectory it’s not really clear how much space it does take,
especially when it reached nearly 70% of my whole drive.

To move the Steam installation (for example in your home folder), simply issue
the following command:

 $ mv ~/.local/share/Steam ~/Steam

And launch the client again, it will adjust all the symlinks for folders, saves,
etc. by itself. Even the desktop / system shortcuts for the games work because
they launch Steam (which is in the path) with the appropriate Steam game ID.

Steam Remote Play (hardware decoding/encoding)
==============================================

Steam Remote Play hardware decoding and encoding are exposed through different
backends, depending on the hardware you are running. These are detected at
runtime, and are all 32 bit libraries also on 64 bit systems, as the client is
32 bit only.

+--------+---------+-------------+--------------+
| Vendor | Driver  | Encoding    | Decoding     |
+--------+---------+-------------+--------------+
| Intel  | intel   | VA-API      | VA-API       |
+--------+---------+-------------+--------------+
| Nvidia | nvidia  | NVENC/NVFBC | NVDEC/VDPAU  |
+--------+---------+-------------+--------------+
| AMD    | radeon  | VA-API      | VA-API/VDPAU |
+--------+---------+-------------+--------------+
| Nvidia | nouveau | -           | VA-API/VDPAU |
+--------+---------+-------------+--------------+
| AMD    | amdgpu  | VA-API      | VA-API/VDPAU |
+--------+---------+-------------+--------------+

Steam Remote Play configuration
===============================

Valve has supported Steam Remote Play (both as a server and as a client) in
Linux for quite some time. According to the documentation, streaming in the same
network segment uses UDP ports 27031 to 27036 and TCP ports 27036 and 27037.

If you have installed a default desktop, FirewallD should be your firewall
solution. To make sure that Steam can listen on the required ports through your
firewall software, execute the following commands as root.

You should be able to see the word “steam” by running:

 # firewall-cmd --get-services | grep steam

Then get the firewall zone you are in, and enable the service for it. For
example, on my system, to get the firewall zone I’m using:

 # firewall-cmd --get-active-zones 
 public
   interfaces: em1

You may want to set up a home or other trusted zone in your firewall. This will
help protect your system from unauthorized remote access over the internet.
This is out of scope for this help text, but this tutorial will guide
you through the process:

  https://ctrl.blog/entry/how-to-firewalld-zone-by-ip

Then enable the Steam service permanently (i.e. at reboot) on the public or
your preferred zone immediately with these commands:

 # firewall-cmd --zone=public --add-service=steam-streaming --permanent
 # firewall-cmd --zone=public --add-service=steam-streaming

Now start up two Steam clients with your user on the same network, and you
should see games installed on both systems as available for playing in both
Steam clients.

For Steam Remote Play outside of your network, there is no need to open any
additional inbound ports.

Joysticks, keyboards and game pads
==================================

The package contains the UDEV rules for lots of gamepads as presented in the
Steam devices repository (https://github.com/ValveSoftware/steam-devices).
Also it contains additional UDEV rules to make sure some multimedia keyboards
and tablet devices are properly detected as game pads and not mouses.

Steam Controller
================

To use the Steam Controller as a normal gamepad you require the Steam client to
be running and the user requiring Gamepad emulation needs to be in the 'input'
group.

Regular firmware updates will go through regular USB hid reports and can be
performed wired or wirelessly. Valve will also sometimes be releasing infrequent
bootloader firmware updates; these updates are different and can only work when
wired.

When Steam asks you to plug in the controller to start the update, the
controller will change from a HID device to a mass storage device with an
identifier of 'CRP DISABLED'. Steam will then wait for that device to become
mounted somewhere so that it can copy the firmware file into the controller.
If you don't auto-mount mass storage devices by default, you need to mount it
manually when the Steam client is waiting for the volume to get mounted.