Commit graph

316 commits

Author SHA1 Message Date
Matthew Berry
026e8390ee don't render disabled background layers 2021-01-02 00:46:55 -08:00
Matthew Berry
452bd0c75a handle background priority mode 0 2021-01-01 23:04:16 -08:00
Matthew Berry
f1f59c3ce6 abstract bg reg reads/writes, clear scanline before render, decouple scanline row 2020-12-31 00:12:15 -08:00
Matthew Berry
8e221d221e store framebuffer as Slice(UInt16) and batch writes, fix mode 5 bg color 2020-12-30 23:22:18 -08:00
Matthew Berry
f8914d4be3 move dma/timer puts to logs 2020-12-30 00:03:21 -08:00
Matthew Berry
468631666c ignore writes to apu 0xA8..0xAF since they're unmapped 2020-12-29 22:52:51 -08:00
Matthew Berry
bf156dc18d proper dma sound sound control (volume, enable, balance) 2020-12-28 08:15:36 -08:00
Matthew Berry
df4ce8540e dma audio is actually playing the correct sounds! 2020-12-27 20:35:34 -08:00
Matthew Berry
ddb0d1f423 a rough start to fifo audio 2020-12-26 10:17:47 -08:00
Matthew Berry
b6e5c54da4 timer interrupts 2020-12-13 12:41:45 -08:00
Matthew Berry
1aab2cc5a8 allow writes to dma apu channels 2020-12-13 12:38:16 -08:00
Matthew Berry
4b6563773c fixed ppu interrupt flags 2020-12-13 12:37:07 -08:00
Matthew Berry
0c39869653 removed unused variables 2020-12-13 12:35:52 -08:00
Matthew Berry
106a14b5a6 very basic dma 2020-12-13 12:35:25 -08:00
Matthew Berry
9c2d135293 updated channel3 from cgb audio to gba audio 2020-12-11 23:41:44 -08:00
Matthew Berry
18eabafad1 change to_u8 to to_u8! to avoid bounds checks at runtime 2020-12-06 16:07:44 -08:00
Matthew Berry
524eeabd11 basic timer implementation, enough to make tonc tmr_demo mostly work
todo: proper cascade enable/disable
todo: interrupts from timers
2020-12-06 16:02:53 -08:00
Matthew Berry
50dc14eddb cleanup mmio range checks a little bit.. 2020-12-05 17:26:14 -08:00
Matthew Berry
9f65505731 handle volume and channel enable properly for gba 2020-12-05 14:39:37 -08:00
Matthew Berry
ac8319b19c basic apu support (copy from CryBoy w/ slight modification), scheduler short-circuit, scheduler clear 2020-12-05 12:25:55 -08:00
Matthew Berry
70913a4ee8 thumb alu fix neg handling 2020-12-01 00:10:23 -08:00
Matthew Berry
a79afb3817 add halting 2020-11-30 08:44:37 -08:00
Matthew Berry
042b76d910 passing destoer isr test, booting kirby, failing tonc irq_demo
- handle exception returns after alu
- proper spsr banking
- fill pipeline before interrupts
- align r15 before each pipeline fill
2020-11-28 00:07:21 -08:00
Matthew Berry
b6346536d5 added support for a basic cli debugger 2020-11-27 00:24:33 -08:00
Matthew Berry
e48c186068 properly handle if ack 2020-11-26 12:18:36 -08:00
Matthew Berry
327904b6d6 fix oam writes, fix print_state when -Dtrace is not provided 2020-11-23 08:16:33 -08:00
Matthew Berry
c190adfca2 arm ldm/stm handle empty list & base in list, pass all of gba-suite 2020-11-22 18:02:59 -08:00
Matthew Berry
c51ffe83ae account for prefetch on str r15, write back when str && rd==rn 2020-11-22 15:47:51 -08:00
Matthew Berry
33e3cc8e09 account for prefetch on str r15, write back when str && rd==rn 2020-11-22 12:03:45 -08:00
Matthew Berry
902fb9c9ef fix negative / zero flags on long multiply 2020-11-22 12:03:14 -08:00
Matthew Berry
768457178f psr transfer - properly generate mask (gbatek is right, arm manual is wrong) 2020-11-22 12:02:10 -08:00
Matthew Berry
357ca9f0d4 align print_state with mgba's trace, move trace flag check to caller 2020-11-22 01:10:33 -08:00
Matthew Berry
a802bf0e56 properly handle carry flag in data processing, alu operations, etc
passing gba-suite arm 228 where I was failing before, now stuck on 356
2020-11-21 12:02:22 -08:00
Matthew Berry
04a70527ec handle thumb stm w/ rb in list, pass gba-suite thumb 2020-11-17 23:15:12 -08:00
Matthew Berry
37ef5ab719 basic irq impl, loads HAL screen in Kirby, crashes on tonc's irq_demo 2020-11-17 00:23:28 -08:00
Matthew Berry
b5ba760993 add some gifs/pictures to the readme 2020-11-16 22:32:57 -08:00
Matthew Berry
3b7e0448c9 run through normatt's bios successfully, print unmapped mmio/ppu read/writes to stdout
simply comment out the default PC value to run the bios. I've left it
disabled because that's not the source of my inaccuracy, and it's
annoying to look at every time :p
2020-11-15 23:32:06 -08:00
Matthew Berry
5c6ec3e6f2 added read/write of waitcnt and a bunch of ppu regs 2020-11-14 09:47:08 -08:00
Matthew Berry
7401788dab update some opengl docs in display 2020-11-13 00:03:28 -08:00
Matthew Berry
e7849616ab mode 0 hfip / vflip, 100% done with tonc brin_demo 2020-11-12 00:09:48 -08:00
Matthew Berry
7086673a78 properly get screen entity index when size isn't 32x32 2020-11-11 00:00:23 -08:00
Matthew Berry
b6ddfcf424 move from sdl textures to opengl, add byuu color correction shaders :D 2020-11-10 00:00:06 -08:00
Matthew Berry
717965c400 sraw read/write, abort on unmapped access rather than raise 2020-11-09 23:08:14 -08:00
Matthew Berry
fdbfe805bd writes to bgofs regs 2020-11-08 22:34:57 -08:00
Matthew Berry
a5b0add637 mode 0 start: rendering 32x32 bg0 2020-11-08 01:45:28 -08:00
Matthew Berry
502df9b634 cartridge oob data, wait states 1/2 2020-11-07 19:40:29 -08:00
Matthew Berry
8e21578553 scanline rendering modes 3-5 2020-11-07 00:20:33 -08:00
Matthew Berry
86d21e5f43 ppu mode 5 because why not 2020-11-06 00:39:11 -08:00
Matthew Berry
b94ea60e6f psr transfer logic improvement, fix spsr load, remove default regs 2020-11-05 22:26:53 -08:00
Matthew Berry
8ec8645ca2 thumb laod address fix word bits selection 2020-11-04 22:32:37 -08:00