Rekai Nyangadzayi Musuka
67f7c49270
fix: advance r15, even when the pipeline is reloaded from the scheduler
...
The PC would fall behind whenever an IRQ was called because the pipeline
was reloaded (+8 to PC), however that was never actually done by any code
Now, the PC is always incremented when the pipeline is reloaded
2022-09-17 20:38:10 -03:00
Rekai Nyangadzayi Musuka
55cc9c9a9e
chore: dump pipeline state on cpu panic
2022-09-17 20:38:10 -03:00
Rekai Nyangadzayi Musuka
7d00609d29
fix: reimpl THUMB.5 instructions
...
pipeline branch now passes arm.gba and thumb.gba again
(TODO: Stop rewriting my commits away)
2022-09-17 20:38:10 -03:00
Rekai Nyangadzayi Musuka
fcd06c7a3e
fix: impl workaround for stage2 miscompilation
2022-09-17 20:38:10 -03:00
Rekai Nyangadzayi Musuka
92970622c2
chore: instantly refill the pipeline on flush
...
I believe this to be necessary in order to get hardware interrupts
working.
thumb.gba test 108 fails but I'm committing anyways (despite the
regression) because this is kind of rebase/merge hell and I have
something that at least sort of works rn
2022-09-17 20:38:10 -03:00
Rekai Nyangadzayi Musuka
a56e4a8203
fix: reimpl handleInterrupt code
2022-09-17 20:38:10 -03:00
Rekai Nyangadzayi Musuka
17315e0c88
feat: implement basic pipeline
...
passes arm.gba, thumb.gb and armwrestler, fails in actual games
TODO: run FuzzARM debug specific titles
2022-09-17 20:38:10 -03:00
Rekai Nyangadzayi Musuka
730b6813de
feat: resolve off-by-{word, halfword} errors when printing debug info
2022-09-17 20:38:10 -03:00
Rekai Nyangadzayi Musuka
7bc35705dd
feat: reimplement cpu logging
2022-09-17 20:38:10 -03:00
Rekai Nyangadzayi Musuka
d3efa432fa
Merge pull request 'Implement RTC' ( #1 ) from rtc into main
...
Reviewed-on: #1
2022-09-17 23:36:34 +00:00
Rekai Nyangadzayi Musuka
50adb5fbac
feat: add option to force-enable RTC
2022-09-17 20:27:17 -03:00
Rekai Nyangadzayi Musuka
19d78b9292
feat: auto-detect RTC in commercial ROMS
2022-09-17 20:23:49 -03:00
Rekai Nyangadzayi Musuka
a2e702c366
fix: account for lateness in RTC scheduler event
2022-09-17 09:07:31 -03:00
Rekai Nyangadzayi Musuka
12c138364d
fix: RTC day is 6 bits wide, not 3
2022-09-16 10:59:41 -03:00
Rekai Nyangadzayi Musuka
7783c11fac
feat: put RTC Sync on Scheduler
...
TODO: Database to see what games have what GPIO devices
2022-09-16 10:39:02 -03:00
Rekai Nyangadzayi Musuka
3fc3366c8a
chore: import datetime library + default time for RTC
2022-09-16 10:39:02 -03:00
Rekai Nyangadzayi Musuka
d6b182f245
fix: ignore RTC Time/DateTime writes
...
this falls in-line with better emulators
2022-09-16 10:39:02 -03:00
Rekai Nyangadzayi Musuka
3857c44e68
chore: use Clock.Writer for Command parsing, delete Clock.Command
2022-09-16 10:39:02 -03:00
Rekai Nyangadzayi Musuka
089c5fa025
feat: implement RTC Read/Writes
2022-09-16 10:39:02 -03:00
Rekai Nyangadzayi Musuka
c977f3f965
feat: implement force irqs for GPIO/RTC
2022-09-16 10:38:51 -03:00
Rekai Nyangadzayi Musuka
92417025e9
fix: properly resovle stack UAF
2022-09-16 02:10:41 -03:00
Rekai Nyangadzayi Musuka
1c52c0bf91
chore: shorten `orelse @panic` to `.?`
2022-09-16 02:10:41 -03:00
Rekai Nyangadzayi Musuka
617f7f4690
fix: update GpioData extern union
...
u4's are no longer supported in extern unions :\
2022-09-16 02:10:41 -03:00
Rekai Nyangadzayi Musuka
434a0dfac9
tmp: incomplete impl of GPIO + RTC
2022-09-16 02:10:41 -03:00
Rekai Nyangadzayi Musuka
4ec8dab460
chore: Guilty Gear X expects these I/O Registers
2022-09-14 11:38:26 -03:00
Rekai Nyangadzayi Musuka
59c9ff910e
feat: implement open bus for unmapped i/o
2022-09-12 23:18:29 -03:00
Rekai Nyangadzayi Musuka
0027d3f8a3
chore: comment open bus impl
2022-09-11 07:38:55 -03:00
Rekai Nyangadzayi Musuka
9f45888910
chore: update dependencies
2022-09-11 06:59:10 -03:00
Rekai Nyangadzayi Musuka
bf442d5a40
chore: Update README.md
2022-09-10 07:34:52 -03:00
Rekai Nyangadzayi Musuka
65cfc97f28
feat: reimplement audio sync
...
APU will now drop samples if the Audio Queue is already full, therefore
creating a "sped-up" effect when the emulator runs faster than 100%
2022-09-08 20:38:42 -03:00
Rekai Nyangadzayi Musuka
fa862f095a
chore: move arm/thumb lut idx functions
2022-09-06 23:58:24 -03:00
Rekai Nyangadzayi Musuka
f3c05b6fe6
chore: update dependencies
2022-09-05 22:52:07 -03:00
Rekai Nyangadzayi Musuka
3fb7f2f814
chore: better conform to zig idioms
2022-09-03 18:30:48 -03:00
Rekai Nyangadzayi Musuka
59669ba3a5
chore: rename arm7tdmi variables to just cpu
...
Less verbose, specifying arm7tdmi doesn't really do much when there's
no other CPU in the system
2022-09-03 17:56:37 -03:00
Rekai Nyangadzayi Musuka
6a798d2c9d
chore: allocate sprite array on heap
...
Each Sprite optional is 10 bytes meaning I'm allocating 1.28Kb on the
stack which isn't necessary.
2022-08-29 01:07:25 -05:00
Rekai Nyangadzayi Musuka
5f8c6833f4
chore: improve init/deinit methods
2022-08-29 01:07:25 -05:00
Rekai Nyangadzayi Musuka
aa52bb5917
chore: reorganize some code
2022-08-26 14:13:49 -05:00
Rekai Nyangadzayi Musuka
e57f918856
chore: pass the allocator as an argument more often
...
As of right now, I think the only cases where I shouldn't explicitly pass an allocator
are in read/write functions and deinits
2022-08-26 13:54:38 -05:00
Rekai Nyangadzayi Musuka
e5b7441740
fix: resolve use-afer-free in backup.zig
...
This worked fine on stage1, and works fine in debug in stage3.
However, stage3 ReleaseSafe would panic due to what I assume must
have been an undefined behaviour optimization.
While I'm happy that I was quickly made aware of the issue thanks to
the safety checks in ReleaseSafe I do wish that this issue showed itself
in Debug, since I *am* using the GPA
2022-08-26 13:04:09 -05:00
Rekai Nyangadzayi Musuka
2ab8769b7a
feat: Get ZBA working on Zig's new stage2/stage3 compiler
2022-08-21 12:28:31 -05:00
Rekai Nyangadzayi Musuka
3c3c0d32dd
chore: move window scale const to emu.zig
2022-08-08 11:03:23 +02:00
Rekai Nyangadzayi Musuka
739db99c83
fix: reimpl debug reads w/out throwing away *const Self
2022-08-07 05:11:29 -05:00
Rekai Nyangadzayi Musuka
5a18b1dcc7
chore: update dependencies:
2022-08-06 08:28:30 -05:00
Rekai Nyangadzayi Musuka
2c8616f610
feat: reimplement cpu logging
2022-07-27 14:50:28 -03:00
Rekai Nyangadzayi Musuka
53eec5c3ff
chore: don't init bus in Arm7tdmi init
2022-07-27 13:44:24 -03:00
Rekai Nyangadzayi Musuka
c397b7069d
feat: move arm instr decoding to module
2022-07-27 13:23:29 -03:00
Rekai Nyangadzayi Musuka
9d037fdc3e
feat: move thumb instr decoding to module
2022-07-27 13:10:58 -03:00
Rekai Nyangadzayi Musuka
53191b0eeb
chore: change directory structure
2022-07-22 21:11:19 -03:00
Rekai Nyangadzayi Musuka
c7c4a90948
fix: reimplement halt fast-forwarding
2022-07-21 11:25:49 -03:00
Rekai Nyangadzayi Musuka
03ded099d2
chore: move audio sync, video sync variables
2022-07-21 11:05:49 -03:00