Skip to content

An experimental PS4 emulator written in Rust

License

Notifications You must be signed in to change notification settings

bayedieng/obliteration

 
 

Repository files navigation

Logo

About

CI Discord

Obliteration is an experimental PS4 emulator using Kyty and Uplift as a reference. The project is under development and cannot run any games that Kyty is able to run yet.

The original author of Kyty is not involved in the development of Obliteration in any way. Obliteration is a completely separate project. The reason you see the author of Kyty in the contributor list is because this project contains commits from Kyty.

Get a daily build

You can download binaries from the latest commits here. You MUST sign in to GitHub otherwise you will not be able to download files.

Screenshots

Screenshots

Thanks to VocalFan for the awesome icon!

Obliteration discussion

We have a Discord server for discussion about Obliteration and its development. You can join the server here.

Features

  • Cross-platform with native binary for each platform.
  • Built-in FTP client to pull the decrypted firmware from jailbroken PS4.
  • Built-in PKG file supports for Fake PKG.
  • Game library.
  • Emulate system calls instead of user-space libraries.
  • Supports AArch64 CPU.

System requirements

  • Windows 10, Linux or macOS.
  • x86-64 CPU.
  • A jailbroken PS4 with FTP server that supports SELF decryption.

Windows-specific requirements

  • Microsoft Visual C++ 2022 Redistributable. If there is an error related to msvcp140.dll, vcruntime140.dll, or vcruntime140_1.dll that means you need to install this manually. It's likely your system already has it, so try to run Obliteration first.

Linux-specific requirements

Obliteration supports only 4KB/8KB/16KB pages. Most people should not have any problem with this because 4KB is the default for most distros.

Building from source

Windows prerequisites

  • Visual Studio 2022
    • Desktop development with C++ workload is required
  • Rust on the latest stable channel
  • CMake 3.21+
    • Make sure you have Add CMake to the system PATH selected when installing
  • Python 3.6+
    • Make sure you have Add python.exe to PATH selected when installing

Linux prerequisites

  • GCC 9.4+
  • Rust on the latest stable channel
  • CMake 3.21+

macOS prerequisites

  • macOS 12+
  • Homebrew
  • Clang 13+
  • Rust on the latest stable channel
  • CMake 3.21+

Install Qt 6

You need to install Qt 6 on your system before you proceed. The minimum version is 6.5.

Windows-specific requirements

You need Qt Online Installer for open-source to install Qt, downloaded from https://www.qt.io. The installer will ask you to sign in with a Qt account, which you can create for free. You need to check Custom installation and do not check Qt for desktop development that is using the MinGW toolchain. Make sure you have checked the MSVC 2019 64-bit component in the Select Components page for the version you wish to install and uncheck all of the other components.

Once installation is completed you need to set the CMAKE_PREFIX_PATH environment variable to the full path of the installed version (e.g. C:\Qt\6.5.1\msvc2019_64). To set an environment variable:

  1. Open a run dialog with Win + R.
  2. Enter sysdm.cpl then click OK.
  3. Go to the Advanced tab then click on Environment Variables....
  4. Click New... to create a new environment variable. Just create for either User variables or System variables, not both.
  5. Restart your terminal or IDE to load the new PATH.

Install Qt with Homebrew (macOS only)

brew install qt@6

Configure build system

cmake --preset PRESET .

The value of PRESET will depend on your platform and the build configuration you want to use. The current available presets are:

  • windows-release
  • windows-debug
  • linux-release
  • linux-debug
  • mac-release
  • mac-debug

If all you want is to use the emulator, choose [YOUR-PLATFORM]-release for optimized outputs. But if you want to edit the code, choose *-debug.

Build

cmake --build build

You can use -j to enable parallel building (e.g. cmake --build build -j 2). Each parallel build on Linux consumes a lot of memory so don't use the number of your CPU cores otherwise your system might crash due to out of memory. On Windows it seems like it is safe to use the number of your CPU cores.

Development

Before proceeding, make sure the build preset you are using is *-debug. We recommend Visual Studio Code as a code editor with the following extensions:

Then open this folder with VS Code. It will ask which CMake preset to use and you need to choose the same one that you were using when building. Everything should work out of the box (e.g. code completion, debugging, etc).

Get a homebrew application for testing

If you don't have a PS4 application for testing you can download PS Scene Quiz for free here.

Rules for Rust sources

  • Use unsafe code only when you know what you are doing. When you do try to wrap it in a safe function so other people who are not familiar with unsafe code can have a safe life.
  • Don't chain method calls without an intermediate variable if the result code is hard to follow. We encourage code readability as a pleasure when writing so try to make it easy to read and understand for other people.
  • Do not blindly cast an integer. Make sure the value can fit in a destination type. We don't have any plans to support non-64-bit systems so the pointer size and its related types like usize are always 64-bits.

Rules for C++ sources

Just follow how Qt is written (e.g. coding style, etc.). Always prefers Qt classes over std when possible so you don't need to handle exceptions. Do not use the Qt ui file to design the UI because it will break on a high-DPI screen.

Starting point

The application consists of 2 binaries:

  1. Main application. This is what users will see when they launch Obliteration. Its entry point is inside src/main.cpp.
  2. Emulator kernel. This is where emulation takes place. Its entry point is inside src/kernel/src/main.rs.

Debugging the kernel

Create .kernel-debug in the root of the repository. The contents of this file is YAML and the kernel will deserialize it to the Args struct in src/kernel/src/main.rs when passing the --debug flag to the kernel.

  • game: (Folder Path) | Where is the game to load?
  • system: (Folder Path) | Where is the system firmware?
  • debug-dump: (Folder Path) | Where should the debug log be saved?
  • clear-debug-dump: (boolean) | Should we remove the old debug log?

We already provide a launch configuration for VS Code so all you need to do is choose Kernel as the configuration and start debugging.

UI Icons

We use icons from https://materialdesignicons.com for UI (e.g. on the menu and toolbar).

Additional informations

PS4 Developer Wiki has a lot of useful information about the PS4 internal. We also have a PS4 reverse engineering project.

Code contribution

If you want to make some contributions but don't know what to work on you can look for TODO comment or todo! macro invocation in the source code. You can also take a look on the unassigned issues.

License

  • src/ansi_escape.hpp, src/ansi_escape.cpp, src/log_formatter.hpp and src/log_formatter.cpp are licensed under GPL-3.0 only.
  • src/param, src/pfs and src/pkg are licensed under LGPL-3.0 license.
  • All other source code is licensed under MIT license.
  • All release binaries are under GPL-3.0 license.

About

An experimental PS4 emulator written in Rust

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 90.5%
  • C++ 8.7%
  • CMake 0.8%