Xbox 360 Emulator Research Project
Go to file
emoose 265903fe66 [CPU] Add XEXP support to XexModule, if XEXP is in same folder as XEX
This was a headache to work out, big thanks to the lack of documentation on .xexp files... a ton of guesswork was involved here but luckily it turned out well.

I did have to make some pretty major changes to the way XEX files are loaded though.
Previously it'd just load everything in one go: XEX headers -> decrypt/decompress data -> load imports/symbols -> set loader data table entries, etc...

Now it's changed to something like this:
- Load base XEX headers + decrypted/decompressed image data, return X_STATUS_PENDING
- In the LoadFromFile call used to load the XEX, search for XEXP patch file (only .xexp in same folder atm)
- If patch exists: load XEXP, decrypt headers/data, apply patch to base XEX, dispose of XEXP
- Finish XEX load via LoadXexContinue() (handles imports/symbols/loader data...)

This saves us from needing to reset the imports/function/symbol stuff after patching (since all the XEX code will be a lot different), but I'm not really sure if I went about it the best way.
2018-10-20 04:36:21 +01:00
.github Mention the Xenia subreddit in the issue template 2017-08-13 11:40:03 -05:00
assets [UI] Correct the order of mips in the icon 2018-05-04 17:35:29 -05:00
docs [Docs] Fix formatting error in CPU documentation. 2018-05-27 10:17:08 -05:00
src/xenia [CPU] Add XEXP support to XexModule, if XEXP is in same folder as XEX 2018-10-20 04:36:21 +01:00
third_party [Vulkan] Update to Vulkan 1.1 2018-05-04 17:40:21 -05:00
tools Validate trace executable before starting thread pool 2017-12-20 14:36:10 -06:00
.appveyor.yml AppVeyor magic? 2018-05-10 19:53:06 -05:00
.clang-format Include order fixes. 2015-12-27 10:27:46 -08:00
.gitattributes gitattributes (maybe). 2015-05-24 01:16:34 -07:00
.gitignore Update .gitignore. 2018-05-22 22:24:39 -05:00
.gitmodules [Vulkan] Replace vulkan-loader with volk 2018-05-04 16:49:46 -05:00
.travis.yml [Base Tests] Add tests for all cases in memory.cc 2018-04-20 18:50:39 -07:00
LICENSE Adding CONTRIBUTING.md so that github shows it on issues. 2015-08-28 14:16:38 -07:00
README.md Always use master branch for Travis badge for build status. 2018-06-14 18:05:43 -05:00
premake5.lua Ignore unused-result warnings 2018-06-26 13:36:33 -05:00
xb Add xb symlink to xenia-build to match xb.bat for win 2017-07-11 11:47:24 -06:00
xb.bat Remove "FOUND PYTHON 2" debug message 2017-09-21 16:45:42 -05:00
xenia-build Merge pull request #1086 from bwrsandman/xenia-build-test-bin-path 2018-10-12 15:08:04 -05:00
xeniarc clang-format detection cleanup. 2015-08-01 00:41:46 -07:00

README.md

Xenia - Xbox 360 Emulator Research Project

Xenia is an experimental emulator for the Xbox 360. For more information see the main xenia website.

Come chat with us about emulator-related topics on Discord. For developer chat join #dev but stay on topic. Lurking is fine. Please check the frequently asked questions page before asking questions. We've got jobs/lives/etc, so don't expect instant answers.

Discussing illegal activities will get you banned. No warnings.

Status

Buildbot Status
Windows Build status
Linux Build status

Some real games run. Most don't. See the Game compatibility list for currently tracked games and feel free to contribute your own updates, screenshots, and information there following the existing conventions.

Disclaimer

The goal of this project is to experiment, research, and educate on the topic of emulation of modern devices and operating systems. It is not for enabling illegal activity. All information is obtained via reverse engineering of legally purchased devices and games and information made public on the internet (you'd be surprised what's indexed on Google...).

Quickstart

Windows 8.1+ with Python 3.4 and Visual Studio 2017 and the Windows SDKs installed:

> git clone https://github.com/benvanik/xenia.git
> cd xenia
> xb setup

# Pull latest changes, rebase, and update submodules and premake:
> xb pull

# Build on command line:
> xb build

# Run premake and open Visual Studio (run the 'xenia-app' project):
> xb devenv

# Run premake to update the sln/vcproj's:
> xb premake

# Format code to the style guide:
> xb format

When fetching updates use xb pull to automatically fetch everything and run premake for project files/etc.

Building

See building.md for setup and information about the xb script. When writing code, check the style guide and be sure to run clang-format!

Contributors Wanted!

Before contributing code or issues be sure to read CONTRIBUTING.md.

Have some spare time, know advanced C++, and want to write an emulator? Contribute! There's a ton of work that needs to be done, a lot of which is wide open greenfield fun.

For general rules and guidelines please see CONTRIBUTING.md.

Fixes and optimizations are always welcome (please!), but in addition to that there are some major work areas still untouched:

  • Help work through missing functionality/bugs in game compat
  • Add input drivers for PS4 controllers (or anything else)
  • Skilled with Linux? A strong contributor is needed to help with porting

See more projects good for contributors. It's a good idea to ask on Discord/the bugs before beginning work on something.

FAQ

For more see the main frequently asked questions page.

Can I get an exe?

Check Appveyor's artifacts to see what's there.