a1008738d2
chore: run zigfmt
2022-04-08 02:13:58 -03:00
bf7b533b3c
chore: stub more apu I/O addresses
2022-03-28 19:40:47 -03:00
04d54ec97a
chore: move DMA and Timers from io to bus
2022-03-15 08:25:26 -03:00
1fd80c1c23
feat: define APU registers
2022-03-15 08:09:07 -03:00
8e3f48837d
chore: organize io switch statements
2022-03-13 07:50:19 -03:00
017ec407f5
chore: don't panic on unknown bus and io writes/reads
...
This will lead to emulation bugs due to devices I've yet to implement but by
doing this a lot of games become playable "by default" such as Doom or
Kirby: Nightmare in Dream Land.
When implementing feature and/or debuggin make sure to set:
panic_on_und_bus and panic_on_und_io to true so that the emu crashes
on unknown reads/writes
2022-03-13 05:39:09 -03:00
4a76611fca
feat: implement Timers
2022-03-13 05:35:01 -03:00
f1df3d6615
chore: clean up io
2022-03-04 22:55:04 -04:00
ddb68a7952
feat: pass beeg yoshi
2022-02-28 18:24:24 -04:00
d6ef53fd67
feat: DMA Transfer MVP
2022-02-28 12:34:00 -06:00
ac0486be1b
chore(io): replace some bitfields with enums
2022-02-24 17:20:23 -06:00
441ebc38c7
fix: better emulate behaviour of IO reads
2022-02-24 17:20:20 -06:00
be2dfb379a
chore: document select unimplmented I/O registers
...
These registers are written to / read from Kirby: Nightmare in Dream Land
2022-02-22 17:14:30 -06:00
c2cf2d2965
feat: implement Hblank and Vcount Interrupts
...
Also implemented unique behaviour when writing to IF
2022-02-21 14:45:47 -06:00
c767e88e8d
chore: improve io.zig
2022-02-19 11:48:17 -05:00
3746cf6025
chore: don't panic on 32-bit I/O
2022-02-19 06:45:39 -04:00
f6c8d7ca07
chore: stub CPU HALTing
2022-02-17 00:27:34 -04:00
4018f3875b
chore: properly write to VOFS and HOFS in 32-bit bus
2022-02-16 23:23:41 -04:00
034f2e8d1d
feat: implement hofs and vofs on io bus
2022-02-16 04:29:04 -04:00
ce97a52868
feat: add support for multiple BGs in Mode 0
2022-02-16 03:27:06 -04:00
d2d4667f7b
feat: document mode 0
2022-02-16 03:05:19 -04:00
e5a76a3c02
chore: give DISPCNT DISPSTAT and VCOUNT to PPU struct
2022-02-13 04:28:15 -04:00
31fa06ac4a
chore: give io read/write functions access to the entire Bus
2022-02-13 04:13:06 -04:00
ec25a9aae4
feat: implement BG Scrolling Registers
2022-02-13 04:04:10 -04:00
b238a3e8f3
feat: impelemnt BG0,1,2CNT and IF
2022-02-13 03:23:09 -04:00
2842345111
chore: remove unnecessary @as calls
2022-02-05 21:01:39 -04:00
428eff1468
Revert "fix: allow for 32-bit reads to KEYINPUT"
...
This reverts commit 3a51707280bcb35f3397c8a6da8441f95629bf07.
2022-02-05 14:52:49 -04:00
3a51707280
fix: allow for 32-bit reads to KEYINPUT
2022-02-05 13:47:05 -04:00
28c81f79ae
fix: no buttons are pressed by default
2022-02-01 20:52:01 -04:00
b0332e6eb8
chore: stub KeyInput I/O register
2022-01-30 02:38:29 -04:00
6c008ce950
fix: allow 32-bit writes to DISPCNT
2022-01-30 01:42:54 -04:00
1c173eb4b8
chore(io): implement IE and IME
2022-01-12 02:19:26 -04:00
0f08ad05be
feat(bus): implement IWRAM and EWRAM
2022-01-10 07:59:21 -04:00
89a8fe403b
feat(bus): have VCOUNT be addressable on the bus
2022-01-10 03:35:28 -04:00
2467b94dbd
chore(io): rename some io bitfield fields
2022-01-10 02:13:25 -04:00
568c374131
chore: code cleanup
2022-01-07 20:00:42 -04:00
a407671de2
chore(io): alias @This() to Self in io.zig
2022-01-07 19:34:54 -04:00
c6123d8a6d
feat: implement PPU Timings in Scheduler
2022-01-05 21:18:33 -04:00
5ea888f68c
feat(bus): implement Palette RAM and DISPSTAT
2022-01-04 03:29:56 -06:00
c9f0e1632c
fix(io): fix DISPCNT is at wrong IO address
2022-01-03 17:49:15 -06:00
dee0e113d8
feat(cpu): implement skipBios method
2022-01-02 14:58:39 -06:00
1c42d1795a
feat(bus): add Io Struct
...
Also, add more information to all panic messages
2022-01-02 14:40:49 -06:00