Proton
Compatibility tool for Steam Play based on Wine and additional components
Top Related Projects
Compatibility tool for Steam Play based on Wine and additional components
A games launcher for GOG, Amazon and Epic Games for Linux, Windows and macOS.
Lutris desktop client
Vulkan-based implementation of D3D8, 9, 10 and 11 for Linux / Wine
Fork of VKD3D. Development branches for Proton's Direct3D 12 implementation.
Quick Overview
Proton is a compatibility layer developed by Valve Software that allows Windows games to run on Linux operating systems. It integrates Steam Play, Wine, and additional components to provide a seamless gaming experience for Linux users, enabling them to play many Windows-exclusive titles without the need for a Windows installation.
Pros
- Greatly expands the library of games available to Linux users
- Regularly updated and maintained by Valve, ensuring compatibility with new game releases
- Integrates seamlessly with Steam, providing a user-friendly experience
- Open-source, allowing community contributions and improvements
Cons
- Not all Windows games are compatible or perform optimally
- May introduce performance overhead compared to native Linux games
- Some anti-cheat systems and DRM technologies can cause issues
- Requires some technical knowledge for troubleshooting and optimizing game performance
Getting Started
To use Proton with Steam on Linux:
- Open Steam and go to Steam > Settings > Steam Play
- Check "Enable Steam Play for all other titles"
- Select the desired Proton version from the dropdown menu
- Click "OK" to save changes
- Install and play Windows games from your Steam library
For manual installation outside of Steam:
# Clone the Proton repository
git clone https://github.com/ValveSoftware/Proton.git
# Change to the Proton directory
cd Proton
# Build Proton (requires necessary dependencies)
./configure.sh
make
# Run a Windows executable using Proton
./proton run /path/to/windows/executable.exe
Note: Using Proton outside of Steam may require additional configuration and troubleshooting.
Competitor Comparisons
Compatibility tool for Steam Play based on Wine and additional components
Pros of proton-ge-custom
- More frequent updates and patches for specific games
- Includes additional features and tweaks not found in the official Proton
- Often provides better compatibility for certain games
Cons of proton-ge-custom
- May introduce instability or unexpected behavior in some cases
- Not officially supported by Valve, which could lead to compatibility issues
- Requires manual installation and updates
Code Comparison
While both projects are based on the same core, proton-ge-custom often includes additional patches and tweaks. Here's a simplified example of how they might differ in handling a specific game:
Proton:
def handle_game_x():
# Standard implementation
pass
proton-ge-custom:
def handle_game_x():
# Standard implementation
# Additional tweaks for better performance
apply_custom_patch()
Both projects aim to improve Windows game compatibility on Linux, but proton-ge-custom takes a more aggressive approach with frequent updates and game-specific optimizations. While this can lead to better performance and compatibility for some games, it may also introduce instability. Users should choose based on their specific needs and tolerance for potential issues.
A games launcher for GOG, Amazon and Epic Games for Linux, Windows and macOS.
Pros of HeroicGamesLauncher
- Cross-platform support for Linux, macOS, and Windows
- User-friendly interface for managing Epic Games and GOG libraries
- Built-in Wine and Proton management for running Windows games on Linux
Cons of HeroicGamesLauncher
- Limited to Epic Games and GOG platforms, while Proton supports a wider range of Steam games
- May require additional configuration for optimal performance compared to Proton's seamless integration with Steam
Code Comparison
HeroicGamesLauncher (TypeScript):
export const runGame = async (appName: string, args: string[] = []) => {
const game = await getGameInfo(appName);
const wineVersion = await getWineVersion(game.wineVersion);
return launchGame(game, wineVersion, args);
};
Proton (C++):
BOOL WINAPI wine_get_unix_file_name( LPCWSTR dosW, LPSTR unix, DWORD size )
{
UNICODE_STRING nt_name;
ANSI_STRING unix_name;
NTSTATUS status;
if (!RtlDosPathNameToNtPathName_U( dosW, &nt_name, NULL, NULL ))
return FALSE;
status = wine_nt_to_unix_file_name( &nt_name, &unix_name, FILE_OPEN, FALSE );
RtlFreeUnicodeString( &nt_name );
if (status != STATUS_SUCCESS) return FALSE;
lstrcpynA( unix, unix_name.Buffer, size );
RtlFreeAnsiString( &unix_name );
return TRUE;
}
The code snippets showcase different approaches: HeroicGamesLauncher uses TypeScript for game launching logic, while Proton employs C++ for low-level file system operations, reflecting their distinct focuses and implementation strategies.
Lutris desktop client
Pros of Lutris
- Supports a wider range of games and platforms beyond Steam
- Offers a user-friendly GUI for managing and launching games
- Provides community-maintained installation scripts for many games
Cons of Lutris
- Less integrated with Steam and may require more manual configuration
- Performance may vary compared to Proton for Steam games
- Relies on community support for game compatibility and troubleshooting
Code Comparison
Lutris (Python):
def is_game_installed(game):
return game.install_path and os.path.exists(game.install_path)
def launch_game(game):
command = game.get_launch_command()
subprocess.Popen(command, cwd=game.directory)
Proton (C++):
bool IsGameInstalled(const CGameID &gameID) {
return SteamApps()->BIsAppInstalled(gameID.AppID());
}
void LaunchGame(const CGameID &gameID) {
SteamApps()->LaunchApp(gameID.AppID(), 0, nullptr);
}
Both projects aim to improve gaming on Linux, but they take different approaches. Lutris offers a more versatile solution for various gaming platforms, while Proton focuses on seamless integration with Steam and potentially better performance for Steam games.
Vulkan-based implementation of D3D8, 9, 10 and 11 for Linux / Wine
Pros of DXVK
- Focused specifically on DirectX to Vulkan translation, potentially offering better performance for DirectX games
- Lighter weight and more modular, can be used independently of Proton
- More frequent updates and contributions from the community
Cons of DXVK
- Limited to DirectX 9, 10, and 11 translation, while Proton covers a broader range of Windows APIs
- Lacks the integrated runtime environment that Proton provides
- May require more manual configuration for optimal performance in some games
Code Comparison
DXVK (DirectX API translation):
VkResult DXVK_CALL dxvk_instance_create(
const DxvkInstanceCreateInfo* pCreateInfo,
DxvkInstance** ppInstance) {
try {
*ppInstance = new DxvkInstance(pCreateInfo);
return VK_SUCCESS;
} catch (const DxvkError& e) {
Logger::err(e.message());
return e.code();
}
}
Proton (Wine integration):
NTSTATUS WINAPI wine_ntoskrnl_main_loop( HANDLE stop_event )
{
LARGE_INTEGER timeout;
NTSTATUS status;
timeout.QuadPart = -10000;
for (;;)
{
status = NtWaitForSingleObject( stop_event, FALSE, &timeout );
if (status != STATUS_TIMEOUT) break;
KiDispatchInterrupt();
}
return status;
}
Fork of VKD3D. Development branches for Proton's Direct3D 12 implementation.
Pros of vkd3d-proton
- Focused specifically on DirectX 12 to Vulkan translation
- Potentially faster performance for D3D12 games
- More frequent updates and contributions from the community
Cons of vkd3d-proton
- Limited scope compared to Proton's broader compatibility
- May require additional configuration for optimal performance
- Less integrated with Steam and other Valve tools
Code Comparison
vkd3d-proton:
VkResult vkd3d_create_instance(const struct vkd3d_instance_create_info *create_info,
struct vkd3d_instance **instance)
{
struct vkd3d_instance *object;
VkResult vr;
Proton:
NTSTATUS WINAPI wine_vkd3d_create_device(const struct vkd3d_device_create_info *create_info,
REFIID iid, void **device)
{
struct vkd3d_device *object;
HRESULT hr;
While both projects deal with DirectX to Vulkan translation, vkd3d-proton focuses on D3D12 specifically, whereas Proton encompasses a broader range of Windows APIs and technologies. vkd3d-proton may offer better performance for D3D12 games but lacks the extensive compatibility and integration that Proton provides. The code snippets show similar function structures, but vkd3d-proton uses Vulkan-specific types, while Proton uses Windows-style types, reflecting their different scopes and approaches.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
Introduction
Proton is a tool for use with the Steam client which allows games which are exclusive to Windows to run on the Linux operating system. It uses Wine to facilitate this.
Most users should use Proton provided by the Steam Client itself. See this Steam Community post for more details.
The source code is provided to enable advanced users the ability to alter Proton. For example, some users may wish to use a different version of Wine with a particular title.
The changelog is available on our wiki.
Obtaining Proton sources
Acquire Proton's source by cloning https://github.com/ValveSoftware/Proton and checking out the branch you desire.
You can clone the latest Proton to your system with this command:
git clone --recurse-submodules https://github.com/ValveSoftware/Proton.git proton
Be sure to update submodules when switching between branches:
git checkout experimental_6.3
git submodule update --init --recursive
If you want to change any subcomponent, now is the time to do so. For
example, if you wish to make changes to Wine, you would apply them to the
wine/
directory.
Building Proton
Most of Proton builds inside the Proton SDK container with very few dependencies on the host side.
Preparing the build environment
You need either a Docker or a Podman setup. We highly recommend the rootless Podman setup. Please refer to your distribution's documentation for setup instructions (e.g. Arch Podman / Docker, Debian Podman / Docker).
The Easy Way
We provide a top-level Makefile which will execute most of the build commands for you.
After checking out the repository and updating its submodules, assuming that you have a working Docker or Podman setup, you can build and install Proton with a simple:
make install
If your build system is missing dependencies, it will fail quickly with a clear error message.
After the build finishes, you may need to restart the Steam client to see the
new Proton tool. The tool's name in the Steam client will be based on the
currently checked out branch of Proton. You can override this name using the
build_name
variable.
See make help
for other build targets and options.
Manual building
Configuring the build
mkdir ../build && cd ../build
../proton/configure.sh --enable-ccache --build-name=my_build
Running configure.sh
will create a Makefile
allowing you to build Proton.
The scripts checks if containers are functional and prompt you if any
host-side dependencies are missing. You should run the command from a
directory created specifically for your build.
The configuration script tries to discover a working Docker or Podman setup
to use, but you can force a compatible engine with
--container-engine=<executable_name>
.
You can enable ccache with --enable-cache
flag. This will mount your
$CCACHE_DIR
or $HOME/.ccache
inside the container.
--proton-sdk-image=registry.gitlab.steamos.cloud/proton/soldier/sdk:<version>
can be used to build with a custom version of the Proton SDK images.
Check --help
for other configuration options.
NOTE: If SELinux is in use, the Proton build container may fail to access
your user's files. This is caused by SELinux's filesystem
labels. You may pass the --relabel-volumes
switch to
configure to cause the container engine to relabel its
bind-mounts and allow access to those files from within the
container. This can be dangerous when used with system directories. Proceed
with caution and refer your container engine's manual.
Building
make
Important make targets:
make install
- install Proton into your user's Steam directory, see the install Proton
locally section for details.
make redist
- create a redistribute build (redist/
) that can be copied to
~/.steam/root/compatibilitytools.d/
.
make deploy
- create a deployment build (deploy/
). This is what we use to
deploy Proton to Steam users via Steamworks.
make module=<module> module
- build both 32- and 64-bit versions of the
specified wine module. This allows rapid iteration on one module. This target
is only useful after building Proton.
make dxvk
/ make vkd3d-proton
- rebuild DXVK / vkd3d-proton.
Debug Builds
To prevent symbol stripping add UNSTRIPPED_BUILD=1
to the make
invocation. This should be used only with a clean build directory.
E.g.:
mkdir ../debug-proton-build && cd ../debug-proton-build
../proton/configure.sh --enable-ccache --build-name=debug_build
make UNSTRIPPED_BUILD=1 install
Install Proton locally
Steam ships with several versions of Proton, which games will use by default or that you can select in Steam Settings' Steam Play page. Steam also supports running games with local builds of Proton, which you can install on your machine.
To install a local build of Proton into Steam, make a new directory in
~/.steam/root/compatibilitytools.d/
with a tool name of your choosing and
place the directory containing your redistributable build under that path.
The make install
target will perform this task for you, installing the
Proton build into the Steam folder for the current user. You will have to
restart the Steam client for it to pick up on a new tool.
A correct local tool installation should look similar to this:
compatibilitytools.d/my_proton/
âââ compatibilitytool.vdf
âââ filelock.py
âââ LICENSE
âââ proton
âââ proton_dist.tar
âââ toolmanifest.vdf
âââ user_settings.sample.py
âââ version
To enable your local build in Steam, go to the Steam Play section of the Settings window. If the build was correctly installed, you should see "proton-localbuild" in the drop-down list of compatibility tools.
Each component of this software is used under the terms of their licenses.
See the LICENSE
files here, as well as the LICENSE
, COPYING
, etc files
in each submodule and directory for details. If you distribute a built
version of Proton to other users, you must adhere to the terms of these
licenses.
Debugging
Proton builds have their symbols stripped by default. You can switch to "debug" beta branch in Steam (search for Proton in your library, Properties... -> BETAS -> select "debug") or build without stripping (see Debug Builds section).
The symbols are provided through the accompanying .debug
files which may
need to be explicitly loaded by the debugging tools. For GDB there's a helper
script wine/tools/gdbinit.py
(source it) that provides load-symbol-files
(or lsf
for short) command which loads the symbols for all the mapped files.
For tips on debugging see docs/DEBUGGING.md.
compile_commands.json
For use with clangd LSP server and similar tooling.
Projects built using cmake or meson (e.g. vkd3d-proton) automatically come with
compile_commands.json
. For autotools (e.g. wine) you have to configure the
build with --enable-bear
that uses
bear to create the compilation database.
It's not on by default as it make the build slightly slower.
The build system collects all the created compile_commands.json files in a
build subdirectory named compile_commands/
.
The paths are translated to point to the real source (i.e. not the rsynced
copy). It still may depend on build directory for things like auto-generated
config.h
though and for wine it may be beneficial to run tools/make_requests
in you source directories as those changes are not committed.
You can then configure your editor to use that file for clangd in a few ways:
- directly - some editors/plugins allow you to specify the path to
compile_commands.json
- via
.clangd
file, e.g.
cd src/proton/wine/
cat > .clangd <<EOF
CompileFlags:
CompilationDatabase: ../build/current-dev/compile_commands/wine64/
EOF
- by symlinking:
ln -s ../build/current-dev/compile_commands/wine64/compile_commands.json .
Runtime Config Options
Proton can be tuned at runtime to help certain games run. The Steam client sets
some options for known games using the STEAM_COMPAT_CONFIG
variable.
You can override these options using the environment variables described below.
The best way to set these environment overrides for all games is by renaming
user_settings.sample.py
to user_settings.py
and modifying it appropriately.
This file is located in the Proton installation directory in your Steam library
(often ~/.steam/steam/steamapps/common/Proton #.#
).
If you want to change the runtime configuration for a specific game, you can
use the Set Launch Options
setting in the game's Properties
dialog in the
Steam client. Set the variable, followed by %command%
. For example, input
"PROTON_USE_WINED3D=1 %command%
" to use the OpenGL-based wined3d renderer
instead of the Vulkan-based DXVK renderer.
To enable an option, set the variable to a non-0
value. To disable an
option, set the variable to 0
. To use Steam's default configuration, do
not specify the variable at all.
All of the below are runtime options. They do not effect permanent changes to the Wine prefix. Removing the option will revert to the previous behavior.
Compat config string | Environment Variable | Description |
---|---|---|
PROTON_LOG | Convenience method for dumping a useful debug log to $PROTON_LOG_DIR/steam-$APPID.log . Set to 1 to enable default logging, or set to a string to be appended to the default WINEDEBUG channels. | |
PROTON_LOG_DIR | Output log files into the directory specified. Defaults to your home directory. | |
PROTON_WAIT_ATTACH | Wait for a debugger to attach to steam.exe before launching the game process. To attach to the game process at startup, debuggers should be set to follow child processes. | |
PROTON_CRASH_REPORT_DIR | Write crash logs into this directory. Does not clean up old logs, so may eat all your disk space eventually. | |
wined3d | PROTON_USE_WINED3D | Use OpenGL-based wined3d instead of Vulkan-based DXVK for d3d11, d3d10, and d3d9. |
nod3d11 | PROTON_NO_D3D11 | Disable d3d11.dll , for d3d11 games which can fall back to and run better with d3d9. |
nod3d10 | PROTON_NO_D3D10 | Disable d3d10.dll and dxgi.dll , for d3d10 games which can fall back to and run better with d3d9. |
dxvkd3d8 | PROTON_DXVK_D3D8 | Use DXVK's d3d8.dll . |
noesync | PROTON_NO_ESYNC | Do not use eventfd-based in-process synchronization primitives. |
nofsync | PROTON_NO_FSYNC | Do not use futex-based in-process synchronization primitives. (Automatically disabled on systems with no FUTEX_WAIT_MULTIPLE support.) |
noxim | PROTON_NO_XIM | Enabled by default. Do not attempt to use XIM (X Input Methods) support. XIM support is known to cause crashes with libx11 older than version 1.7. |
disablenvapi | PROTON_DISABLE_NVAPI | Disable NVIDIA's NVAPI GPU support library. |
nativevulkanloader | Use the Vulkan loader shipped with the game instead of Proton's built-in Vulkan loader. This breaks VR support, but is required by a few games. | |
forcelgadd | PROTON_FORCE_LARGE_ADDRESS_AWARE | Force Wine to enable the LARGE_ADDRESS_AWARE flag for all executables. Enabled by default. |
heapdelayfree | PROTON_HEAP_DELAY_FREE | Delay freeing some memory, to work around application use-after-free bugs. |
gamedrive | PROTON_SET_GAME_DRIVE | Create an S: drive which points to the Steam Library which contains the game. |
noforcelgadd | Disable forcelgadd. If both this and forcelgadd are set, enabled wins. | |
oldglstr | PROTON_OLD_GL_STRING | Set some driver overrides to limit the length of the GL extension string, for old games that crash on very long extension strings. |
vkd3dfl12 | Force the Direct3D 12 feature level to 12, regardless of driver support. | |
vkd3dbindlesstb | Put force_bindless_texel_buffer into VKD3D_CONFIG . | |
nomfdxgiman | WINE_DO_NOT_CREATE_DXGI_DEVICE_MANAGER | Enable hack to work around video issues in some games due to incomplete IMFDXGIDeviceManager support. |
noopwr | WINE_DISABLE_VULKAN_OPWR | Enable hack to disable Vulkan other process window rendering which sometimes causes issues on Wayland due to blit being one frame behind. |
hidenvgpu | PROTON_HIDE_NVIDIA_GPU | Force Nvidia GPUs to always be reported as AMD GPUs. Some games require this if they depend on Windows-only Nvidia driver functionality. See also DXVK's nvapiHack config, which only affects reporting from Direct3D. |
WINE_FULLSCREEN_INTEGER_SCALING | Enable integer scaling mode, to give sharp pixels when upscaling. | |
cmdlineappend: | Append the string after the colon as an argument to the game command. May be specified more than once. Escape commas and backslashes with a backslash. | |
xalia | PROTON_USE_XALIA | Enable Xalia, a program that can add a gamepad UI for some keyboard/mouse interfaces. |
seccomp | PROTON_USE_SECCOMP | Note: Obsoleted in Proton 5.13. In older versions, enable seccomp-bpf filter to emulate native syscalls, required for some DRM protections to work. |
d9vk | PROTON_USE_D9VK | Note: Obsoleted in Proton 5.0. In older versions, use Vulkan-based DXVK instead of OpenGL-based wined3d for d3d9. |
Top Related Projects
Compatibility tool for Steam Play based on Wine and additional components
A games launcher for GOG, Amazon and Epic Games for Linux, Windows and macOS.
Lutris desktop client
Vulkan-based implementation of D3D8, 9, 10 and 11 for Linux / Wine
Fork of VKD3D. Development branches for Proton's Direct3D 12 implementation.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot