Difference between revisions of "Xbox Port Roadmap"

From ReactOS Wiki
Jump to: navigation, search
(Implement missing drivers: console driver)
(13 intermediate revisions by 3 users not shown)
Line 1: Line 1:
This page describes the plan of reviving ReactOS port for original Xbox, including components outside the source tree.
+
This page describes the plan of reviving ReactOS port for the original Xbox, including components outside the source tree.
  
 
Once something is done in this list, it should be simply removed.
 
Once something is done in this list, it should be simply removed.
Line 10: Line 10:
 
** Blocks actual OS testing in XQEMU
 
** Blocks actual OS testing in XQEMU
 
** '''Important:''' check whether the problem is reproduced on real Xbox
 
** '''Important:''' check whether the problem is reproduced on real Xbox
 +
* Fix random 'Invalid Opcode' exceptions - {{JIRA|16627}}
 +
** Blocks testing LiveCD in XQEMU
 +
* Fix DVD drive not being detected - {{JIRA|16628}}
 +
** RealHW only
 
* Fix PCI-to-PCI bridge PnP problem - {{JIRA|16319}}
 
* Fix PCI-to-PCI bridge PnP problem - {{JIRA|16319}}
 
** RealHW only, applied workaround in master - {{GitRev|b99272702c94f5c6707dc095d3d11bb5a0147c43}}
 
** RealHW only, applied workaround in master - {{GitRev|b99272702c94f5c6707dc095d3d11bb5a0147c43}}
Line 16: Line 20:
 
* <code>Assertion failed: (pti->pcti->fsChangeBits & QS_SENDMESSAGE) == 0</code> happens in <code>win32ss/user/ntuser/misc.c, line 729</code> after some idle hours, and it can be safely cont'ed from kernel debugger
 
* <code>Assertion failed: (pti->pcti->fsChangeBits & QS_SENDMESSAGE) == 0</code> happens in <code>win32ss/user/ntuser/misc.c, line 729</code> after some idle hours, and it can be safely cont'ed from kernel debugger
 
** Does not happen with <code>usbohci.sys</code> from Windows 2003 for some reason
 
