Nuked-MD-FPGA
Nuked-OPN2
Nuked-MD-FPGA | Nuked-OPN2 | |
---|---|---|
6 | 2 | |
284 | 210 | |
- | - | |
9.1 | 3.4 | |
8 months ago | 10 months ago | |
Verilog | C | |
GNU General Public License v3.0 only | GNU Lesser General Public License v3.0 only |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Nuked-MD-FPGA
-
FPGAs and the Renaissance of Retro Hardware
The reality is that the vast majority of these FPGA-based clones don't actually perfectly emulate the logic. They're using the same reverse engineering techniques the traditional emulator developers used and sometimes even the same community documentation. The results are often quite good, but they're making a new implementation that matches the observed behavior of the original system to the best of their abilities.
Now there are some exceptions. Nuked MD FPGA[0] is a recent example of an FPGA recreation that is a fairly direct translation of the original logic using silicon die analysis. In this case, the logic is basically identical, but as you guessed the physical layout is different. Generally speaking, you write FPGA "gateware" in a language like Verilog or VHDL. These don't intrinsically have any information about the physical layout of the logic which is handled by the toolchain instead. As wmf says, this is generally not a problem most of the time. For synchronous logic, either the total propagation delay is small enough for a single cycle or it isn't. The toolchain will estimate this delay and report whether you met timing or not for the configured clockspeed.
Not everything you can do in silicon translates well to FPGAs (both clock edges is also generally not well supported for instance), but for the most part these things are easy enough to work around.
[0] https://github.com/nukeykt/Nuked-MD-FPGA
-
Nuked-MD-FPGA – accurate Sega Genesis re-implementation based on decapped chips
Kinda, sorta? This is like saying "a computer is not enough, you need a binary." What's here is the source code in Verilog. This produces a netlist (set of gates) which is synthesized into an actual bitstream (proprietary gate configuration file) for a specific FPGA hosted on a specific board.
In this case, the project isn't very documented but it looks like fairly generic Verilog without a lot of vendor specific extensions. So, what you need is a Verilog toolchain which can synthesize the source code into a netlist, and then into a bitstream, and the right set of extra code to target an actual physical piece of hardware.
Right now, it looks like the only board support that's checked into the repository is for the Icarus Verilog simulation environment: https://github.com/nukeykt/Nuked-MD-FPGA/tree/main/icarus .
But, the overall setup looks pretty simple and generic, so it should (hopefully) be possible to synthesize to your board of choice by reimplementing run.v and memstubs.v towards an actual hardware configuration.
- Nuked-MD-FPGA -- cycle-accurate Sega Genesis/MD hardware implementation based on reverse-engineering console's chips
Nuked-OPN2
- Emulating OPN2 with samples
-
Trying To Recreate The Hard FM Pad From Door Into Summer, any tips? Tried using deflemask and dexed but no luck
There's a chipset emulator available at https://github.com/nukeykt/Nuked-OPN2 But you'll need to code a UI for it
What are some alternatives?
MegaDrivePlusPlus - Universal Region mod, 50/60 Hz switch and In-Game-Reset (IGR) for Sega Mega Drive (AKA Genesis)
asmotor - Powerful macro (cross) assembler package for several CPUs
Genesis_MiSTer - Sega Genesis for MiSTer
mame - MAME
analogue-pocket-utils - Collection of IP and information on how to develop for openFPGA and Analogue Pocket
Provenance - iOS & tvOS multi-emulator frontend, supporting various Atari, Bandai, NEC, Nintendo, Sega, SNK and Sony console systems… Get Started: https://wiki.provenance-emu.com |
moa - An emulator for various m68k and z80 based computers, written in Rust. Currently it has support for the Sega Genesis, TRS-80, and Computie (my own project), with Macintosh support in the works
megadev - A Sega Mega CD development framework in C and 68k asm
SGDK - SGDK - A free and open development kit for the Sega Mega Drive
OPNMIDI-Player-Java - Simple MIDI-player for Android based on libOPNMIDI library
independence-day - Gno.land airdrop scripts.
Nuked-MD - Cycle accurate Mega Drive emulator