2024-02-23 21:32:32 +00:00
<!--
SPDX-FileCopyrightText: 2024 shadPS4 Emulator Project
SPDX-License-Identifier: GPL-2.0-or-later
-->
2024-06-11 19:14:18 +00:00
# Build shadPS4 for Windows
2023-07-21 08:05:31 +00:00
2024-08-20 16:26:35 +00:00
This tutorial reads as if you have none of the prerequisites already installed. If you do, just ignore the steps regarding installation.
2024-09-03 00:31:41 +00:00
If you are building to contribute to the project, please omit `--depth 1` from the git invocations.
2023-07-21 08:05:31 +00:00
2024-08-20 16:26:35 +00:00
Note: **ARM64 is not supported!** As of writing, it will not build nor run. The instructions with respect to ARM64 are for developers only.
2023-07-21 08:05:31 +00:00
2024-08-20 16:26:35 +00:00
## Option 1: Visual Studio 2022
2023-07-21 08:05:31 +00:00
2024-08-20 16:26:35 +00:00
### (Prerequisite) Download the Community edition from [**Visual Studio 2022**](https://visualstudio.microsoft.com/vs/)
2023-07-21 08:05:31 +00:00
2024-08-20 16:26:35 +00:00
Once you are within the installer:
2024-09-03 00:31:41 +00:00
2024-08-20 16:26:35 +00:00
1. Select `Desktop development with C++`
2. Go to "Individual Components" tab
2024-08-28 10:10:04 +00:00
3. Search and select `C++ Clang Compiler for Windows` and `MSBuild support for LLVM`
2024-08-20 16:26:35 +00:00
4. Continue the installation
2023-07-21 08:05:31 +00:00
2024-08-20 16:26:35 +00:00
### (Prerequisite) Download [**Qt**](https://doc.qt.io/qt-6/get-and-install-qt.html)
2023-07-21 08:05:31 +00:00
2024-08-20 16:26:35 +00:00
Beware, this requires you to create a Qt account. If you do not want to do this, please follow the MSYS2/MinGW compilation method instead.
2023-07-21 08:05:31 +00:00
2024-12-25 23:55:15 +00:00
1. Under the current, non beta version of Qt (at the time of writing 6.7.3), select the option `MSVC 2022 64-bit` or similar, as well as `QT Multimedia` .
2024-12-07 21:27:57 +00:00
If you are on Windows on ARM / Qualcomm Snapdragon Elite X, select `MSVC 2022 ARM64` instead.
2023-07-21 08:05:31 +00:00
2024-08-28 10:10:04 +00:00
Go through the installation normally. If you know what you are doing, you may unselect individual components that eat up too much disk space.
2024-08-20 16:26:35 +00:00
2024-08-28 10:10:04 +00:00
2. Download and install [Qt Visual Studio Tools ](https://marketplace.visualstudio.com/items?itemName=TheQtCompany.QtVisualStudioTools2022 )
2024-09-03 00:31:41 +00:00
2024-08-20 16:26:35 +00:00
Once you are finished, you will have to configure Qt within Visual Studio:
2024-09-03 00:31:41 +00:00
2024-08-20 16:26:35 +00:00
1. Tools -> Options -> Qt -> Versions
2024-12-07 21:27:57 +00:00
2. Add a new Qt version and navigate it to the correct folder. Should look like so: `C:\Qt\6.7.3\msvc2022_64`
2024-09-03 00:31:41 +00:00
3. Enable the default checkmark on the new version you just created.
2024-08-20 16:26:35 +00:00
### (Prerequisite) Download [**Git for Windows**](https://git-scm.com/download/win)
Go through the Git for Windows installation as normal
2024-08-28 10:10:04 +00:00
### Cloning the source code
2024-08-20 16:26:35 +00:00
1. Open Git for Windows, navigate to a place where you want to store the shadPS4 source code folder
2024-08-28 10:10:04 +00:00
2. Clone the repository by running
`git clone --depth 1 --recursive https://github.com/shadps4-emu/shadPS4`
### Compiling with Visual Studio GUI
1. Open up Visual Studio, select `Open a local folder` and select the folder with the shadPS4 source code. The folder should contain `CMakeLists.txt`
2. Change x64-Clang-Debug to x64-Clang-Release if you want a regular, non-debug build.
3. If you want to build shadPS4 with the Qt Gui:
1. Click x64-Clang-Release and select "Manage Configurations"
2. Look for "CMake command arguments" and add to the text field
2024-12-07 21:27:57 +00:00
`-DENABLE_QT_GUI=ON -DCMAKE_PREFIX_PATH=C:\Qt\6.7.3\msvc2022_64`
2024-08-28 10:10:04 +00:00
(Change Qt path if you've installed it to non-default path)
3. Press CTRL+S to save and wait a moment for CMake generation
4. Change the project to build to shadps4.exe
5. Build -> Build All
2024-12-07 21:27:57 +00:00
Your shadps4.exe will be in `C:\path\to\source\Build\x64-Clang-Release\`
2024-08-28 10:10:04 +00:00
To automatically populate the necessary files to run shadPS4.exe, run in a command prompt or terminal:
2024-12-27 11:53:58 +00:00
`C:\Qt\6.7.3\msvc2022_64\bin\windeployqt6.exe "C:\path\to\shadps4.exe"`
2024-08-28 10:10:04 +00:00
(Change Qt path if you've installed it to non-default path)
2024-08-20 16:26:35 +00:00
## Option 2: MSYS2/MinGW
### (Prerequisite) Download [**MSYS2**](https://www.msys2.org/)
Go through the MSYS2 installation as normal
If you are building to distribute, please omit `-DCMAKE_CXX_FLAGS="-O2 -march=native"` within the build configuration step.
Normal x86-based computers, follow:
2024-09-03 00:31:41 +00:00
2024-08-20 16:26:35 +00:00
1. Open "MSYS2 MINGW64" from your new applications
2. Run `pacman -Syu` , let it complete;
2024-12-05 21:09:43 +00:00
3. Run `pacman -S --needed git mingw-w64-x86_64-binutils mingw-w64-x86_64-clang mingw-w64-x86_64-cmake mingw-w64-x86_64-rapidjson mingw-w64-x86_64-ninja mingw-w64-x86_64-ffmpeg`
2024-09-26 06:12:41 +00:00
1. Optional (Qt only): run `pacman -S --needed mingw-w64-x86_64-qt6-base mingw-w64-x86_64-qt6-tools mingw-w64-x86_64-qt6-multimedia`
2024-08-20 16:26:35 +00:00
4. Run `git clone --depth 1 --recursive https://github.com/shadps4-emu/shadPS4`
5. Run `cd shadPS4`
2024-09-03 00:31:41 +00:00
6. Run `cmake -S . -B build -DCMAKE_C_COMPILER="clang.exe" -DCMAKE_CXX_COMPILER="clang++.exe" -DCMAKE_CXX_FLAGS="-O2 -march=native"`
1. Optional (Qt only): add `-DENABLE_QT_GUI=ON`
2024-08-20 16:26:35 +00:00
7. Run `cmake --build build`
2024-09-03 00:31:41 +00:00
1. Optional (Qt only): run `windeployqt6 build/shadps4.exe`
2024-08-20 16:26:35 +00:00
8. To run the finished product, run `./build/shadPS4.exe`
ARM64-based computers, follow:
2024-09-03 00:31:41 +00:00
2024-08-20 16:26:35 +00:00
1. Open "MSYS2 CLANGARM64" from your new applications
2. Run `pacman -Syu` , let it complete;
2024-12-05 21:09:43 +00:00
3. Run `pacman -S --needed git mingw-w64-clang-aarch64-binutils mingw-w64-clang-aarch64-clang mingw-w64-clang-aarch64-rapidjson mingw-w64-clang-aarch64-cmake mingw-w64-clang-aarch64-ninja mingw-w64-clang-aarch64-ffmpeg`
2024-09-26 06:12:41 +00:00
1. Optional (Qt only): run `pacman -S --needed mingw-w64-clang-aarch64-qt6-base mingw-w64-clang-aarch64-qt6-tools mingw-w64-clang-aarch64-qt6-multimedia`
2024-08-20 16:26:35 +00:00
4. Run `git clone --depth 1 --recursive https://github.com/shadps4-emu/shadPS4`
5. Run `cd shadPS4`
2024-09-03 00:31:41 +00:00
6. Run `cmake -S . -B build -DCMAKE_C_COMPILER="clang.exe" -DCMAKE_CXX_COMPILER="clang++.exe" -DCMAKE_CXX_FLAGS="-O2 -march=native"`
1. Optional (Qt only): add `-DENABLE_QT_GUI=ON`
2024-08-20 16:26:35 +00:00
7. Run `cmake --build build`
2024-09-03 00:31:41 +00:00
1. Optional (Qt only): run `windeployqt6 build/shadps4.exe`
2024-08-20 16:26:35 +00:00
8. To run the finished product, run `./build/shadPS4.exe`
## Note on MSYS2 builds
These builds may not be easily copyable to people who do not also have a MSYS2 installation.
If you want to distribute these builds, you need to copy over the correct DLLs into a distribution folder.
2024-09-03 00:31:41 +00:00
In order to run them, you must be within the MSYS2 shell environment.