Rekai Nyangadzayi Musuka
3ae24d6977
chore: account for empty rlist in THUMB LDM/STM
2022-02-05 18:03:39 -04:00
Rekai Nyangadzayi Musuka
0a22730479
fix(cpu): handle edge case in LDRSH
2022-02-05 17:12:25 -04:00
Rekai Nyangadzayi Musuka
bf4207ba8c
chore: reorganize util.zig
2022-02-05 15:55:12 -04:00
Rekai Nyangadzayi Musuka
78080b4682
fix: zero initialize all allocated memory
2022-02-05 15:54:53 -04:00
Rekai Nyangadzayi Musuka
428eff1468
Revert "fix: allow for 32-bit reads to KEYINPUT"
...
This reverts commit 3a51707280
.
2022-02-05 14:52:49 -04:00
Rekai Nyangadzayi Musuka
5ec8d4b0a5
fix: resolve decoding mixup in THUMB format 8 instructions
2022-02-05 14:50:34 -04:00
Rekai Nyangadzayi Musuka
3a51707280
fix: allow for 32-bit reads to KEYINPUT
2022-02-05 13:47:05 -04:00
Rekai Nyangadzayi Musuka
b4d20fb264
chore: refactor ARMv4 decoding
2022-02-05 13:46:55 -04:00
Rekai Nyangadzayi Musuka
746158043d
chore: add more debug information to CPU panic method
2022-02-05 13:46:24 -04:00
Rekai Nyangadzayi Musuka
25300c8a9f
chore: give more descriptive panic messages when changing mode fails
2022-02-04 16:54:57 -04:00
Rekai Nyangadzayi Musuka
27d0ba8c7e
chore: clean up THUMB instruction decoding
2022-02-04 15:57:46 -04:00
Rekai Nyangadzayi Musuka
2f74b61f2e
feat: parse cartridge header
2022-02-04 05:54:06 -04:00
Rekai Nyangadzayi Musuka
b233981a34
feat: rename ARM and THUMB SWI functions
2022-02-04 04:34:47 -04:00
Rekai Nyangadzayi Musuka
1b8db0c427
chore: group THUMB and select ARM instructions together (same file)
2022-02-04 04:18:20 -04:00
Rekai Nyangadzayi Musuka
3e4f9eddb2
feat: integrate zig-clap with ZBA
2022-02-04 03:12:35 -04:00
Rekai Nyangadzayi Musuka
6ab4610a81
fix(cpu): properly decode format 7 and 8
2022-02-03 01:29:18 -04:00
Rekai Nyangadzayi Musuka
91384a7c68
fix(cpu): resolve edge cases in THUMB Format 5
2022-02-03 00:55:57 -04:00
Rekai Nyangadzayi Musuka
c6bb4bf8e1
fix(cpu): allow for select values to overflow
...
FuzzARM found these operations which panicked, when they should
have overflowed. These are now fixed
n = 8000
2022-02-02 22:49:33 -04:00
Rekai Nyangadzayi Musuka
800ed6f1a7
feat(cpu): implement format 13
...
While bugs do exist, at this point all THUMB and ARMv4 instructions
have been implemented! Yay!
2022-02-02 22:31:21 -04:00
Rekai Nyangadzayi Musuka
027e4fb57b
feat(cpu): implement THUMB format 17
2022-02-02 22:31:08 -04:00
Rekai Nyangadzayi Musuka
1378c809e6
feat(cpu): implement THUMB format11
2022-02-02 22:30:46 -04:00
Rekai Nyangadzayi Musuka
33399e9517
chore: update to latest zig nightly
2022-02-02 21:26:12 -04:00
Rekai Nyangadzayi Musuka
99492a6782
chore: progress towards passing ldr/str thumb in armwrestler
2022-02-02 21:14:46 -04:00
Rekai Nyangadzayi Musuka
8b574efe85
fix(cpu): properly negate in NEG
2022-02-02 20:12:20 -04:00
Rekai Nyangadzayi Musuka
9fd03d2a92
fix(cpu): reimplement THUMB offset shifts
2022-02-02 20:12:07 -04:00
Rekai Nyangadzayi Musuka
9affe01da8
fix(cpu): op == 0b00 decodes to add in format 5
2022-02-02 18:58:06 -04:00
Rekai Nyangadzayi Musuka
784bc81a4a
fix(cpu): account for overflow in THUMB alu MUL
2022-02-02 18:57:33 -04:00
Rekai Nyangadzayi Musuka
045c98de1f
chore: use if-else when decoding THUMB instructions
2022-02-02 18:48:47 -04:00
Rekai Nyangadzayi Musuka
c2901ee0d8
fix(cpu): account for rn in rlist in block data transfer
2022-02-02 17:35:33 -04:00
Rekai Nyangadzayi Musuka
d95efa5b12
feat: implement LDM/STM behaviour when S is set
2022-02-02 16:12:47 -04:00
Rekai Nyangadzayi Musuka
237beb9caa
feat(cpu): Pass all LDR/STR ARMwrestler tests
2022-02-02 14:07:18 -04:00
Rekai Nyangadzayi Musuka
30bad76e44
feat(cpu): decode and implement all necessary ARM CPU instructions
2022-02-02 12:06:41 -04:00
Rekai Nyangadzayi Musuka
c34c2ee6eb
feat(cpu): implement ARM SWP and SWPB
2022-02-02 08:44:33 -04:00
Rekai Nyangadzayi Musuka
6c7934be70
fix: resolve off by n * 2 when accessing Palette during BG Mode 4
2022-02-01 22:56:53 -04:00
Rekai Nyangadzayi Musuka
48017b45f5
feat(cpu): Implement Multiply Long ARM instructions
2022-02-01 22:09:38 -04:00
Rekai Nyangadzayi Musuka
28c81f79ae
fix: no buttons are pressed by default
2022-02-01 20:52:01 -04:00
Rekai Nyangadzayi Musuka
a80600156d
feat(cpu): implement format 18 THUMB instructions
2022-02-01 19:12:01 -04:00
Rekai Nyangadzayi Musuka
0d7600ed7a
chore: more detailed panic message
2022-02-01 19:11:56 -04:00
Rekai Nyangadzayi Musuka
ca41f6a85c
feat(cpu): implement format 10 THUMB instructions
2022-02-01 17:56:11 -04:00
Rekai Nyangadzayi Musuka
85927a943f
feat(cpu): implement SWP
2022-02-01 16:30:55 -04:00
Rekai Nyangadzayi Musuka
b27bf4a85c
fix(cpu): perform MUL with u64s, throw away upper 32 bits
2022-02-01 16:15:08 -04:00
Rekai Nyangadzayi Musuka
b07eb22b86
feat: implement keyboard input
2022-02-01 16:11:59 -04:00
Rekai Nyangadzayi Musuka
f6e4b4931f
chore: don't panic on unsupported BG mode
2022-01-30 02:43:11 -04:00
Rekai Nyangadzayi Musuka
e35d81eeb8
chore: tempoarily disable fps counter
2022-01-30 02:42:01 -04:00
Rekai Nyangadzayi Musuka
8c248ffb11
chore: zero-initialize VRAM
2022-01-30 02:39:16 -04:00
Rekai Nyangadzayi Musuka
b0332e6eb8
chore: stub KeyInput I/O register
2022-01-30 02:38:29 -04:00
Rekai Nyangadzayi Musuka
dd632975f8
fix(cpu): properly decode multiply instructions
2022-01-30 02:16:12 -04:00
Rekai Nyangadzayi Musuka
a459d4b433
feat(cpu): implement ARM multiply instructions
2022-01-30 02:04:24 -04:00
Rekai Nyangadzayi Musuka
6c008ce950
fix: allow 32-bit writes to DISPCNT
2022-01-30 01:42:54 -04:00
Rekai Nyangadzayi Musuka
8d1df7ae43
fix(cpu): properly decode ldm stm thumb instructions
2022-01-30 01:12:34 -04:00
Rekai Nyangadzayi Musuka
6ffaf12804
fix(cpu): properly decode THUMB PUSH and POP at comptime
2022-01-30 00:16:13 -04:00
Rekai Nyangadzayi Musuka
dc6931639f
fix(cpu): don't ignore 11th bit of THUMB BL offset
2022-01-29 23:53:40 -04:00
Rekai Nyangadzayi Musuka
e18f10126e
feat(cpu): implement thumb push / pop and stub format 13 thumb instrs
2022-01-29 23:22:10 -04:00
Rekai Nyangadzayi Musuka
0598ba402d
feat(cpu): implement THUMB format 9 loads / stores
2022-01-29 22:34:40 -04:00
Rekai Nyangadzayi Musuka
b8a9aaee86
fix(cpu): resolve issues with unexpected PC value in THUMB
2022-01-29 22:07:36 -04:00
Rekai Nyangadzayi Musuka
00058f6094
feat(cpu): implement THUMB ldmia stmia
2022-01-29 21:10:14 -04:00
Rekai Nyangadzayi Musuka
2dde47318c
chore: implement THUMB format 4 instructions
2022-01-29 20:42:13 -04:00
Rekai Nyangadzayi Musuka
ae4023e51c
chore: dedup code in THUMB instructions
2022-01-29 20:05:27 -04:00
Rekai Nyangadzayi Musuka
bce067557f
chore: refactor and genericize ARM data processing calculations
2022-01-29 19:40:58 -04:00
Rekai Nyangadzayi Musuka
e0acabf050
chore: relocate barrel_shifter zig file
2022-01-29 18:52:16 -04:00
Rekai Nyangadzayi Musuka
599e068c7e
feat(cpu): implement format2 THUMB instructions
2022-01-29 18:46:27 -04:00
Rekai Nyangadzayi Musuka
4ca65caef0
feat(cpu): implement format19 THUMB instructions
2022-01-29 18:25:50 -04:00
Rekai Nyangadzayi Musuka
0c49bf2288
chore: account for THUMB BL instruction when mimicking mGBA logs
2022-01-29 18:14:00 -04:00
Rekai Nyangadzayi Musuka
44dbdba48c
feat(cpu): implement format16 THUMB instructions
2022-01-29 17:44:04 -04:00
Rekai Nyangadzayi Musuka
d85e0c8d05
feat(cpu): implement format 1 THUMB instructions
2022-01-29 17:29:30 -04:00
Rekai Nyangadzayi Musuka
995633e9e8
fix: dont close file handle early
2022-01-29 01:18:45 -04:00
Rekai Nyangadzayi Musuka
cfbd292edc
feat(cpu): implement format 6 THUMB instructions
2022-01-29 01:18:41 -04:00
Rekai Nyangadzayi Musuka
95efb3f35d
chore: rename title
2022-01-28 23:27:03 -04:00
Rekai Nyangadzayi Musuka
6a6dccf4d8
chore: refactor GBA Display Timings
...
This change should reflect that the Hblank bit of DISPSTAT is toggled on all scanlines
while also ensuring that the Vblank bit is set on all Vblank scanlines
2022-01-28 22:58:19 -04:00
Rekai Nyangadzayi Musuka
ad1db4dc2e
chore: move a single statement lol
2022-01-28 22:57:48 -04:00
Rekai Nyangadzayi Musuka
19359f7ee4
chore: mark indexing methods as inline
2022-01-28 17:11:29 -04:00
Rekai Nyangadzayi Musuka
24f0922f86
feat: create emulator thread
2022-01-28 16:33:38 -04:00
Rekai Nyangadzayi Musuka
b1cc985230
chore: disable logging by default
2022-01-25 18:20:30 -04:00
Rekai Nyangadzayi Musuka
e5c8f0ce07
chore: revert fastboot changes
2022-01-25 18:20:01 -04:00
Rekai Nyangadzayi Musuka
fbc5b309b0
chore: binary logging + file logging + DP chanes + fastBoot changes
2022-01-25 18:18:52 -04:00
Rekai Nyangadzayi Musuka
540fbf739a
chore: rename skipBios to fastBoot
2022-01-25 11:15:17 -04:00
Rekai Nyangadzayi Musuka
0546b1c308
chore: set correct values for select banked registers on fast boot
2022-01-25 11:14:15 -04:00
Rekai Nyangadzayi Musuka
997dc1314c
feat(cpu): implement SWI
2022-01-25 10:34:21 -04:00
Rekai Nyangadzayi Musuka
1456d0f317
chore(bios): allow reading from BIOS
2022-01-25 10:32:28 -04:00
Rekai Nyangadzayi Musuka
6257418405
fix(cpu): interim solution to weird program counter behaviour on illegal tst instruction
2022-01-25 09:23:32 -04:00
Rekai Nyangadzayi Musuka
985fefb9f6
chore(cpu): implement behaviour for undefined test instruction
2022-01-25 08:05:42 -04:00
Rekai Nyangadzayi Musuka
95dd3e3df8
fix(cpu): fix PC offset when barrel shifter and bit 4 of DP is set
2022-01-24 17:52:01 -04:00
Rekai Nyangadzayi Musuka
702ff288d8
fix(cpu): implement S set + rd == 15 case for data processing
2022-01-19 07:46:49 -04:00
Rekai Nyangadzayi Musuka
bf36a23722
feat(cpu): implement banked registers
2022-01-19 07:29:49 -04:00
Rekai Nyangadzayi Musuka
fc5a3460dd
fix(cpu): improve MRS and MSR instructions
2022-01-18 20:17:00 -04:00
Rekai Nyangadzayi Musuka
6177927049
feat(cpu): implement CMN
2022-01-18 15:09:25 -04:00
Rekai Nyangadzayi Musuka
903b75c7c4
fix(barrel_shifter): fix PC being 1 word ahead in barrel shifter
2022-01-18 15:08:29 -04:00
Rekai Nyangadzayi Musuka
8d786cbe25
feat(cpu): Implement RSC
2022-01-18 14:46:57 -04:00
Rekai Nyangadzayi Musuka
212bc9e11d
feat(cpu): implement RSB
2022-01-18 14:36:03 -04:00
Rekai Nyangadzayi Musuka
63a57ac954
feat(cpu): implement BIC
2022-01-18 14:28:47 -04:00
Rekai Nyangadzayi Musuka
85dae5e1d7
feat(cpu): implement EOR
2022-01-18 14:27:07 -04:00
Rekai Nyangadzayi Musuka
6189bf0315
feat(cpu): implement ADD
2022-01-18 14:25:29 -04:00
Rekai Nyangadzayi Musuka
2f3213f693
feat(cpu): implement fix for ADC and implement SBC
2022-01-18 14:20:01 -04:00
Rekai Nyangadzayi Musuka
a62cd9aa40
chore(barrel_shifter): remove panic from ASR
2022-01-18 14:19:58 -04:00
Rekai Nyangadzayi Musuka
25c57a4cc7
fix(barrel_shifter): should not modify cpsr when amount == 0
2022-01-18 13:30:41 -04:00
Rekai Nyangadzayi Musuka
a7a44c4463
chore(cpu): refactor the barrel shifter once again
2022-01-17 15:55:55 -04:00
Rekai Nyangadzayi Musuka
d4d2fedfbe
feat(cpu): implement ADC
...
ADC interacting w/ the Barrel Shifter is not working though
2022-01-17 14:29:34 -04:00
Rekai Nyangadzayi Musuka
483e149b32
feat(cpu): implement RRX for Barrel Shifter
2022-01-17 14:19:40 -04:00
Rekai Nyangadzayi Musuka
85ffdf44f5
feat(cpu): implement SUB in THUMB format 3
2022-01-17 11:36:02 -04:00
Rekai Nyangadzayi Musuka
9098a55ae3
feat(cpu): implement ARM SUB in data processing
2022-01-17 11:35:41 -04:00