This repo is the main code repo for the GoLEm FPGA Firmware and its companion libraries and binaries.
This repo is a monorepo, containing multiple crates.
The main crate is GoLEm_firmware
, which is the actual firmware for GoLEm.
It is meant as a drop-in replacement for MiSTer.
This repo also contains the twin packages senior
and junior
, which are the client and server respectively.
They are meant to be used together to replace the MiSTer firmware into a client/server architecture to help debug and develop cores and firmware features that don't require user interface.
Basically, running junior
on the DE10-Nano, it starts a webserver and does not provide an interactive interface.
The webserver provides a full REST API to interact with the FPGA, and the senior
client can be used as a client CLI to interact with it (though not needed).
For more details, see the junior
and senior
respective READMEs.
GoLEm wants to be a replacement for the MiSTer Firmware, achieving the same emulation capabilities, but with a better codebase (more maintainable) and an easier, user-focused interface.
From MiSTer's wiki:
MiSTer is an open project that aims to recreate various classic computers, game consoles and arcade machines, using modern hardware. It allows software and game images to run as they would on original hardware, using peripherals such as mice, keyboards, joysticks and other game controllers.
The MiSTer code is currently coded in legacy C and C++. It is hard to maintain, hard to build, and hard to contribute to.
GoLEm is written in easier-to-maintain (but still Open Source) Rust. The design of the application has been made from top down to enable contributions and maintenance. It is easier to read this code.
This is also an opportunity to improve the user experience greatly. For example,
Try it, get up to speed with the MiSTer project itself, and get ready to contribute when the time comes.
For the purposes of getting google to crawl the wiki, here's a link to the (not for humans) crawlable wiki
If you're a human looking for the wiki, that's here
There are currently two parts to this repo; a Rust library that is then linked with the C++ code.
The current structure is still in flux, but essentially the rust
code is in the src
directory, while the C++ code is in the root.
C++ dependencies are located in the lib/
folder, and the support/
folder contains various code necessary to run the cores.
To build the rust
library portion of this code, you'll need to install the rust
toolchain.
The easiest way to do this is to use rustup
.
Instructions can be found here.
The easiest way to build the MiSTer
binary is to use the Docker container provided by misterkun
here.
To build the DE10 target executable, run the following command:
cargo build --lib --target=armv7-unknown-linux-gnueabihf --no-default-features --features=de10 --release
docker run -it --rm -v $PWD:/mister misterkun/toolchain make BASE=arm-linux-gnueabihf
If everything goes well, you should have a GoLEm_firmware
file in the root directory of this repo.
Simply copy that binary to your device and execute it.
The following commands can help:
ssh root@$MISTER_IP 'killall MiSTer' # Make sure MiSTer is not running
scp *_firmware root@$MISTER_IP:/media/fat/ # Copy the binary to the device
ssh root@$MISTER_IP 'sync; PATH=/media/fat:$PATH; GoLEm_firmware' # Restart the firmware
There is a Desktop version of this (that does not support Cores), which can be ran locally in debug mode with:
cargo run
This version should help develop some features that don't require an FPGA (like menus and configs).
Tests can be run with cargo test
as you would.
This repo is not the main fork of the MiSTer firmware. If you want to contribute to MiSTer itself, please go to the MiSTer repo.
You can help a lot by testing this firmware and report bugs.
To contribute, please fork this repo, make your changes, and submit a PR. Most PRs should be approved right away, but some may require discussion.
Make sure you follow the Rust Code of Conduct when contributing. We use the Rust CoC currently because it is the most complete and well thought out CoC we could find. We might fork it locally in the future.
Thank you for understanding.