Find a file
2019-05-19 17:46:55 +03:00
.github Move Contributing to .github 2018-02-12 01:58:14 +04:00
.travis travis: update mac build 2019-05-06 21:06:25 +02:00
3rdparty Link LLVMAsmParser library 2019-05-19 17:46:55 +03:00
asmjit@1e550aa568 Update asmjit 2019-03-13 01:56:43 +03:00
asmjitsrc CMake: use CMAKE_SOURCE_DIR instead of .. in some places 2018-12-10 01:43:47 +03:00
bin Further changes to Skyline and Envy 2019-05-14 09:16:45 +01:00
llvm@b860b5e8f4 Update LLVM 2019-04-12 22:20:21 +03:00
llvm_build Update dependencies 2018-08-25 01:47:13 +03:00
rpcs3 rsx: Fix upload block range optimization 2019-05-19 17:33:21 +03:00
Utilities Link LLVMAsmParser library 2019-05-19 17:46:55 +03:00
Vulkan Update Project to Visual Studio 2017. 2018-08-25 01:15:47 +03:00
.clang-format Update .clang-format 2018-05-08 13:05:29 +03:00
.editorconfig Fix .editorconfig encoding 2018-09-17 12:18:40 +03:00
.gitignore Fix macOS compilation 2018-11-19 14:39:33 +03:00
.gitmodules libusb VS stuff 2019-04-16 22:47:24 +02:00
.mention-bot Added DHrpcs3 to mention-bot ignore list (#2026) 2016-08-04 22:36:10 +03:00
.travis.yml travis: update mac build 2019-05-06 21:06:25 +02:00
appveyor.yml updated domain name for vulkan mirror 2019-04-01 13:46:32 +03:00
CMakeLists.txt Add CMake switch for disabling Discord Rich Presence and fix no llvm build 2018-12-20 11:29:35 +01:00
git-clang-format Add a git pre-commit hook running clang-format 2016-08-27 15:40:41 +02:00
LICENSE Few bugs fixed and license file added 2014-02-13 11:33:07 +01:00
pre-commit.readme Add a git pre-commit hook running clang-format 2016-08-27 15:40:41 +02:00
README.md Update to README.md due to dependency 2019-04-30 14:33:01 +03:00
rpcs3.sln libusb VS stuff 2019-04-16 22:47:24 +02:00
rpcs3_debug.props Partial commit: Preview 2016-04-15 19:22:15 +03:00
rpcs3_default.props Increase max stack size to 8 MB on Windows 2019-04-14 18:03:45 +03:00
rpcs3_llvm.props Link LLVMAsmParser library 2019-05-19 17:46:55 +03:00
rpcs3_memleak.props Property sheets, configuration simplified 2015-12-08 20:02:30 +03:00
rpcs3_release.props Partial commit: Preview 2016-04-15 19:22:15 +03:00
usertype.dat .clang-format added 2016-08-12 14:32:57 +03:00

RPCS3

Build Status Build status

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

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

Support Lead Developers Nekotekina and kd-11 on Patreon

Contributing

If you want to help the project but do not code, the best way to help out is to test games and make bug reports. See:

If you want to contribute as a developer, please take a look at the following pages:

You should also contact any of the developers in the forums or in the Discord server to learn more about the current state of the emulator.

Dependencies

Windows

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

Linux

  • Qt 5.10+ (Avoid 5.11.1, due to a bug)
  • 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 libevdev-dev qtdeclarative5-dev qtbase5-private-dev
  • Arch: sudo pacman -S glew openal cmake vulkan-validation-layers qt5-base qt5-declarative
  • 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.

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.

Clone and initialize the repository:

  1. git clone https://github.com/RPCS3/rpcs3.git
  2. cd rpcs3/
  3. git submodule update --init

Windows

Configuring the Qt plugin (if used)

  1. Go to the Qt5 menu and edit Qt5 options.
  2. Add the path to your Qt installation with compiler e.g. <QtInstallFolder>\5.11.2\msvc2017_64.
  3. 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

Linux

While still in the project root:

  1. cd .. && mkdir rpcs3_build && cd rpcs3_build
  2. cmake ../rpcs3/ && make
  3. Run RPCS3 with ./bin/rpcs3

When using GDB, configure it to ignore SIGSEGV signal (handle SIGSEGV nostop noprint). If desired, use the various build options in CMakeLists.

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.