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:
- A Dockerfile.toolchain for a Motorola 68000-compatible Rust compiler. You can build this using
the command
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. - A Dockerfile to compile the megapong application. Use
docker build -t rust-mega-drive .
to compile it. It assumes that you built the toolchain Docker image asrust-m68k:latest
. To obtain the "megapong" example, run:Now, you will have a# 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
megapong.md
binary in the subfoldertarget/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:
- Generate the project with the M68k backend enabled:
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" ..
- Build:
(This step can take along time and a lot of memory if used with a lot of threads.)
ninja -j16
- You should now have all of the LLVM binaries in
build/bin
.
- Generate the project with the M68k backend enabled:
-
Checkout the Rust fork (clone the m68k-linux branch).
-
Copy
config.toml.example
toconfig.toml
and edit:- Set
[build] target = ["x86_64-unknown-linux-gnu", "m68k-unknown-linux-gnu"
- Set
[target.x86_64-unknown-linux-gnu] llvm-config = "path/to/build/bin/llvm-config"
- Set
-
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"
- Set the required environment variables:
export MEGADRIVE_HOME=path/to/rust-mega-drive/share export RUSTUP_TOOLCHAIN=m68k export LLVM_CONFIG=path/to/llvm/build/bin/llvm-config
- Build the tools & libraries:
cargo build --release
- Install the cargo tool:
cd tools/cargo-megadrive cargo install --path=.
- Build the example Mega Drive image:
cd examples/megapong cargo megadrive build
- You should now have an example megadrive image in
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.