Skip to content

NESTang is an FPGA Nintendo Entertainment System implemented with Sipeed Tang Primer 25K, Nano 20K and Primer 20K boards

License

Notifications You must be signed in to change notification settings

djjohnson13p/nestang

 
 

Repository files navigation

NESTang - NES for Sipeed Tang FPGA Boards

NESTang is an open source project to recreate the Nintendo Entertainment System (NES) with Sipeed Tang FPGA boards, including Sipeed Tang Primer 25K, Tang Nano 20K and Tang Primer 20K.

Main features,

  • 720p HDMI output with sound.
  • Cycle accurate gameplay quality has been achieved since the NES circuits have been almost entirely replicated.
  • Rom loading from MicroSD cards with an easy-to-use menu system, powered by a RISC-V softcore.
  • Extensive mapper support including MMC5, Namco and more.
  • NES/SNES controllers, or DS2 controllers.

If you haven't bought your board yet, Tang Primer 25K is probably the one to get, as it supports SNESTang better.

Getting the parts

You need either the Sipeed Tang Primer 25K or Tang Nano 20K FPGA board to run the latest NESTang.

Installation

A step-by-step instructions is available. Here are quick instructions for the more experienced,

  • Assemble the board and modules: result for the primer 25k, and nano 20k.
  • Download a NESTang release from github. The bitstream (nestang_*.fs) should be written to flash at address 0. The firmware (firmware.bin) should be written to 0x500000 (5MB). See this screenshot for how to do it.
  • Put your ROM files onto a MicroSD Card (exFAT or FAT32 file system). Insert the card, connect an HDMI monitor or TV, and enjoy your games.

Version 0.4 also supports tang primer 20k.

Development

If you want to generate the bitstream from source, see Build Instructions. Make sure you use the Gowin IDE version 1.9.9 commercial (requires a free license).

Usb_hid_host was development so NESTang could support USB gamepads. Follow the link if you want to use it for your FPGA projects. It supports keyboards and mice too.

Next steps

See NESTang changes.md.

Here are what I may work on when I get time. No promise though. Suggestions and pull requests are welcome!

  • Cheats support.
  • Saves and loads.

Special Thanks

nand2mario (nand2mario at outlook.com)

Since 2022.9

About

NESTang is an FPGA Nintendo Entertainment System implemented with Sipeed Tang Primer 25K, Nano 20K and Primer 20K boards

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • SystemVerilog 48.2%
  • Verilog 42.9%
  • C++ 5.3%
  • Python 2.1%
  • Tcl 0.7%
  • Assembly 0.3%
  • Other 0.5%