This repository hosts a few packages for use with the SEGA Mega Drive (Sega Genesis in North America).
At the moment, these packages only work with a fork of LLVM & Rust. To use them you will need to build both.
For convenience, this repository provides a two-stage Dockerized approach to building the contained code:
docker build -t rust-m68k:latest -f Dockerfile.toolchain .
. If the build runs out of memory, you can
tweak the number of parallel build processes using --build-arg NUM_JOBS=4
or lower if your system requires it.docker build -t rust-mega-drive .
to compile it.
It assumes that you built the toolchain Docker image as rust-m68k:latest
. To obtain the "megapong" example, run:
# Run the image with default command to build megapong
docker run -it -v $(pwd)/target:/target rust-mega-drive:latest
# Take back control over the target directory
sudo chown -R $USER:$USER target
Now, you will have a megapong.md
binary in the subfolder target/m68k-none-eabi/release/
!
This is a more in-depth approach to building a Motorola 68000 compatible Rust/LLVM toolchain. You can skip these instructions if you used Docker as the main build tool.
Checkout the llvm-12
branch from the
LLVM project fork.
Build the toolchain with cmake:
cd llvm-project
mkdir build
cd build
cmake -G Ninja "-DLLVM_USE_LINKER=lld" "-DCMAKE_BUILD_TYPE=Release" "-DLLVM_ENABLE_ASSERTIONS=ON" "-DLLVM_PARALLEL_LINK_JOBS=1" "-DLLVM_TARGETS_TO_BUILD=X86" "-DLLVM_EXPERIMENTAL_TARGETS_TO_BUILD=M68k" "-DLLVM_ENABLE_PROJECTS=clang;lld" ..
ninja -j16
(This step can take along time and a lot of memory if used with a lot of threads.)
build/bin
.Checkout the Rust fork (clone the m68k-linux branch).
Copy config.toml.example
to config.toml
and edit:
[build] target = ["x86_64-unknown-linux-gnu", "m68k-unknown-linux-gnu"
[target.x86_64-unknown-linux-gnu] llvm-config = "path/to/build/bin/llvm-config"
Build:
./x.py build --stage=2 rustc cargo
You should now have a Rust toolchain in build/x86_64-unknown-linux-gnu/stage2
.
Link the toolchain in rustup so it is easier to use:
rustup toolchain link m68k "path/to/build/x86_64-unknown-linux-gnu/stage2"
export MEGADRIVE_HOME=path/to/rust-mega-drive/share
export RUSTUP_TOOLCHAIN=m68k
export LLVM_CONFIG=path/to/llvm/build/bin/llvm-config
cargo build --release
cd tools/cargo-megadrive
cargo install --path=.
cd examples/megapong
cargo megadrive build
target/m68k-none-eabi/release/megapong.md
.This suite is distributed under the terms of the MIT license. The full license text can be read in LICENSE.