Toggle menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

Uxnds 3DS: Difference between revisions

From GameBrew
No edit summary
No edit summary
 
(17 intermediate revisions by 2 users not shown)
Line 4: Line 4:
|description=Uxn (retro-style fantasy computer) ported to 3DS.
|description=Uxn (retro-style fantasy computer) ported to 3DS.
|author=asiekierka
|author=asiekierka
|lastupdated=2021/05/27
|lastupdated=2024/07/27
|type=Computer
|type=Computer
|version=0.1.1-3ds
|version=0.5.2
|license=MIT
|license=MIT
|download=https://dlhb.gamebrew.org/3dshomebrews/uxnds3ds.7z
|download=https://dlhb.gamebrew.org/3dshomebrews/uxnds3ds.7z
Line 17: Line 17:


==Installation==
==Installation==
There are three binaries provided:
There is one binary provided: uxnds.3dsx.
* uxn3ds.3dsx - Faster, but best used only with known-good software,
* uxn3ds_debug.3dsx - Slower, but provides debugging information, profiling information and performs CPU stack bounds checks.


By default, uxnds will run /uxn/boot.rom.
By default, uxnds will run /uxn/boot.rom or /uxn/launcher.rom. It also supports reading files from within /uxn.


'''Note:''' When using a real DS/DSi/3DS console, it is recommended to launch this program via nds-hb-menu - though, as it currently doesn't use argc/argv, it doesn't really change much.
'''Note:''' When using a real [[uxnds|DS/DSi]]/3DS console, it is recommended to launch this program via [[Homebrew Menu|nds-hb-menu]] - though, as it currently doesn't use argc/argv, it doesn't really change much.


==User guide==
==User guide==
On start, a keyboard is presented on the bottom screen, and the uxn display is on the top screen.  
On start, a keyboard is presented on the bottom screen, and the uxn display is on the top screen.  
You can use the system button in the lower-left corner to reset the uxn virtual machine.


