Go to file
Lokathor 8efef6ebc5
No more old book stuff (#123)
* stop with the book, we should focus on the crate.

* Update README.md

* Update README.md
2021-04-05 18:11:42 -06:00
.cargo Simplify build process (#106) 2021-02-20 11:49:40 -07:00
.github/workflows prevent building the book 2021-02-23 00:16:37 -07:00
examples update to voladdress-0.4 (#120) 2021-03-31 20:22:42 -06:00
examples-bak Get all the code lined up 2019-02-14 19:39:34 -07:00
src update to voladdress-0.4 (#120) 2021-03-31 20:22:42 -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 No more old book stuff (#123) 2021-04-05 18:11:42 -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 No more old book stuff (#123) 2021-04-05 18:11:42 -06:00
rustfmt.toml Fix rustfmt to get things a little more compact 2019-02-12 10:00:16 -07:00
todo_check.bat fixed point stuff 2018-12-18 02:05:59 -07:00

License:Zlib License:Apache2 License:MIT

ci crates.io docs.rs

  • Built with cargo-make
  • 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.

First Time Setup

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

Contribution

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