** Does not happen with <code>usbohci.sys</code> from Windows 2003 for some reason
* Fix <code>XBOX_IDE_CONTROL_PORT</code>, it should be <code>0x3F6</code> (primary channel) instead of <code>0x170</code> (secondary channel), see links: [https://git.reactos.org/?p=reactos.git;a=blob;f=boot/freeldr/freeldr/arch/i386/xboxdisk.c;h=e1e4d3559e74689b223629de83b5f6529181ab9c;hb=e329e83857db0db67c6798c538ad658be044057e#l31], [http://209.68.14.80/ref/hdd/if/ide/confChannels-c.html], [https://github.com/xqemu/xqemu/blob/master/hw/ide/isa.c#L105]
 
  
 
=== Improve ReactOS ===
 
=== Improve ReactOS ===
* Obtain memory map via multiboot on Xbox - {{JIRA|16300}}, [https://github.com/reactos/reactos/pull/1971 PR #1971]
 
** Will allow <code>bootvid</code> and <code>xboxvmp</code> to work properly
 
** Will allow firmware to prepare SMBIOS/PCI BIOS tables in memory
 
 
* Add bootvid selection into <code>txtsetup.sif</code> and <code>setuplib</code> - '''FIXME: needs ticket'''
 
* Add bootvid selection into <code>txtsetup.sif</code> and <code>setuplib</code> - '''FIXME: needs ticket'''
 
** See [https://chat.reactos.org/reactos/pl/ourrbyihibbf5p8whcb879uwzy chat message] from Hermes Belusca
 
** See [https://chat.reactos.org/reactos/pl/ourrbyihibbf5p8whcb879uwzy chat message] from Hermes Belusca
 
* Fix Xbox HAL to report reserved video memory range for NVIDIA NV2A - '''FIXME: needs ticket'''
 
* Fix Xbox HAL to report reserved video memory range for NVIDIA NV2A - '''FIXME: needs ticket'''
 
** See [https://chat.reactos.org/reactos/pl/83uwqwtb63yefm5ca8qy3qgmtr chat message] from Thomas Faber
 
** See [https://chat.reactos.org/reactos/pl/83uwqwtb63yefm5ca8qy3qgmtr chat message] from Thomas Faber
* Add ATAPI support into FreeLdr - {{JIRA|16220}}
 
** Will allow to test bootcd and livecd
 
** Could be useful for [[PC-98]] port as well
 
 
* Add automatic HAL selection in FreeLdr - '''FIXME: needs ticket'''
 
* Add automatic HAL selection in FreeLdr - '''FIXME: needs ticket'''
 
** Will allow to test bootcd and livecd
 
** Will allow to test bootcd and livecd
Line 47: Line 44:
 
* Add <code>bootvid</code> driver for Xbox - {{JIRA|16219}}
 
* Add <code>bootvid</code> driver for Xbox - {{JIRA|16219}}
 
** Nice for public demonstration and user experience
 
** Nice for public demonstration and user experience
 +
* Add console text mode driver for NVIDIA NV2A - '''FIXME: needs ticket'''
 +
** Will allow installing from bootcd
 
* Add <code>vgasave</code> driver for NVIDIA NV2A - '''FIXME: needs ticket'''
 
* Add <code>vgasave</code> driver for NVIDIA NV2A - '''FIXME: needs ticket'''
 
** See [https://chat.reactos.org/reactos/pl/kptqdu1uppbc3qogujqjioz83e chat message] from r3mendozal
 
** See [https://chat.reactos.org/reactos/pl/kptqdu1uppbc3qogujqjioz83e chat message] from r3mendozal
Line 58: Line 57:
 
** Add support for OpenGL
 
** Add support for OpenGL
 
** Potentially will help here - [https://jira.reactos.org/browse/CORE-16465?focusedCommentId=118579&page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#comment-118579 CORE-16465]
 
** Potentially will help here - [https://jira.reactos.org/browse/CORE-16465?focusedCommentId=118579&page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#comment-118579 CORE-16465]
 
=== Backport fixes into XboxDev Cromwell ===
 
* Add multisystem support
 
** General refactoring of boot code
 
** Prepare for multisystem support and more refactoring
 
** Refactor config entries finalization
 
** Better function naming for multisystem
 
** Add nested multisystem boot menu
 
* Add ReactOS boot support based on Ge van Geldorp code
 
* Add ReactOS native partition boot support
 
* Fix array write out-of-bounds bug in <code>rawread</code>
 
  
 
=== Fix bugs and improve Cromwell ===
 
=== Fix bugs and improve Cromwell ===
 
* Fix glitchy text characters: '''. _ ( f'''
 
* Fix glitchy text characters: '''. _ ( f'''
 
* Fix boot device label positioning (in 720x480 and 1024x576 screen mode)
 
* Fix boot device label positioning (in 720x480 and 1024x576 screen mode)
* Fix static framebuffer address (64 vs 128 MB RAM)
 
* Fix memory map
 
 
* Fix Xromwell XBE problems on some Xbox'es ''(at least the one JayFoxRox have)''
 
* Fix Xromwell XBE problems on some Xbox'es ''(at least the one JayFoxRox have)''
 
* Add SMBIOS table generation
 
* Add SMBIOS table generation

Revision as of 13:26, 15 January 2020

This page describes the plan of reviving ReactOS port for the original Xbox, including components outside the source tree.

Once something is done in this list, it should be simply removed.

Revive ReactOS Xbox port

Progress is tracked in CORE-16216.

Fix ReactOS bugs

  • Fix USB OHCI - CORE-16352
    • Blocks actual OS testing in XQEMU
    • Important: check whether the problem is reproduced on real Xbox
  • Fix random 'Invalid Opcode' exceptions - CORE-16627
    • Blocks testing LiveCD in XQEMU
  • Fix DVD drive not being detected - CORE-16628
    • RealHW only
  • Fix PCI-to-PCI bridge PnP problem - CORE-16319
    • RealHW only, applied workaround in master - b992727
  • Fix FindResourceExW debug print problem (low priority)
    • Too hard to reproduce
  • Assertion failed: (pti->pcti->fsChangeBits & QS_SENDMESSAGE) == 0 happens in win32ss/user/ntuser/misc.c, line 729 after some idle hours, and it can be safely cont'ed from kernel debugger
    • Does not happen with usbohci.sys from Windows 2003 for some reason

Improve ReactOS

  • Add bootvid selection into txtsetup.sif and setuplib - FIXME: needs ticket
  • Fix Xbox HAL to report reserved video memory range for NVIDIA NV2A - FIXME: needs ticket
  • Add automatic HAL selection in FreeLdr - FIXME: needs ticket
    • Will allow to test bootcd and livecd
  • Add support for Xbox BRFR partitions - CORE-16329
    • Requires disk_new driver - CORE-6264
    • Blocks testing on real hardware
  • Fix or implement FATX filesystem driver - CORE-16373
    • FATX support should be removed from fastfat, or not, if we switch to fastfat_new (but when?) - CORE-11819
    • Blocks testing on real hardware
  • Add input support in FreeLdr on Xbox - CORE-16218 (low priority)
    • freeldr.ini can be modified manually
  • Add HAL/video/bootvid sections into unattend.inf - FIXME: needs ticket

Documentation

  • Fix constants and variables naming in freeldr and xboxvmp from Xbox-Linux to MS (low priority)

Implement missing drivers

  • Add bootvid driver for Xbox - CORE-16219
    • Nice for public demonstration and user experience
  • Add console text mode driver for NVIDIA NV2A - FIXME: needs ticket
    • Will allow installing from bootcd
  • Add vgasave driver for NVIDIA NV2A - FIXME: needs ticket
  • Add NVIDIA nForce nvnet driver - CORE-15872 (low priority)
    • First test with existing closed-source driver
    • Potentially will help improving XQEMU nForce net emulation
  • Improve xboxvmp driver to support NVIDIA hardware acceleration (low priority)
    • Add support for 2D acceleration
    • Add support for DirectDraw
    • Add support for Direct3D
    • Add support for OpenGL
    • Potentially will help here - CORE-16465

Fix bugs and improve Cromwell

  • Fix glitchy text characters: . _ ( f
  • Fix boot device label positioning (in 720x480 and 1024x576 screen mode)
  • Fix Xromwell XBE problems on some Xbox'es (at least the one JayFoxRox have)
  • Add SMBIOS table generation
    • Check corresponding data on NVIDIA nForce 420 board
  • Add PCI BIOS table generation
    • Check corresponding data on NVIDIA nForce 420 board
  • Import features from XBOverclock project
  • Add full device information page for Peripherals menu (low priority)
  • Other published issues: https://github.com/XboxDev/cromwell/issues

Create open source Xbox firmware

See page Run Xbox Games on ReactOS‎.