===Resources===
===Resources===
* [https://itch.io/c/248074/uxn-roms Uxn roms] ([https://git.sr.ht/~rabbits repo]) - Uxn roms by Rekka Bellum and Devine Lu Linvega.
* [https://itch.io/c/248074/uxn-roms Uxn Roms] ([https://git.sr.ht/~rabbits repo]) - Uxn roms by Rekka Bellum and Devine Lu Linvega.
* [https://github.com/aduros/webuxn/tree/master/roms Uxn Demos] - List of demos by Bruno Garcia.
* [https://github.com/aduros/webuxn/tree/master/roms Uxn Demos] - List of demos by Bruno Garcia.
* [https://compudanzas.net/uxn_tutorial.html Unx tutorial] - Unx programming guide.
* [https://compudanzas.net/uxn_tutorial.html Unx tutorial] - Unx programming guide.
Line 46: Line 46:
<youtube>z8TieqFotXE</youtube>
<youtube>z8TieqFotXE</youtube>


==Compatbility==
==Compatibility==
Works on DS, DSi and 3DS.
Works on DS, DSi and 3DS.


==Changelog==
==Changelog==
'''v0.5.2'''
*[NDS] Updated to BlocksDS 1.3.1.
'''v0.5.1'''
*[3DS] Fix crash on start.
'''v0.5.0'''
* Ported the ARM assembly CPU core from [https://git.badd10de.dev/uxngba uxngba].
** Speed benefits of +20-40% can be observed!
** Some CPU core bugs have also been fixed in the process, as tested with <code>opctest</code>.
** Relative to the core above, additional minor optimizations have been done for ARMv5/ARMv6 CPUs.
* [NDS] The debug build of uxnds will now prompt before exiting. This allows more convenient execution of CLI applications.
* [NDS] Updated to BlocksDS 1.3.0.
* Note that the new CPU core is not guaranteed to be bug-free; feel free to revert to [https://github.com/asiekierka/uxnds/releases/tag/v0.4.10 0.4.10] if you run into any issues.
'''v0.4.10'''
* [NDS] Fix drawing sprites with negative coordinates.
* [NDS] Update BlocksDS toolchain.
* Add support for <code>system/expansion</code> commands 0x00 and 0x02.
* Update <code>file</code> device implementation.
* Update bundled programs.
'''v0.4.9'''
*Actually add support for placing the "uxn" folder alongside the .3dsx/.nds file.
'''v0.4.8'''
* NDS: Update to BlocksDS 0.11.3.
* NDS: Add support for proper NitroFS filesystems; place "boot.rom" in the root of a NitroFS filesystem.
* Add support for placing the "uxn" folder alongside the .3dsx/.nds file.
'''v0.4.7'''
* [NDS] Improvements to file I/O.
* [NDS] Optimize 1-bit PPU drawing.
* [NDS] Update to BlocksDS 0.11.0.
* Implement division by zero and system device changes in the Uxn/Varvara specification.
'''v0.4.6'''
* [NDS] Improvements to file I/O and startup speed.
* [NDS] Reduce binary size by 2%.
* [NDS] Update to BlocksDS 0.9.1.
* The 3DS port is unchanged from 0.4.5.
'''v0.4.5'''
* [NDS] Lower APU sample rate and minor APU optimizations to improve sound playback stability.
* [NDS] Update to BlocksDS 0.8.1+git.
* Implement audio detunes.
* Implement full sprite flipping.
'''v0.4.4'''
* [NDS] Update to BlocksDS 0.8.
* Implement breaking screen drawing behaviour change.
'''v0.4.3'''
* [3DS] Update to libctru 2.2.2.
* [3DS] Optimize and fix bugs in the screen device implementation.
* No changes to the NDS version.
'''v0.4.2'''
* [3DS] Major screen drawing optimizations.
* [NDS] Fixed drawing vertically-flipped tiles on the bottom edge of the screen.
* [NDS] Fixed palette changes not being queued until frame change.
* Added key repeat emulation for physical button presses.
* Vertical drawing synchronization is no longer applied if a frame took longer than 1 VBlank to process.
'''v0.4.1a'''
*Add support from loading "boot.rom" from a relative path.
*Fix controller device implementation to more closely match uxn/Varvara.
*[NDS] Minor audio fixes.
'''v0.4.0'''
*New features:
**[3DS] Native 3DS port! Unlike the old uxn3ds, this one should have feature parity with the NDS port, in particular including a touch keyboard. As with uxn3ds, a 320x240 resolution screen is provided over 256x192, and the 3D slider can be used to observe the background and foreground layers separately.
**[NDS] New keyboard implementation - providing all keys exposed by the official Varvara implementation, as well as improving modifier support.
*Improvements/Bug fixes:
**Fix "datetime" device implementation.
**[NDS] Minor optimizations to screen "fill mode".
**Moved the "reset" button to use a touch button instead.
'''v0.1.1-3ds (proof of concept)'''
'''v0.1.1-3ds (proof of concept)'''
* CPU core update (incl. performance improvements)
* CPU core update (incl. performance improvements).


==External links==
==External links==
* GitHub - https://github.com/asiekierka/uxnds
* GitHub - https://github.com/asiekierka/uxnds
* Reddit - https://www.reddit.com/r/3dshacks/comments/nhj5xa/uxn_retrostyle_fantasy_computer_ported_to_ds
* Reddit - https://www.reddit.com/r/3dshacks/comments/nhj5xa/uxn_retrostyle_fantasy_computer_ported_to_ds
[[Category:3DS homebrew emulators]]
[[Category:Homebrew computer emulators on 3DS]]

Latest revision as of 04:29, 28 July 2024

uxnds 3DS
Uxn3ds2.png
General
Authorasiekierka
TypeComputer
Version0.5.2
LicenseMIT License
Last Updated2024/07/27
Links
Download
Website
Source

unxds is a port of the Unx virtual machine to the 3DS. Uxn is a portable 8-bit virtual computer inspired by forth-machines, capable of running simple tools and games programmable in its own assembly language.

This emulator allows you run to your uxn projects on the 3DS, it can also be used for developers who want to learn how to program little 8-bit things.

Installation

There is one binary provided: uxnds.3dsx.

By default, uxnds will run /uxn/boot.rom or /uxn/launcher.rom. It also supports reading files from within /uxn.

Note: When using a real DS/DSi/3DS console, it is recommended to launch this program via nds-hb-menu - though, as it currently doesn't use argc/argv, it doesn't really change much.

User guide

On start, a keyboard is presented on the bottom screen, and the uxn display is on the top screen.

You can use the system button in the lower-left corner to reset the uxn virtual machine.

Resources

Controls

L/R - Swap top and bottom screens

Touchscreen - Mouse input

Screenshots

uxn3ds3.png uxn3ds4.png

Media

Noodle - Magic Brush (Devine Lu Linvega)

Compatibility

Works on DS, DSi and 3DS.

Changelog

v0.5.2

  • [NDS] Updated to BlocksDS 1.3.1.

v0.5.1

  • [3DS] Fix crash on start.

v0.5.0

  • Ported the ARM assembly CPU core from uxngba.
    • Speed benefits of +20-40% can be observed!
    • Some CPU core bugs have also been fixed in the process, as tested with opctest.
    • Relative to the core above, additional minor optimizations have been done for ARMv5/ARMv6 CPUs.
  • [NDS] The debug build of uxnds will now prompt before exiting. This allows more convenient execution of CLI applications.
  • [NDS] Updated to BlocksDS 1.3.0.
  • Note that the new CPU core is not guaranteed to be bug-free; feel free to revert to 0.4.10 if you run into any issues.

v0.4.10

  • [NDS] Fix drawing sprites with negative coordinates.
  • [NDS] Update BlocksDS toolchain.
  • Add support for system/expansion commands 0x00 and 0x02.
  • Update file device implementation.
  • Update bundled programs.

v0.4.9

  • Actually add support for placing the "uxn" folder alongside the .3dsx/.nds file.

v0.4.8

  • NDS: Update to BlocksDS 0.11.3.
  • NDS: Add support for proper NitroFS filesystems; place "boot.rom" in the root of a NitroFS filesystem.
  • Add support for placing the "uxn" folder alongside the .3dsx/.nds file.

v0.4.7

  • [NDS] Improvements to file I/O.
  • [NDS] Optimize 1-bit PPU drawing.
  • [NDS] Update to BlocksDS 0.11.0.
  • Implement division by zero and system device changes in the Uxn/Varvara specification.

v0.4.6

  • [NDS] Improvements to file I/O and startup speed.
  • [NDS] Reduce binary size by 2%.
  • [NDS] Update to BlocksDS 0.9.1.
  • The 3DS port is unchanged from 0.4.5.

v0.4.5

  • [NDS] Lower APU sample rate and minor APU optimizations to improve sound playback stability.
  • [NDS] Update to BlocksDS 0.8.1+git.
  • Implement audio detunes.
  • Implement full sprite flipping.

v0.4.4

  • [NDS] Update to BlocksDS 0.8.
  • Implement breaking screen drawing behaviour change.

v0.4.3

  • [3DS] Update to libctru 2.2.2.
  • [3DS] Optimize and fix bugs in the screen device implementation.
  • No changes to the NDS version.

v0.4.2

  • [3DS] Major screen drawing optimizations.
  • [NDS] Fixed drawing vertically-flipped tiles on the bottom edge of the screen.
  • [NDS] Fixed palette changes not being queued until frame change.
  • Added key repeat emulation for physical button presses.
  • Vertical drawing synchronization is no longer applied if a frame took longer than 1 VBlank to process.

v0.4.1a

  • Add support from loading "boot.rom" from a relative path.
  • Fix controller device implementation to more closely match uxn/Varvara.
  • [NDS] Minor audio fixes.

v0.4.0

  • New features:
    • [3DS] Native 3DS port! Unlike the old uxn3ds, this one should have feature parity with the NDS port, in particular including a touch keyboard. As with uxn3ds, a 320x240 resolution screen is provided over 256x192, and the 3D slider can be used to observe the background and foreground layers separately.
    • [NDS] New keyboard implementation - providing all keys exposed by the official Varvara implementation, as well as improving modifier support.
  • Improvements/Bug fixes:
    • Fix "datetime" device implementation.
    • [NDS] Minor optimizations to screen "fill mode".
    • Moved the "reset" button to use a touch button instead.

v0.1.1-3ds (proof of concept)

  • CPU core update (incl. performance improvements).

External links

Advertising: