PS3 emulator/debugger
Go to file
Lassi Hämäläinen 7aef811ff7 CMake: Refactor CMake build (#5032)
* CMake: Refactor build to multiple libraries

- Refactor CMake build system by creating separate libraries for
  different components
- Create interface libraries for most dependencies and add 3rdparty::*
  ALIAS targets for ease of use and use them to try specifying correct
  dependencies for each target
- Prefer 3rdparty:: ALIAS when linking dependencies
- Exclude xxHash subdirectory from ALL build target
- Add USE_SYSTEM_ZLIB option to select between using included ZLib and
  the ZLib in CMake search path

* Add cstring include to Log.cpp

* CMake: Add 3rdparty::glew interface target

* Add Visual Studio CMakeSettings.json to gitignore

* CMake: Move building and finding LLVM to 3rdparty/llvm.cmake script

- LLVM is now built under 3rdparty/ directory in the binary directory

* CMake: Move finding Qt5 to 3rdparty/qt5.cmake script

- Script has to be included in rpcs3/CMakeLists.txt because it defines
  Qt5::moc target which isn't available in that folder if it is
  included in 3rdparty directory
- Set AUTOMOC and AUTOUIC properties for targets requiring them (rpcs3
  and rpcs3_ui) instead of setting CMAKE_AUTOMOC and CMAKE_AUTOUIC so
  those properties are not defined for all targets under rpcs3 dir

* CMake: Remove redundant code from rpcs3/CMakeLists.txt

* CMake: Add BUILD_LLVM_SUBMODULE option instead of hardcoded check

- Add BUILD_LLVM_SUBMODULE option (defaults to ON) to allow controlling
  usage of the LLVM submodule.
- Move option definitions to root CMakeLists

* CMake: Remove separate Emu subtargets

- Based on discussion in pull request #5032, I decided to combine
  subtargets under Emu folder back to a single rpcs3_emu target

* CMake: Remove utilities, loader and crypto targets: merge them to Emu

- Removed separate targets and merged them into rpcs3_emu target as
  recommended in pull request (#5032) conversations. Separating targets
  probably later in a separate pull request

* Fix relative includes in pad_thread.cpp

* Fix Travis-CI cloning all submodules needlessly
2018-09-18 13:07:33 +03:00
.github
.travis CMake: Refactor CMake build (#5032) 2018-09-18 13:07:33 +03:00
3rdparty CMake: Refactor CMake build (#5032) 2018-09-18 13:07:33 +03:00
asmjit@673dcefaa0
asmjitsrc CMake: Refactor CMake build (#5032) 2018-09-18 13:07:33 +03:00
bin Qt: Add Classic (Bright) Stylesheet 2018-07-05 23:22:33 +04:00
llvm@be9f7bfe20 Update LLVM 2018-07-21 12:18:07 +03:00
llvm_build Update dependencies 2018-08-25 01:47:13 +03:00
rpcs3 CMake: Refactor CMake build (#5032) 2018-09-18 13:07:33 +03:00
Utilities CMake: Refactor CMake build (#5032) 2018-09-18 13:07:33 +03:00
Vulkan Update Project to Visual Studio 2017. 2018-08-25 01:15:47 +03:00
.clang-format
.editorconfig Fix .editorconfig encoding 2018-09-17 12:18:40 +03:00
.gitignore CMake: Refactor CMake build (#5032) 2018-09-18 13:07:33 +03:00
.gitmodules 3rdparty: remove optional submodule 2018-08-31 20:13:54 +04:00
.mention-bot
.travis.yml CMake: Refactor CMake build (#5032) 2018-09-18 13:07:33 +03:00
appveyor.yml 3rdparty: remove optional submodule 2018-08-31 20:13:54 +04:00
CMakeLists.txt CMake: Refactor CMake build (#5032) 2018-09-18 13:07:33 +03:00
git-clang-format
LICENSE
pre-commit.readme
README.md Bump CMake Requirement to 3.8.2+ 2018-08-29 22:01:57 +01:00
rpcs3_debug.props
rpcs3_default.props Add _ENABLE_EXTENDED_ALIGNED_STORAGE 2018-08-25 21:06:24 +03:00
rpcs3_llvm.props
rpcs3_memleak.props
rpcs3_release.props
rpcs3.sln Update Project to Visual Studio 2017. 2018-08-25 01:15:47 +03:00
usertype.dat

RPCS3

Build Status Build status

The world's first open-source PlayStation 3 emulator/debugger, written in C++ for Windows and Linux.

You can find some basic information in our website. Game info is being populated on the wiki. For discussion about this emulator and PS3 emulation, or game compatibility reports, please visit our forums and our Discord server.

Support Lead Developers Nekotekina and kd-11 on Patreon

Development

If you want to contribute please take a look at the Coding Style, Roadmap and Developer Information pages. You should as well contact any of the developers in the forums or in Discord in order to know more about the current situation of the emulator.

Dependencies

Windows

Either add the QTDIR environment variable, e.g. <QtInstallFolder>\5.11.1\msvc2017_64\ , or use the Visual Studio Qt Plugin

Linux

  • Qt 5.10+
  • GCC 7.3+ or Clang 5.0+
  • CMake 3.8.2+
  • Debian & Ubuntu: sudo apt-get install cmake build-essential libasound2-dev libpulse-dev libopenal-dev libglew-dev zlib1g-dev libedit-dev libvulkan-dev libudev-dev git qt5-default
  • Arch: sudo pacman -S glew openal cmake vulkan-validation-layers qt5-base
  • Fedora: sudo dnf install alsa-lib-devel cmake glew glew-devel libatomic libevdev-devel libudev-devel openal-devel qt5-devel vulkan-devel
  • OpenSUSE: sudo zypper install git cmake libasound2 libpulse-devel openal-soft-devel glew-devel zlib-devel libedit-devel vulkan-devel libudev-devel libqt5-qtbase-devel libevdev-devel

If you have an NVIDIA GPU, you may need to install the libglvnd package.

MacOS

MacOS is not supported at this moment because it doesn't meet system requirements (OpenGL 4.3)

  • Xcode 10
  • Install with Homebrew: brew install glew llvm qt cmake

Building on Windows:

To initialize the repository don't forget to execute git submodule update --init to pull the submodules.

Configuring the Qt plugin (if used)

  1. Go to the Qt5 menu and edit Qt5 options. Add the path to your Qt installation with compiler e.g. <QtInstallFolder>\5.11.1\msvc2017_64.
  2. While selecting the rpcs3qt project, go to Qt5->Project Setting and select the version you added.

Building the projects

Open rpcs3.sln. The recommended build configuration is Release - LLVM, for all purposes.

You may want to download precompiled LLVM libs and extract to root rpcs3 folder (which contains rpcs3.sln), as well as download and extract additional libs to lib\%CONFIGURATION%-x64\ to speed up compilation time (unoptimised/debug libs are currently not available precompiled).

If you're not using precompiled libs, build the projects in __BUILD_BEFORE folder: right-click on every project > Build.

Build > Build Solution

Building on Windows (MinGW):

  1. Install packages
  • pacman -S base-devel mingw-w64-x86_64-toolchain mingw-w64-x86_64-cmake mingw-w64-x86_64-yasm mingw-w64-x86_64-python2 mingw-w64-x86_64-ntldd-git mingw-w64-x86_64-qt5 mingw-w64-x86_64-openal mingw-w64-x86_64-glew git
  1. Clone repository
  • git clone https://github.com/RPCS3/rpcs3.git
  1. Update submodules
  • cd rpcs3
  • git submodule update --init
  • cd ..
  1. Configure and compile rpcs3
  • mkdir rpcs3_build && cd rpcs3_build
  • cmake -G "MSYS Makefiles" -DCMAKE_MAKE_PROGRAM=mingw32-make ../rpcs3/
  • mingw32-make.exe GitVersion && mingw32-make.exe discord-rpc
  • If you use -DUSE_SYSTEM_FFMPEG=OFF, run mingw32-make ffmpeg-mingw
  1. Build rpcs3
  • Run mingw32-make or mingw32-make -jX where X is your CPU cores.
  1. Copy dependencies
  • cd ./bin
  • for l in $(ntldd.exe -R rpcs3.exe|grep mingw64|sed -e 's/^[ \t]*//'|cut -d' ' -f3);do cp $l .;done
  1. Copy qt plugins
  • mkdir -p ./qt/plugins/{bearer,imageformats,platforms,styles}
  • cp /mingw64/share/qt5/plugins/bearer/qgenericbearer.dll ./qt/plugins/bearer/
  • cp /mingw64/share/qt5/plugins/imageformats/{qgif.dll,qicns.dll,qico.dll,qjpeg.dll,qtga.dll,qtiff.dll,qwbmp.dll,qwebp.dll} ./qt/plugins/imageformats/
  • cp /mingw64/share/qt5/plugins/platforms/qwindows.dll ./qt/plugins/platforms/
  • cp /mingw64/share/qt5/plugins/styles/qwindowsvistastyle.dll ./qt/plugins/styles/
  1. Run RPCS3 with ./rpcs3

Building on Linux & Mac OS:

  1. git clone https://github.com/RPCS3/rpcs3.git
  2. cd rpcs3/
  3. git submodule update --init
  4. cd ../ && mkdir rpcs3_build && cd rpcs3_build
  5. cmake ../rpcs3/ && make GitVersion && make
  6. Run RPCS3 with ./bin/rpcs3

If you are on MacOS and want to build with brew llvm and qt don't forget to add the following environment variables

  • LLVM_DIR=/usr/local/opt/llvm/ (or wherever llvm was installed).
  • Qt5_DIR=/usr/local/opt/qt/lib/cmake/Qt5 (or wherever qt was installed).

When using GDB, configure it to ignore SIGSEGV signal (handle SIGSEGV nostop noprint).

CMake Build Options (Linux & Mac OS)

  • -DUSE_SYSTEM_LIBPNG=ON/OFF (default = OFF) Build against the shared libpng instead of using the builtin one. libpng 1.6+ highly recommended. Try this option if you get version conflict errors or only see black game icons.

  • -DUSE_SYSTEM_FFMPEG=ON/OFF (default = OFF) Build against the shared ffmpeg libraries instead of using the builtin patched version. Try this if the builtin version breaks the OpenGL renderer for you.

  • -DWITHOUT_LLVM=ON/OFF (default = OFF) This forces RPCS3 to build without LLVM, not recommended.

  • -DWITH_GDB=ON/OFF (default = OFF) This Builds RPCS3 with support for debugging PS3 games using gdb.

  • -DUSE_VULKAN=ON/OFF (default = ON) This builds RPCS3 with Vulkan support.

  • -DUSE_NATIVE_INSTRUCTIONS=ON/OFF (default = ON) This builds rpcs3 with -march=native, which is useful for local builds, but not good for packages.

License

Most files are licensed under the terms of GNU GPLv2 License, see LICENSE file for details. Some files may be licensed differently, check appropriate file headers for details.