Go to file
2021-05-01 18:38:34 -06:00
.cargo remove proc macro usage and finish out the mmio (#125) 2021-04-08 23:57:30 -06:00
.github/workflows remove proc macro usage and finish out the mmio (#125) 2021-04-08 23:57:30 -06:00
examples fix wrapping math errors. Part of https://github.com/rust-console/gba/issues/129 2021-04-11 18:00:18 -06:00
src palettes and oam (#137) 2021-04-16 15:01:38 -06:00
.gitignore Implement a sync API for working with global mutable state. (#107) 2021-02-21 16:57:26 -07:00
build.rs Simplify build process (#106) 2021-02-20 11:49:40 -07:00
Cargo.toml dumb. 2021-04-19 11:21:37 -06:00
init.sh Fixed dead link + convenience additions 2018-12-13 14:31:11 +01:00
LICENSE-APACHE.md move to a tri-license (adds Zlib and MIT options) (#116) 2021-03-01 08:36:39 -07:00
LICENSE-MIT.md move to a tri-license (adds Zlib and MIT options) (#116) 2021-03-01 08:36:39 -07:00
LICENSE-ZLIB.md move to a tri-license (adds Zlib and MIT options) (#116) 2021-03-01 08:36:39 -07:00
linker.ld Added .iwram section (#118) 2021-02-28 12:09:49 -07:00
make_example.sh Implement a sync API for working with global mutable state. (#107) 2021-02-21 16:57:26 -07:00
Makefile.toml Simplify build process (#106) 2021-02-20 11:49:40 -07:00
README.md Update README.md 2021-04-19 11:30:20 -06:00
rust-toolchain.toml add rust toolchain file, Closes https://github.com/rust-console/gba/issues/139 2021-05-01 18:38:34 -06:00
rustfmt.toml Fix rustfmt to get things a little more compact 2019-02-12 10:00:16 -07:00

License:Zlib License:Apache2 License:MIT

ci crates.io docs.rs

  • Stability:None

gba

A crate to make GBA programming easy.

Currently we don't have as much documentation as we'd like. If you check out the awesome-gbadev repository they have many resources, though most are oriented towards C.

System Setup

There's a few extra things to install that you just need to do once per system.

Building for the GBA requires Nightly rust, and also uses the build-std feature, so you'll need the rust source available.

rustup install nightly
rustup +nightly component add rust-src

You'll also need the ARM binutils so that you can have the assembler and linker for the ARMv4T architecture. The way to get them varies by platform:

  • Ubuntu and other debian-like linux distros will usually have them in the package manager.
    sudo apt-get install binutils-arm-none-eabi
    
  • With OSX you can get them via homebrew.
    brew install --cask gcc-arm-embedded
    
  • On Windows you can get the installer from ARM's website and run that.
    • Download the GNU Arm Embedded Toolchain
    • When installing the toolchain, make sure to select "Add path to environment variable" during install.
    • You'll have to restart any open command prompts after you so run the installer so that they see the new PATH value.

Finally, rustc itself is only able to make ELF format files. These can be run in emulators, but aren't able to be played on actual hardware. You'll need to convert the ELF file into a GBA rom. There's a cargo-make file in this repository to do this, and it relies on a tool called gbafix to assign the right header data to the ROM when packing it.

cargo install cargo-make
cargo install gbafix

Project Setup

To build a GBA project, you'll want to copy the .cargo/config.toml file from this repo into your own project.

Then use one of the examples as a guide to get started.

When you build your project, cargo will put outputs in the target/thumbv4t-none-eabi/ directory. This includes the debug/ and release/ sub-directories. Your binary will be in there, but it'll be in ELF format. You can run this directly in an emulator such as mGBA if you'd like.

When you're ready to convert your program into a "proper" GBA rom you'll need to run an objcopy to extract just the raw binary data:

arm-none-eabi-objcopy -O binary [RUST_BINARY_NAME] [ROM_NAME].gba

Then you'll need to patch the header data with gbafix

gbafix [ROM_NAME].gba

And you'll be all done!

Contribution

This crate is tri-licensed under Zlib / Apache-2.0 / MIT. Any contributions you submit must be licensed the same.