fix: incorrect order-of-operations in ARM BL impl

This commit is contained in:
2022-04-27 23:15:39 -05:00
parent a87b46898b
commit 002287ecfe
2 changed files with 5 additions and 4 deletions

View File

@@ -10,7 +10,7 @@ pub fn branch(comptime L: bool) InstrFn {
return struct {
fn inner(cpu: *Arm7tdmi, _: *Bus, opcode: u32) void {
if (L) cpu.r[14] = cpu.r[15];
cpu.r[15] = cpu.fakePC() +% sext(24, opcode << 2);
cpu.r[15] = cpu.fakePC() +% (sext(24, opcode) << 2);
}
}.inner;
}