2022-10-21 08:12:17 +00:00
|
|
|
# ZBA (working title)
|
|
|
|
An in-progress Gameboy Advance Emulator written in Zig ⚡!
|
|
|
|
|
|
|
|
## Tests
|
2022-10-21 08:12:39 +00:00
|
|
|
- [ ] [jsmolka GBA Test Collection](https://github.com/jsmolka/gba-tests)
|
2022-10-21 08:12:34 +00:00
|
|
|
- [x] `arm.gba` and `thumb.gba`
|
|
|
|
- [x] `flash64.gba`, `flash128.gba`, `none.gba`, and `sram.gba`
|
|
|
|
- [x] `hello.gba`, `shades.gba`, and `stripes.gba`
|
|
|
|
- [x] `memory.gba`
|
2022-10-21 08:12:46 +00:00
|
|
|
- [x] `bios.gba`
|
2022-10-21 08:12:34 +00:00
|
|
|
- [ ] `nes.gba`
|
2022-10-21 08:12:39 +00:00
|
|
|
- [ ] [DenSinH's GBA ROMs](https://github.com/DenSinH/GBARoms)
|
|
|
|
- [x] `eeprom-test`
|
2022-10-21 08:12:46 +00:00
|
|
|
- [x] `flash-test`
|
2022-10-21 08:12:39 +00:00
|
|
|
- [x] `midikey2freq`
|
|
|
|
- [ ] `swi-tests-random`
|
|
|
|
- [ ] [destoer's GBA Tests](https://github.com/destoer/gba_tests)
|
2022-10-21 08:12:40 +00:00
|
|
|
- [x] `cond_invalid.gba`
|
2022-10-21 08:12:39 +00:00
|
|
|
- [x] `dma_priority.gba`
|
|
|
|
- [x] `hello_world.gba`
|
|
|
|
- [x] `if_ack.gba`
|
|
|
|
- [ ] `line_timing.gba`
|
|
|
|
- [ ] `lyc_midline.gba`
|
|
|
|
- [ ] `window_midframe.gba`
|
2022-10-21 08:12:46 +00:00
|
|
|
- [ ] [ladystarbreeze's GBA Test Collection](https://github.com/ladystarbreeze/GBA-Test-Collection)
|
2022-10-21 08:12:39 +00:00
|
|
|
- [x] `retAddr.gba`
|
|
|
|
- [x] `helloWorld.gba`
|
|
|
|
- [ ] `helloAudio.gba`
|
2022-10-21 08:12:17 +00:00
|
|
|
- [x] [`armwrestler-gba-fixed.gba`](https://github.com/destoer/armwrestler-gba-fixed)
|
2022-10-21 08:12:34 +00:00
|
|
|
- [x] [FuzzARM](https://github.com/DenSinH/FuzzARM)
|
2022-10-21 08:12:17 +00:00
|
|
|
|
|
|
|
## Resources
|
|
|
|
* [GBATEK](https://problemkaputt.de/gbatek.htm)
|
|
|
|
* [TONC](https://coranac.com/tonc/text/toc.htm)
|
|
|
|
* [ARM Architecture Reference Manual](https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/third-party/ddi0100e_arm_arm.pdf)
|
|
|
|
* [ARM7TDMI Data Sheet](https://www.dca.fee.unicamp.br/cursos/EA871/references/ARM/ARM7TDMIDataSheet.pdf)
|
|
|
|
|
|
|
|
## Compiling
|
2022-10-21 08:12:39 +00:00
|
|
|
Most recently built on Zig [0.10.0-dev.1933+5f2d0d414](https://github.com/ziglang/zig/tree/5f2d0d414)
|
2022-10-21 08:12:17 +00:00
|
|
|
|
|
|
|
### Dependencies
|
|
|
|
* [SDL.zig](https://github.com/MasterQ32/SDL.zig)
|
|
|
|
* [SDL2](https://www.libsdl.org/download-2.0.php)
|
|
|
|
* [zig-clap](https://github.com/Hejsil/zig-clap)
|
2022-10-21 08:12:31 +00:00
|
|
|
* [known-folders](https://github.com/ziglibs/known-folders)
|
2022-10-21 08:12:24 +00:00
|
|
|
* [`bitfields.zig`](https://github.com/FlorenceOS/Florence/blob/f6044db788d35d43d66c1d7e58ef1e3c79f10d6f/lib/util/bitfields.zig)
|
|
|
|
|
|
|
|
`bitfields.zig` from [FlorenceOS](https://github.com/FlorenceOS) is included under `lib/util/bitfield.zig`.
|
|
|
|
|
2022-10-21 08:12:31 +00:00
|
|
|
Use `git submodule update --init` from the project root to pull the git submodules `SDL.zig`, `zig-clap`, and `known-folders`
|
2022-10-21 08:12:24 +00:00
|
|
|
|
2022-10-21 08:12:31 +00:00
|
|
|
Be sure to provide SDL2 using:
|
|
|
|
* Linux: Your distro's package manager
|
|
|
|
* MacOS: ¯\\\_(ツ)_/¯
|
|
|
|
* Windows: [`vcpkg`](https://github.com/Microsoft/vcpkg) (install `sdl2:x64-windows`)
|
2022-10-21 08:12:24 +00:00
|
|
|
|
2022-10-21 08:12:31 +00:00
|
|
|
`SDL.zig` will provide a helpful compile error if the zig compiler is unable to find SDL2.
|
2022-10-21 08:12:24 +00:00
|
|
|
|
2022-10-21 08:12:31 +00:00
|
|
|
Once you've got all the dependencies, execute `zig build -Drelease-fast`. The executable is located at `zig-out/bin/`.
|
2022-10-21 08:12:17 +00:00
|
|
|
|
2022-10-21 08:12:24 +00:00
|
|
|
## Controls
|
|
|
|
Key | Button
|
|
|
|
--- | ---
|
|
|
|
<kbd>X</kbd> | A
|
|
|
|
<kbd>Z</kbd> | B
|
|
|
|
<kbd>A</kbd> | Left Shoulder
|
|
|
|
<kbd>S</kbd> | Right Shoulder
|
|
|
|
<kbd>Return</kbd> | Start
|
|
|
|
<kbd>RShift</kbd> | Select
|
|
|
|
Arrow Keys | D-Pad
|