Only Windows and Linux are officially supported for building. However, various other platforms are capable of building RPCS3. Other instructions may be found here.
The following tools are required to build RPCS3 on Windows 10 or later:
-
Visual Studio 2022 (or at least Visual Studio 2019 16.11.xx+ as C++20 is not included in previous versions)
-
Optional - CMake 3.28.0+ (add to PATH)
NOTES:
- Visual Studio 2022 integrates CMake 3.29+ and it also supports both the
sln
solution (.sln
,.vcxproj
) andCMake
solution (CMakeLists.txt
,CMakePresets.json
). See sections Building with Visual Studio sln solution and Building with Visual Studio CMake solution on how to build the project with Visual Studio. - Install and use this standalone CMake tool just in case of your preference. See section Building with standalone CMake tool on how to build the project with standalone CMake tool.
- Visual Studio 2022 integrates CMake 3.29+ and it also supports both the
-
Python 3.6+ (add to PATH)
-
Qt 6.7.3 In case you can't download from the official installer, you can use Another Qt installer (In that case you will need to manually add the "qtmultimedia" module when installing Qt)
-
Vulkan SDK 1.3.268.0 (see "Install the SDK" here) for now future SDKs don't work. You need precisely 1.3.268.0.
The sln
solution available only on Visual Studio is the preferred building solution. It easily allows to build the RPCS3 application in Release
and Debug
mode.
In order to build RPCS3 with the sln
solution (with Visual Studio), Qt libs need to be detected. To detect the libs:
-
add and set the
QTDIR
environment variable, e.g.<QtInstallFolder>\6.7.3\msvc2019_64\
-
or use the Visual Studio Qt Plugin
NOTE: If you have issues with the Visual Studio Qt Plugin, you may want to uninstall it and install the Legacy Qt Plugin instead.
In order to build RPCS3 with the CMake
solution (with both Visual Studio and standalone CMake tool):
- add and set the
CMAKE_PREFIX_PATH
environment variable to the Qt libs path, e.g.<QtInstallFolder>\6.7.3\msvc2019_64\
These are the essentials tools to build RPCS3 on Linux. Some of them can be installed through your favorite package manager:
- Clang 17+ or GCC 13+
- CMake 3.28.0+
- Qt 6.7.3
- Vulkan SDK 1.3.268.0 (See "Install the SDK" here) for now future SDKs don't work. You need precisely 1.3.268.0.
- SDL2 (for the FAudio backend)
If you have an NVIDIA GPU, you may need to install the libglvnd package.
sudo pacman -S glew openal cmake vulkan-validation-layers qt6-base qt6-declarative qt6-multimedia qt6-svg sdl2 sndio jack2 base-devel
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
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
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.
If the gcc-13
package is not available on your system, use the following commands
sudo add-apt-repository ppa:ubuntu-toolchain-r/test
sudo apt-get update
sudo apt-get install gcc-13 g++-13
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.
For Ubuntu systems, it is strongly recommended to use the PPA from LunarG which will provide a compatible Vulkan SDK to compile RPCS3. If your Vulkan SDK is older, it can lead to compilation errors.
. /etc/os-release
wget -qO - https://packages.lunarg.com/lunarg-signing-key-pub.asc | sudo apt-key add -
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
sudo apt update
sudo apt install vulkan-sdk
. /etc/os-release
wget -O - https://apt.kitware.com/keys/kitware-archive-latest.asc 2>/dev/null | sudo apt-key add -
sudo apt-add-repository "deb https://apt.kitware.com/ubuntu/ $UBUNTU_CODENAME main"
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
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
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
Clone and initialize the repository
git clone https://github.com/RPCS3/rpcs3.git
cd rpcs3
git submodule update --init
Start Visual Studio, click on Open a project or solution
and select the rpcs3.sln
file inside the RPCS3's root folder
- go to
Extensions->Qt VS Tools->Qt Versions
- add the path to your Qt installation with compiler e.g.
<QtInstallFolder>\6.7.3\msvc2019_64
, version will fill in automatically - go to
Extensions->Qt VS Tools->Options->Legacy Project Format
. (Only available in the Legacy Qt Plugin) - set
Build: Run pre-build setup
totrue
. (Only available in the Legacy Qt Plugin)
NOTE: The recommended build configuration is Release
. (On older revisions: Release - LLVM
)
You may want to download the precompiled LLVM libs and extract them to 3rdparty\llvm\
,
as well as download and extract the additional libs to lib\%CONFIGURATION%-x64\
to speed up compilation
time (unoptimised/debug libs are currently not available precompiled).
If you're not using the precompiled libs, those dependency libs need to be compiled first. From the Solution Explorer
panel:
- expand
__BUILD_BEFORE
- from the
Solution Configurations
drop-down menu, selectRelease
(selectDebug
if you want to build inDebug
mode) - one after another, right-click on the following projects and then click on
Build
to build the selected lib:glslang
- either
llvm_build
- or
llvm_build_clang_cl
(if you installed clang on VS)
In order to build the RPCS3 application:
-
from the
Solution Configurations
drop-down menu, selectRelease
(selectDebug
if you want to build inDebug
mode)NOTE: In case you previously compiled the dependency libs under
__BUILD_BEFORE
, you have also to select the same build configuration (e.g.Release
, if you compiled the dependency libs inRelease
mode) -
click on
Build
menu and then onBuild Solution
-
once the build is completed, the RPCS3 application will be available under the
<rpcs3_root>\bin
folder
Start Visual Studio, click on Open a local folder
and select the RPCS3's root folder
Once the project is open on VS, from the Solution Explorer
panel:
- right-click on
rpcs3
and then click onSwitch to CMake Targets View
- from the
Configuration
drop-down menu, selectmsvc-release
(selectmsvc-debug
if you want to build inDebug
mode) - right-click on
CMakeLists.txt Project
and then click onConfigure Cache
- once the cache is created, the
rpcs3 project
will be available - right-click on
rpcs3 Project
and then click onBuild All
, or click onBuild
menu and then onBuild All
- once the build is completed, the RPCS3 application will be available under the
<rpcs3_root>\build-msvc\bin
folder
In case you preferred to install and use the standalone CMake tool:
-
move on the RPCS3's root folder
-
execute the following commands to create the cache and to build the application (for the build, use
--preset msvc-debug
if you want to build inDebug
mode), respectively:cmake --preset msvc cmake --build --preset msvc-release
-
once the build is completed, the RPCS3 application will be available under the
<rpcs3_root>\build-msvc\bin
folder
While still in the project root:
cd .. && mkdir --parents rpcs3_build && cd rpcs3_build
cmake ../rpcs3/ && make
orCXX=g++-13 CC=gcc-13 cmake ../rpcs3/ && make
to force these compilers- run RPCS3 with
./bin/rpcs3
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.
When using GDB, configure it to ignore SIGSEGV signal (handle SIGSEGV nostop noprint
).
If desired, use the various build options in CMakeLists.