2021-04-16 00:58:57 +01:00
|
|
|
# Rust for the Game Boy Advance
|
2021-03-06 17:58:59 +00:00
|
|
|
|
2021-07-05 23:41:00 +01:00
|
|
|
![AGB logo](.github/logo.png)
|
|
|
|
|
2021-06-03 18:55:42 +01:00
|
|
|
This is a library for making games on the Game Boy Advance using the Rust
|
|
|
|
programming language. It attempts to be a high level abstraction over the
|
|
|
|
internal workings of the Game Boy Advance whilst still being high performance
|
|
|
|
and memory efficient.
|
|
|
|
|
|
|
|
The documentation for the latest release can be found on
|
|
|
|
[docs.rs](https://docs.rs/agb/latest/agb/). Note that this repository does not
|
2021-07-06 22:09:33 +01:00
|
|
|
necessarily contain the latest release, but in development versions. Further work
|
2021-06-03 18:55:42 +01:00
|
|
|
is needed to improve the documentation.
|
2021-03-06 17:58:59 +00:00
|
|
|
|
|
|
|
|
2021-04-11 16:56:05 +01:00
|
|
|
## Build Requirements
|
2021-03-06 17:58:59 +00:00
|
|
|
|
2021-05-23 02:35:39 +01:00
|
|
|
* Recent rustup, see [the rust website](https://www.rust-lang.org/tools/install)
|
|
|
|
for instructions for your operating system.
|
|
|
|
* You can update rustup with `rustup update`, or using your package manager
|
|
|
|
if you obtained rustup in this way.
|
2021-04-10 18:32:47 +01:00
|
|
|
* arm eabi binutils
|
2021-04-15 22:16:49 +01:00
|
|
|
* Debian and derivatives: `sudo apt install binutils-arm-none-eabi`
|
|
|
|
* Arch Linux and derivatives: `pacman -S arm-none-eabi-binutils`
|
2021-05-23 02:35:39 +01:00
|
|
|
* Windows can apparently use the [GNU Arm Embedded
|
|
|
|
Toolchain](https://developer.arm.com/tools-and-software/open-source-software/developer-tools/gnu-toolchain/gnu-rm/downloads).
|
|
|
|
Make sure to select "Add path to environment variable" during the install.
|
|
|
|
* This process has only been tested on Ubuntu and Arch Linux.
|
2021-03-06 17:58:59 +00:00
|
|
|
|
2021-04-11 16:56:05 +01:00
|
|
|
## Test Requirements
|
|
|
|
|
2021-08-01 21:13:55 +01:00
|
|
|
* libelf and cmake
|
|
|
|
* Debian and derivatives: `sudo apt install libelf-dev cmake`
|
|
|
|
* Arch Linux and derivatives: `pacman -S libelf cmake`
|
2021-04-19 22:23:22 +01:00
|
|
|
* mgba-test-runner
|
|
|
|
* Run `cargo install --path mgba-test-runner` inside this directory
|
2021-04-11 16:56:05 +01:00
|
|
|
|
|
|
|
## Real Hardware Build
|
|
|
|
|
|
|
|
* Need gbafix, rust implementation can be installed with `cargo install gbafix`.
|
|
|
|
* On compiled elf file, additionally need to
|
|
|
|
```bash
|
|
|
|
arm-none-eabi-objcopy -O binary {input-elf} {output-gba}
|
|
|
|
gbafix {output-gba}
|
|
|
|
```
|
|
|
|
|
2021-03-08 00:00:43 +00:00
|
|
|
## Stability
|
|
|
|
|
|
|
|
0% stable, I have no problems making drastic changes in the API in order to make
|
|
|
|
something nice to work with.
|