Document Vagrant usage

This commit is contained in:
Andrew Eikum 2018-11-19 13:08:55 -06:00
parent ffaa0b5f8a
commit 4d82d9cfff
3 changed files with 109 additions and 67 deletions

155
README.md
View File

@ -34,7 +34,7 @@ The most current source for Proton is here:
Which you can clone to your system with this command: Which you can clone to your system with this command:
git clone https://github.com/ValveSoftware/Proton.git proton git clone https://github.com/ValveSoftware/Proton.git proton
After cloning the Proton git repository, the next step will be to After cloning the Proton git repository, the next step will be to
obtain the various submodules that go into building Proton: obtain the various submodules that go into building Proton:
@ -49,89 +49,114 @@ changes to the <tt>wine/</tt> directory.
--- ---
Building Building
--- ---
The following instructions describe how we create the build environment for the At a high level, the build instructions are:
production builds of Proton. For reproducibility and security reasons, we build
inside of a Debian 9 virtual machine. However, you should be able to follow
these instructions on other distributions as well.
1. Set up your build environment
1. Configure the build
1. Build Proton
1. Install Proton locally (optional)
See below for more details on all of these steps. Please read all of the
instructions before proceeding.
---
Set up the build environment
---
Proton has a lot of build-time dependencies. The following instructions
describe how we create the build environment for the production builds of
Proton. For reproducibility and security reasons, we will be setting up a
Debian 9 virtual machine. However, you should be able to follow these
instructions on other distributions as well.
Proton provides a Vagrantfile, which will automatically set up the Debian 9 VM
for you. After installing [Vagrant](https://www.vagrantup.com/), initialize the
VM by running from within the Proton directory:
vagrant up
It will take a long time to download and install the Steam runtime containers
and so on. Eventually it will complete. You can SSH into the virtual machine
with:
vagrant ssh
The Vagrantfile is set up to rsync the `proton` directory into the VM on boot,
and it will create a `build` directory in `$HOME` that is ready for you to run
`make`. On the host machine, you can use `vagrant rsync-auto` to have Vagrant
automatically sync changes on your host machine into the build machine. It is
recommended that you make changes on your host machine, and then perform the
build in the VM. Any changes you make in the `proton` directory on the VM may
be overwritten by later rsync updates from the host machine.
The Vagrantfile also creates a directory called `vagrant_share` in the `proton`
directory of your host machine, which is mounted at `/vagrant` within the VM.
You can use this shared folder to move your Proton build out of the VM, or as
one way to copy files into the VM.
If you do not wish to use Vagrant, you can reference Vagrantfile and
`vagrant-user-setup.sh` for the list of dependencies and instructions on how to
set up your own machine or another VM of your choosing.
When you are done with the VM, you can shut it down from the host machine:
vagrant halt
Please read the Vagrant documentation for more information about how to use
Vagrant VMs.
---
Alternative: Building without the Steam Runtime
---
The Steam Runtime provides a clean and consistent set of libraries. Software The Steam Runtime provides a clean and consistent set of libraries. Software
distributed through Steam should depend only on libraries available through the distributed through Steam should depend only on libraries available through the
runtime, and so we build in that environment for production Proton builds. runtime, and so we build in that environment for production Proton builds. The
However, if you are simply making a build for yourself, you can skip the Docker Vagrantfile described above will set this up for you. However, if you are
and Steam Runtime setup steps below, as they take a very long time to set up. simply making a build for yourself, you may want to skip setting up the Steam
At configure-time, pass the `--no-steam-runtime` flag instead of the Docker runtime, as it takes a very long time to set up. To do this, edit the
flags shown here. `vagrant-user-setup.sh` script appropriately before running `vagrant up`.
The build system uses Docker containers. It requires your user to be able to ---
usefully run Docker containers, which generally means [your user needs to be in Configure the build
the "docker" group](https://docs.docker.com/install/linux/linux-postinstall/), ---
which can have [security After setting up the build system, it is time to run the configure script which
implications](https://docs.docker.com/engine/security/security/). will generate the Makefile to build your project. The Vagrantfile is set up to
do this automatically for you in a directory called `$HOME/build` within the
Starting from a stock Debian 9 installation, you will need to install the VM. If you are configuring manually, run these steps:
`gpgv2`, `gnupg2`, `g++`, `g++-6-multilib`, and `mingw-w64` packages from the
Debian repos. You will also need to install `meson` version 0.43 or later,
which can be [acquired from backports](https://backports.debian.org/Instructions/). Next,
[install Docker-CE from the official Docker repositories](https://docs.docker.com/install/linux/docker-ce/debian/).
Finally, since we will need to be able to run Wine during the build process,
[install the `winehq-devel` package from the official WineHQ repositories](https://wiki.winehq.org/Debian).
This will pull in all of the dependencies required to run wine. You can then
(and we do) uninstall the `winehq-devel` package in order to ensure that a
system Wine installation does not interfere with your build process.
DXVK requires that we choose the posix alternative for the mingw-w64 compilers:
sudo update-alternatives --set x86_64-w64-mingw32-gcc `which x86_64-w64-mingw32-gcc-posix`
sudo update-alternatives --set x86_64-w64-mingw32-g++ `which x86_64-w64-mingw32-g++-posix`
sudo update-alternatives --set i686-w64-mingw32-gcc `which i686-w64-mingw32-gcc-posix`
sudo update-alternatives --set i686-w64-mingw32-g++ `which i686-w64-mingw32-g++-posix`
Next we set up the Steam runtime build environments. Here we use the
`wip-docker` branch to get access to the Docker images.
cd ~
git clone https://github.com/ValveSoftware/steam-runtime.git
cd steam-runtime
git checkout -b wip-docker origin/wip-docker
The steps below will build the Docker images. Each step will take a significant
amount of time. Note the path to a file in the `proton` directory. See the
previous section for instructions on cloning Proton.
cd ~
#set up the 64-bit Docker image for building Proton
./steam-runtime/setup_docker.sh --beta amd64 --extra-bootstrap=./proton/steamrt-bootstrap.sh steam-proton-dev
#set up the 32-bit Docker image for building Proton
./steam-runtime/setup_docker.sh --beta i386 --extra-bootstrap=./proton/steamrt-bootstrap.sh steam-proton-dev32
With the build system set up, we can configure Proton and kick off the build.
If you are not building in the runtime, pass `--no-steam-runtime` to
`configure.sh` instead.
mkdir proton/mybuild/ mkdir proton/mybuild/
cd proton/mybuild cd proton/mybuild
../configure.sh --steam-runtime64=docker:steam-proton-dev --steam-runtime32=docker:steam-proton-dev32 ../configure.sh --steam-runtime64=docker:steam-proton-dev --steam-runtime32=docker:steam-proton-dev32
make -j6 all dist
**Tip**: If you are building without the Steam runtime as shown here, you If you are building without the Steam runtime, then instead use:
should first run `make obj-wine64/Makefile obj-wine32/Makefile` and check the
files `obj-wine64/config.log` and `obj-wine32/config.log` for missing packages. ../configure.sh --no-steam-runtime
**Tip**: If you are building without the Steam runtime, you should now run
`make obj-wine64/Makefile obj-wine32/Makefile` and check the files
`obj-wine64/config.log` and `obj-wine32/config.log` for missing packages.
Search for `won't be supported`. A couple of missing packages are normal: Search for `won't be supported`. A couple of missing packages are normal:
`opencv`, `gstreamer`, `vkd3d`, `oss`, and `libavcodec`. More than that may `opencv`, `gstreamer`, `vkd3d`, `oss`. More than that may indicate a problem.
indicate a problem. One easy way to install the dependencies required to build Please see your distro's documentation to acquire the considerable build
Wine is to use `apt-get`'s `build-dep` feature. dependencies for Wine.
The `mybuild/dist` folder now contains a build of Proton which you can install ---
Build Proton
---
A couple of Makefile targets are provided. `make dist` will create a Proton
installation that you can install locally with `make install`. `make deploy`
will package Proton up for distribution via Steamworks.
The `dist/` folder now contains a build of Proton which you can install
manually or with `make install` to install into your user's Steam installation. manually or with `make install` to install into your user's Steam installation.
See the next section for more details. See the next section for more details.
--- ---
Deploying Install Proton locally
--- ---
Steam ships with several versions of Proton, which games will use by default or Steam ships with several versions of Proton, which games will use by default or
that you can select in Steam Settings's SteamPlay page. Steam also supports that you can select in Steam Settings's SteamPlay page. Steam also supports
running games with local builds of Proton, which you can install on your running games with local builds of Proton, which you can install on your
machine. machine. The `install` target will perform the below steps for you.
To install a local build of Proton into Steam, make a new directory in To install a local build of Proton into Steam, make a new directory in
`~/.steam/steam/compatibilitytools.d/` with a tool name of your choosing and `~/.steam/steam/compatibilitytools.d/` with a tool name of your choosing and

16
Vagrantfile vendored
View File

@ -12,6 +12,7 @@ Vagrant.configure(2) do |config|
v.memory = `grep 'MemTotal' /proc/meminfo | sed -e 's/MemTotal://' -e 's/ kB//'`.to_i / 1024 / 2 v.memory = `grep 'MemTotal' /proc/meminfo | sed -e 's/MemTotal://' -e 's/ kB//'`.to_i / 1024 / 2
end end
#set up shared and rsynced folders
config.vm.synced_folder "./vagrant_share/", "/vagrant/", id: "share", create: true config.vm.synced_folder "./vagrant_share/", "/vagrant/", id: "share", create: true
config.vm.synced_folder ".", "/home/vagrant/proton", id: "proton", type: "rsync", rsync__exclude: ["/output/", "vagrant_share"], rsync__args: ["--verbose", "--archive", "-z", "--links", "--update"] config.vm.synced_folder ".", "/home/vagrant/proton", id: "proton", type: "rsync", rsync__exclude: ["/output/", "vagrant_share"], rsync__args: ["--verbose", "--archive", "-z", "--links", "--update"]
@ -19,22 +20,33 @@ Vagrant.configure(2) do |config|
dpkg --add-architecture i386 dpkg --add-architecture i386
apt-get update apt-get update
apt-get install -y apt-transport-https ca-certificates curl gnupg2 software-properties-common apt-get install -y apt-transport-https ca-certificates curl gnupg2 software-properties-common
#add winehq repo #add winehq repo
curl -fsSL https://dl.winehq.org/wine-builds/Release.key | apt-key add - curl -fsSL https://dl.winehq.org/wine-builds/Release.key | apt-key add -
echo 'deb http://dl.winehq.org/wine-builds/debian stretch main' > /etc/apt/sources.list.d/winehq.list echo 'deb http://dl.winehq.org/wine-builds/debian stretch main' > /etc/apt/sources.list.d/winehq.list
#add backports #add backports
echo 'deb http://ftp.debian.org/debian stretch-backports main' > /etc/apt/sources.list.d/backports.list echo 'deb http://ftp.debian.org/debian stretch-backports main' > /etc/apt/sources.list.d/backports.list
#add docker repo #add docker repo
curl -fsSL https://download.docker.com/linux/debian/gpg | apt-key add - curl -fsSL https://download.docker.com/linux/debian/gpg | apt-key add -
add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/debian stretch stable" add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/debian stretch stable"
#install host build-time dependencies
apt-get update apt-get update
apt-get install -y gpgv2 gnupg2 g++ g++-6-multilib mingw-w64 git docker-ce winehq-devel fontforge-nox apt-get install -y gpgv2 gnupg2 g++ g++-6-multilib mingw-w64 git docker-ce winehq-devel fontforge-nox
apt-get remove -y winehq-devel
apt-get -y -t stretch-backports install meson apt-get -y -t stretch-backports install meson
#remove system Wine installation to ensure no accidental leakage
apt-get remove -y winehq-devel
#configure posix mingw-w64 alternative for DXVK
update-alternatives --set x86_64-w64-mingw32-gcc `which x86_64-w64-mingw32-gcc-posix` update-alternatives --set x86_64-w64-mingw32-gcc `which x86_64-w64-mingw32-gcc-posix`
update-alternatives --set x86_64-w64-mingw32-g++ `which x86_64-w64-mingw32-g++-posix` update-alternatives --set x86_64-w64-mingw32-g++ `which x86_64-w64-mingw32-g++-posix`
update-alternatives --set i686-w64-mingw32-gcc `which i686-w64-mingw32-gcc-posix` update-alternatives --set i686-w64-mingw32-gcc `which i686-w64-mingw32-gcc-posix`
update-alternatives --set i686-w64-mingw32-g++ `which i686-w64-mingw32-g++-posix` update-alternatives --set i686-w64-mingw32-g++ `which i686-w64-mingw32-g++-posix`
#allow vagrant user to run docker
adduser vagrant docker adduser vagrant docker
SHELL SHELL

View File

@ -1,7 +1,12 @@
#!/bin/sh #!/bin/sh
#set up steam runtimes. remove these lines if building without the runtime
git clone https://github.com/ValveSoftware/steam-runtime.git -b wip-docker git clone https://github.com/ValveSoftware/steam-runtime.git -b wip-docker
./steam-runtime/setup_docker.sh --beta amd64 --extra-bootstrap=/home/vagrant/proton/steamrt-bootstrap.sh steam-proton-dev ./steam-runtime/setup_docker.sh --beta amd64 --extra-bootstrap=/home/vagrant/proton/steamrt-bootstrap.sh steam-proton-dev
./steam-runtime/setup_docker.sh --beta i386 --extra-bootstrap=/home/vagrant/proton/steamrt-bootstrap.sh steam-proton-dev32 ./steam-runtime/setup_docker.sh --beta i386 --extra-bootstrap=/home/vagrant/proton/steamrt-bootstrap.sh steam-proton-dev32
#configure proton build
mkdir build mkdir build
cd build cd build
../proton/configure.sh --steam-runtime64=docker:steam-proton-dev --steam-runtime32=docker:steam-proton-dev32 ../proton/configure.sh --steam-runtime64=docker:steam-proton-dev --steam-runtime32=docker:steam-proton-dev32
#if building without the runtime:
#../proton/configure.sh --no-steam-runtime