2019-06-10 21:52:07 +02:00
# Building
Only Windows and Linux are officially supported for building. However, various other platforms are capable of building RPCS3.
Other instructions may be found [here ](https://wiki.rpcs3.net/index.php?title=Building ).
## Setup your environment
2024-03-27 13:55:10 +01:00
### Windows 10 or later
2019-06-10 21:52:07 +02:00
2024-02-11 07:24:23 +01:00
* [CMake 3.28.0+ ](https://www.cmake.org/download/ ) (add to PATH)
2021-04-30 01:28:51 +02:00
* [Python 3.6+ ](https://www.python.org/downloads/ ) (add to PATH)
2024-09-25 19:24:55 +02:00
* [Qt 6.7.3 ](https://www.qt.io/download-qt-installer )
2023-12-30 03:23:19 +01:00
* [Visual Studio 2022 ](https://visualstudio.microsoft.com/thank-you-downloading-visual-studio/?sku=Community ) (or at least Visual Studio 2019 16.11.xx+ as C++20 is not included in previous versions)
2023-12-04 07:46:55 +01:00
* [Vulkan SDK 1.3.268.0 ](https://vulkan.lunarg.com/sdk/home ) (See "Install the SDK" [here ](https://vulkan.lunarg.com/doc/sdk/latest/windows/getting_started.html )) for now future SDKs don't work. You need precisely 1.3.268.0.
2019-06-10 21:52:07 +02:00
2024-09-25 19:24:55 +02:00
**Either add the** `QTDIR` **environment variable, e.g.** `<QtInstallFolder>\6.7.3\msvc2019_64\` ** , or use the [Visual Studio Qt Plugin ](https://marketplace.visualstudio.com/items?itemName=TheQtCompany.QtVisualStudioTools2019 )**
2019-06-10 21:52:07 +02:00
2024-03-27 14:10:15 +01:00
**NOTE: If you have issues with the Qt plugin, you may want to uninstall the Qt Plugin and install the [Legacy Qt Plugin ](https://marketplace.visualstudio.com/items?itemName=TheQtCompany.LEGACYQtVisualStudioTools2019 ) instead.**
2019-06-10 21:52:07 +02:00
### Linux
These are the essentials tools to build RPCS3 on Linux. Some of them can be installed through your favorite package manager.
2024-08-30 19:29:42 +02:00
* Clang 17+ or GCC 13+
2024-02-11 07:24:23 +01:00
* [CMake 3.28.0+ ](https://www.cmake.org/download/ )
2024-09-25 19:24:55 +02:00
* [Qt 6.7.3 ](https://www.qt.io/download-qt-installer )
2023-12-04 07:46:55 +01:00
* [Vulkan SDK 1.3.268.0 ](https://vulkan.lunarg.com/sdk/home ) (See "Install the SDK" [here ](https://vulkan.lunarg.com/doc/sdk/latest/linux/getting_started.html )) for now future SDKs don't work. You need precisely 1.3.268.0.
2023-02-06 20:37:25 +01:00
* [SDL2 ](https://github.com/libsdl-org/SDL/releases ) (for the FAudio backend)
2019-06-10 21:52:07 +02:00
**If you have an NVIDIA GPU, you may need to install the libglvnd package.**
#### Arch Linux
2024-08-30 19:25:17 +02:00
sudo pacman -S glew openal cmake vulkan-validation-layers qt6-base qt6-declarative qt6-multimedia qt6-svg sdl2 sndio jack2 base-devel
2019-06-10 21:52:07 +02:00
#### Debian & Ubuntu
2021-11-24 19:41:05 +01:00
sudo apt-get install build-essential libasound2-dev libpulse-dev libopenal-dev libglew-dev zlib1g-dev libedit-dev libvulkan-dev libudev-dev git libevdev-dev libsdl2-2.0 libsdl2-dev libjack-dev libsndio-dev
2019-06-10 21:52:07 +02:00
2020-02-26 22:31:46 +01:00
Ubuntu is usually horrendously out of date, and some packages need to be downloaded by hand. This part is for Qt, GCC, Vulkan, and CMake
##### Qt PPA
2019-06-10 21:52:07 +02:00
2021-05-22 10:42:05 +02:00
Ubuntu usually does not have a new enough Qt package to suit rpcs3's needs. There is currently no PPA available to work around this.
2020-02-26 22:31:46 +01:00
2024-08-30 19:29:42 +02:00
##### GCC 13.x installation
2020-02-26 22:31:46 +01:00
2024-08-30 19:29:42 +02:00
If the `gcc-13` package is not available on your system, use the following commands
2019-06-10 21:52:07 +02:00
```
2020-02-26 22:31:46 +01:00
sudo add-apt-repository ppa:ubuntu-toolchain-r/test
2019-06-10 21:52:07 +02:00
sudo apt-get update
2024-08-30 19:29:42 +02:00
sudo apt-get install gcc-13 g++-13
2019-06-10 21:52:07 +02:00
```
2024-08-30 19:29:42 +02:00
You can either use `update-alternatives` to setup `gcc-13` /`g++-13` as your default compilers or prefix any `cmake` command by `CXX=g++-13 CC=gcc-13 ` to use it.
2019-06-10 21:52:07 +02:00
##### Vulkan SDK
For Ubuntu systems, it is strongly recommended to use the PPA from [LunarG ](https://packages.lunarg.com/ ) which will provide a compatible Vulkan SDK to compile RPCS3. If your Vulkan SDK is older, it can lead to compilation errors.
```
2020-08-26 07:30:03 +02:00
. /etc/os-release
wget -qO - https://packages.lunarg.com/lunarg-signing-key-pub.asc | sudo apt-key add -
2023-12-04 07:46:55 +01:00
sudo wget -qO /etc/apt/sources.list.d/lunarg-vulkan-1.3.268-$UBUNTU_CODENAME.list https://packages.lunarg.com/vulkan/1.3.268/lunarg-vulkan-1.3.268-$UBUNTU_CODENAME.list
2019-06-10 21:52:07 +02:00
sudo apt update
sudo apt install vulkan-sdk
```
2020-02-26 22:31:46 +01:00
##### CMake
2019-06-10 21:52:07 +02:00
```
2020-08-26 07:30:03 +02:00
. /etc/os-release
2020-02-26 22:31:46 +01:00
wget -O - https://apt.kitware.com/keys/kitware-archive-latest.asc 2>/dev/null | sudo apt-key add -
2020-08-26 07:30:03 +02:00
sudo apt-add-repository "deb https://apt.kitware.com/ubuntu/ $UBUNTU_CODENAME main"
2020-02-26 22:31:46 +01:00
sudo apt-get update
sudo apt-get install kitware-archive-keyring
sudo apt-key --keyring /etc/apt/trusted.gpg del C1F34CDD40CD72DA
sudo apt-get install cmake
2019-06-10 21:52:07 +02:00
```
#### Fedora
2021-05-22 10:42:05 +02:00
sudo dnf install alsa-lib-devel cmake glew glew-devel libatomic libevdev-devel libudev-devel openal-devel qt6-qtbase-devel qt6-qtbase-private-devel vulkan-devel pipewire-jack-audio-connection-kit-devel qt6-qtmultimedia-devel qt6-qtsvg-devel
2019-06-10 21:52:07 +02:00
#### OpenSUSE
2021-05-22 10:42:05 +02:00
sudo zypper install git cmake libasound2 libpulse-devel openal-soft-devel glew-devel zlib-devel libedit-devel vulkan-devel libudev-devel libqt6-qtbase-devel libqt6-qtmultimedia-devel libqt6-qtsvg-devel libQt6Gui-private-headers-devel libevdev-devel libsndio7_1 libjack-devel
2019-06-10 21:52:07 +02:00
## Setup the project
Clone and initialize the repository
```
git clone https://github.com/RPCS3/rpcs3.git
cd rpcs3
git submodule update --init
```
### Windows
#### Configuring the Qt plugin (if used)
2022-08-18 05:20:54 +02:00
1) Go to `Extensions->Qt VS Tools->Qt Versions` .
2024-09-25 19:24:55 +02:00
2) Add the path to your Qt installation with compiler e.g. `<QtInstallFolder>\6.7.3\msvc2019_64` , version will fill in automatically.
2024-03-27 14:10:15 +01:00
3) Go to `Extensions->Qt VS Tools->Options->Legacy Project Format` . (Only available in the legacy Qt plugin)
4) Set `Build: Run pre-build setup` to `true` . (Only available in the legacy Qt plugin)
2019-06-10 21:52:07 +02:00
#### Building the projects
2021-03-29 21:45:48 +02:00
Open `rpcs3.sln` . The recommended build configuration is `Release` . (On older revisions: `Release - LLVM` )
2019-06-10 21:52:07 +02:00
2023-12-16 13:28:39 +01:00
You may want to download the precompiled [LLVM libs ](https://github.com/RPCS3/llvm-mirror/releases/download/custom-build-win-16.0.1/llvmlibs_mt.7z ) and extract them to `3rdparty\llvm\` , as well as download and extract the [additional libs ](https://github.com/RPCS3/glslang/releases/latest/download/glslanglibs_mt.7z ) to `lib\%CONFIGURATION%-x64\` to speed up compilation time (unoptimised/debug libs are currently not available precompiled).
2019-06-10 21:52:07 +02:00
2021-03-29 21:45:48 +02:00
If you're not using the precompiled libs, build the following projects in *__BUILD_BEFORE* folder by right-clicking on a project > *Build* .:
2021-05-29 08:47:51 +02:00
* glslang
2021-03-29 21:45:48 +02:00
* **Either** llvm_build **or** llvm_build_clang_cl
2021-06-01 09:53:58 +02:00
* spirv
2021-03-29 21:45:48 +02:00
Afterwards:
2019-06-10 21:52:07 +02:00
`Build > Build Solution`
### Linux
While still in the project root:
2023-10-13 04:19:39 +02:00
1) `cd .. && mkdir --parents rpcs3_build && cd rpcs3_build`
2024-08-30 19:29:42 +02:00
2) `cmake ../rpcs3/ && make` or `CXX=g++-13 CC=gcc-13 cmake ../rpcs3/ && make` to force these compilers
2019-06-10 21:52:07 +02:00
3) Run RPCS3 with `./bin/rpcs3`
2024-09-30 03:21:09 +02:00
If compiling for ARM, pass the flag `-DUSE_NATIVE_INSTRUCTIONS=OFF` to the cmake command. This resolves some Neon errors when compiling our SIMD headers.
2019-06-10 21:52:07 +02:00
When using GDB, configure it to ignore SIGSEGV signal (`handle SIGSEGV nostop noprint`).
If desired, use the various build options in [CMakeLists ](https://github.com/RPCS3/rpcs3/blob/master/CMakeLists.txt ).