mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-01-28 06:28:20 +03:00
Rename README to README.md and update it; it should be
largely complete for Linux now.
This commit is contained in:
parent
928df711ba
commit
9de9024a30
59
README
59
README
@ -1,59 +0,0 @@
|
||||
Proton is a tool for use with the Steam client which allows games which are
|
||||
exclusive to Windows to run on Linux and macOS operating systems. It uses Wine
|
||||
to facilitate this.
|
||||
|
||||
To build Proton for Linux, set up a Debian machine with the Steam chroots as
|
||||
documented in the Steam Runtime repository:
|
||||
|
||||
https://github.com/ValveSoftware/steam-runtime
|
||||
|
||||
You should then be able to build Proton using the "build_proton.sh" script.
|
||||
Some package installation will be necessary, for example the mingw-w64 cross
|
||||
compiler will be needed, as well as various runtime libraries such as Vulkan.
|
||||
Examine the output near the end of build/wine.win{64,32}/config.log to ensure
|
||||
you have all of the relevant libraries installed in each chroot.
|
||||
|
||||
TODO: Better document setting up the build machine.
|
||||
|
||||
To build Proton for macOS, install the latest Xcode command line tools, as
|
||||
well as cmake (for openal-soft) and a recent nasm (for libjpeg-turbo). You can
|
||||
use a packager like Homebrew to find these packages. Then run
|
||||
"build_proton.sh".
|
||||
|
||||
Once built, the dist/ directory will contain the files which can be distributed
|
||||
through Steam. For testing purposes, you should be able to clear out the files
|
||||
in your steamapps/common/Proton directory and replace them with the contents of
|
||||
dist/. The proton script will unpack the files on first run.
|
||||
|
||||
NOTE: For now, dxvk requires build-time components that are too new for Debian
|
||||
9. It's recommended to build the DLLs on Arch Linux, where dxvk is actively
|
||||
being developed. This may be resolved in dxvk in the future, or may be worked
|
||||
around by using a newer Debian release. See comments in build_proton.sh.
|
||||
|
||||
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.
|
||||
|
||||
|
||||
----
|
||||
RUNTIME CONFIG OPTIONS
|
||||
----
|
||||
|
||||
Proton can be tuned at runtime to help certain games run. The runtime
|
||||
configuration options are documented here. Options can either be defined in a
|
||||
comma-separated list stored in the STEAM_COMPAT_CONFIG environment variable
|
||||
when running Proton (the Steam client does this), or passed through the
|
||||
presence of individual environment variables as documented below.
|
||||
|
||||
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.
|
||||
|
||||
----
|
||||
Run game with DXVK instead of wined3d.
|
||||
Compat config string: dxvk
|
||||
Environment variable: PROTON_USE_DXVK
|
||||
|
||||
----
|
||||
Disable d3d11.dll, for games which can fall back to and run better with d3d9.
|
||||
Compat config string: nod3d11
|
||||
Environment variable: PROTON_NO_D3D11
|
145
README.md
Normal file
145
README.md
Normal file
@ -0,0 +1,145 @@
|
||||
---
|
||||
Introduction
|
||||
---
|
||||
Proton is a tool for use with the Steam client which allows games which are
|
||||
exclusive to Windows to run on Linux and macOS operating systems. It uses Wine
|
||||
to facilitate this.
|
||||
|
||||
Most users will prefer to use Proton provided by the Steam client itself. 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.
|
||||
|
||||
**NOTE:** If you are not comfortable in a command line terminal, or if you find
|
||||
any of the information presented in here strange and uncomfortable, then
|
||||
this is probably not for you. The instructions are likely to be incomplete
|
||||
and require some knowledge and skill on your part, and there is no warranty
|
||||
or guarantee that anyone will help you with this process.
|
||||
|
||||
We strongly recommend that most users use the production build of Proton.
|
||||
|
||||
---
|
||||
Obtaining Proton
|
||||
---
|
||||
The most current source for Proton is here:
|
||||
<https://TODO>
|
||||
|
||||
Which you can clone to your system with this command:
|
||||
|
||||
git clone TODO
|
||||
|
||||
If you clone the Proton git repository, the next step will be to
|
||||
obtain the various submodules that go into building Proton:
|
||||
|
||||
cd proton
|
||||
git submodule init
|
||||
git submodule update
|
||||
|
||||
If you wish to change any subcomponent, now is the time to do so.
|
||||
For example, if you wish to use an alternate version of Wine, you would
|
||||
now put that version in place in the wine/ directory in place of the
|
||||
version that Proton is currently using.
|
||||
|
||||
---
|
||||
Building for Linux
|
||||
---
|
||||
To build Proton for Linux, set up a Debian machine with the Steam chroots as
|
||||
documented in the Steam Runtime repository:
|
||||
|
||||
<https://github.com/ValveSoftware/steam-runtime>
|
||||
|
||||
In addition, you will need to install gcc-5 and a long list of dependencies
|
||||
required for Wine.
|
||||
|
||||
The following set of commands is an example session, and may not be
|
||||
complete. It is important to examine the output near the end of
|
||||
build/wine.win{64,32}/config.log to ensure that you have all of the
|
||||
relevant libraries in each chroot. Search for 'executing Makefile commands'
|
||||
in config.log. It is normal to be missing a few libraries, including
|
||||
OpenCL, OSS, and XAudio2.
|
||||
|
||||
cd
|
||||
git clone https://github.com/ValveSoftware/steam-runtime.git
|
||||
cd steam-runtime
|
||||
./setup_chroot.sh --beta --i386
|
||||
schroot --chroot steamrt_scout_beta_i386
|
||||
|
||||
This will enter the chroot environment, where you would issue the following commands:
|
||||
|
||||
sudo apt-get install gcc-5 g++-5 g++-5-multilib flex bison libosmesa6-dev libpcap-dev libhal-dev libsane-dev libv4l-dev libgphoto2-2-dev libcapi20-dev libgsm1-dev libmpg123-dev libvulkan-dev libxslt1-dev
|
||||
sudo update-alternatives --install `which gcc` gcc `which gcc-5` 50
|
||||
sudo update-alternatives --set gcc `which gcc-5`
|
||||
sudo update-alternatives --install `which g++` g++ `which g++-5` 50
|
||||
sudo update-alternatives --set g++ `which g++-5`
|
||||
sudo update-alternatives --install `which cpp` cpp-bin `which cpp-5` 50
|
||||
sudo update-alternatives --set cpp-bin `which cpp-5`
|
||||
exit
|
||||
|
||||
Next, you need to repeat the process, but for amd64:
|
||||
|
||||
./setup_chroot.sh --beta --amd64
|
||||
schroot --chroot steamrt_scout_beta_amd64
|
||||
|
||||
And then repeat all of the commands to install gcc and Wine depenedencies again.
|
||||
|
||||
Finally, change your directory back to proton, and run:
|
||||
|
||||
cd ../proton
|
||||
./build_proton.sh
|
||||
|
||||
That should configure and build a variety of sub modules, including Wine, and
|
||||
then package the result up into dist/.
|
||||
|
||||
**NOTE:** For now, dxvk requires build-time components that are too new for Debian
|
||||
9. It's recommended to build the DLLs on Arch Linux, where dxvk is actively
|
||||
being developed. This may be resolved in dxvk in the future, or may be worked
|
||||
around by using a newer Debian release. See comments in build_proton.sh.
|
||||
|
||||
---
|
||||
Building for macOS
|
||||
---
|
||||
To build Proton for macOS, install the latest Xcode command line tools, as
|
||||
well as cmake (for openal-soft) and a recent nasm (for libjpeg-turbo). You can
|
||||
use a packager like Homebrew to find these packages. Then run:
|
||||
|
||||
./build_proton.sh
|
||||
|
||||
TODO - Surely there are other dependencies we have not listed there.
|
||||
|
||||
It is important to examine the output near the end of
|
||||
build/wine.win{64,32}/config.log to ensure that you have all of the
|
||||
relevant libraries required to build Wine properly.
|
||||
|
||||
---
|
||||
Deploying
|
||||
---
|
||||
Once built, the dist/ directory will contain the files which can be distributed
|
||||
through Steam. For testing purposes, you should be able to clear out the files
|
||||
in your steamapps/common/Proton directory and replace them with the contents of
|
||||
dist/. The proton script will unpack the files on first run. Note that if you
|
||||
use the Steam client to verify local files, it will restore the production version
|
||||
of Proton.
|
||||
|
||||
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.
|
||||
|
||||
|
||||
----
|
||||
Runtime Config Options
|
||||
----
|
||||
Proton can be tuned at runtime to help certain games run. Options can either
|
||||
be defined in a comma-separated list stored in the STEAM_COMPAT_CONFIG
|
||||
environment variable when running Proton (the Steam client does this),
|
||||
or passed through the presence of individual environment variables as documented below.
|
||||
|
||||
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 |
|
||||
| :-------------------- | :-------------------- | :----------- |
|
||||
| dxvk | PROTON_USE_DXVK | Run the game with DXVK instead of wined3d. |
|
||||
| nod3d11 | PROTON_NO_D3D11 | Disable d3d11.dll, for games which can fall
|
||||
back to and run better with d3d9. |
|
||||
|
||||
<!-- Target: GitHub Flavor Markdown. To test locally: pandoc -f markdown_github -t html README.md -->
|
Loading…
x
Reference in New Issue
Block a user