Skip to content
This repository has been archived by the owner on Dec 5, 2023. It is now read-only.
/ OpenXenium Public archive

OpenXenium - Open Source Xenium Modchip CPLD replacement project for the Original Xbox

Notifications You must be signed in to change notification settings

Ryzee119/OpenXenium

Repository files navigation

OpenXenium

OpenXenium Assembled

About this Repository

This started out as a project to mess around with some VHDL; however turned in a full recreation of a Original Xbox LPC memory/IO device. The VHDL is 100% compatible with XeniumOS, which is a Cromwell based bootloader made by TeamXodus. This allows loading user BIOS binaries and some basic Xbox tools (EEPROM Backup/modification, Hard drive Rebuilding, Locking, Unlocking).

The VHDL written by Team Xodus was never released and the CPLD is read protected so it is not trivial to extract the bitstream. My own VHDL is probably quite similar to what Team Xodus produced for the Xenium Modchip but I have independently reverse engineered the behavioral design on the CPLD. (There was no bypassing of the protection features of a genuine Xenium.) Therefore I have named this project OpenXenium. An open source recreation of the Xenium CPLD released under GPL which documents the internal workings by means of open source VHDL of the Xenium Modchip.

I do a quick run through of the build process here: https://youtu.be/P6YYViKby74

Supported Features

The VHDL implements the following LPC transactions:

  • Memory Read/Writes (Translated to a parallel flash memory interface)
  • IO Read/Writes

From an Original Xbox perspective, this covers all requirements to make a custom LPC memory/IO peripheral for the console. Colloquially known as a modchip which can load custom BIOS files like Cromwell and its derivatives without modifying the onboard TSOP flash memory or softmodding. This supports IO control for accessories like LCD screens, LED controllers, external switches etc.

When used with XeniumOS the VHDL in this repo supports the following features:

  • Software controlled BIOS bank switching (any BIOS combinations that fit into 1mbyte of flash memory (4x256k, 1x512+2x256k, 2x512k, 1x1mbyte).
  • Instant boot to a chosen BIOS using the power button.
  • Boot the XeniumOS with eject button.
  • Ability to boot from the onboard BIOS (colloquially known as TSOP booting). This will completely disable OpenXenium and release D0/LFRAME(1.6) to boot the Xbox as if stock.
  • All the standard features in Cromwell/XeniumOS. (EEPROM tools, Hard drive tools, FTP/SMB Server etc.).
  • Three general purpose outputs. These are normally bitbanged as a SPI master (MOSI,CLK,CS) with the most common use an LCD, however could support any SPI peripheral in theory.
  • Two general purpose inputs. On a Xenium, these are I believe intended to be MISO lines to complement the SPI interface but could be used for any 3.3V digital logic.
  • Three outputs are connected to an RGB led (Or an external user added RGB led).
  • Reserved memory on the flash chip for non-volatile storage of an EEPROM backup and XeniumOS settings.
  • If you bridge the two recovery pins on power up, it will attempt to boot the XeniumOS recovery BIOS if available. This functions the same as a genuine Xenium modchip.
  • I also simulate the LFRAME abort mechanism (Ref Intel LPC Interface Spec Rev 1.1 Section 4.3.1.13) for a v1.6 console to prevent the Xyclops responding to the MCPX LPC Memory Read requests during boot (and conflicting with an external LPC memory peripheral). This is generally accepted to be better than shorting LFRAME the ground constantly which some traditional LPC memory addons do.

Folder Structure

Firmware - Contains the VHDL and constraint files to synthesize the design using Xilinx ISE Design Suite 14.7 to generate a JEDEC or SVF file for programming.
Hardware - Contains the PCB Files (Created with Autodesk Eagle) and bill of materials information to build your own.
Xenium-Tools - Contains a custom XBE (Created with NXDK) to dump the flash contents of Xenium based devices, parse Xenium update files or write a raw flash dump to a OpenXenium/Genuine Xenium and some other Xenium related things.

XeniumOS BIOS

Although XeniumOS is based on Cromwell which is a non-Microsoft GPL open source BIOS, XeniumOS only uses Cromwell to bootstrap their own user interface. Team Xodus released their modified Cromwell portion under GPL (Can be found on old Xbox sites). Their own code portion has callbacks to Cromwell, but supposedly contained no GPL code therefore was never open sourced and presumably never licensed for other hardware (clones). Consequently, although it is claimed to not contain any Microsoft code; XeniumOS is still property of Team Xodus, so I believe it cannot be included in this repo.

The recommended way to get a copy of XeniumOS is to take a backup of your own Xenium modchip using xenium-tools provided in this repo. It is also possible to parse the v2.3.1 XeniumOS update files released by Team Xodus to extract the neccessary data; however this will not contain the factory programmed recovery sector, but otherwise works in the same way.

This has been tested with XeniumOS 2.3.1 (Last release) and XeniumOS 2.3.1(Gold variant). The only way to obtain Gold OS is to dump the flash contents of your XeniumGold as the binary files were never distributed individually.

Installation and Initial Setup

See Installation.MD

Licensing

OpenXenium is free and open source. Please respect the licenses available in their respective folders.

References that helped me in this project

Open Xenium Installed

If you like my work please consider a small donation
paypal
By Ryzee119

About

OpenXenium - Open Source Xenium Modchip CPLD replacement project for the Original Xbox

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages