chore: remove TODOs and some useless imports
This commit is contained in:
		| @@ -1,5 +1,3 @@ | ||||
| const std = @import("std"); | ||||
|  | ||||
| const Bus = @import("../../Bus.zig"); | ||||
| const Arm7tdmi = @import("../../cpu.zig").Arm7tdmi; | ||||
| const InstrFn = @import("../../cpu.zig").ArmInstrFn; | ||||
|   | ||||
| @@ -1,19 +1,16 @@ | ||||
| const std = @import("std"); | ||||
| const util = @import("../../util.zig"); | ||||
|  | ||||
| const Bus = @import("../../Bus.zig"); | ||||
| const Arm7tdmi = @import("../../cpu.zig").Arm7tdmi; | ||||
| const InstrFn = @import("../../cpu.zig").ArmInstrFn; | ||||
|  | ||||
| const u32SignExtend = @import("../../util.zig").u32SignExtend; | ||||
|  | ||||
| pub fn branch(comptime L: bool) InstrFn { | ||||
|     return struct { | ||||
|         fn inner(cpu: *Arm7tdmi, _: *Bus, opcode: u32) void { | ||||
|             if (L) { | ||||
|                 // TODO: Debugging beeg.gba w/ MGBA seems to suggest that I don't do anything here | ||||
|                 cpu.r[14] = cpu.r[15]; | ||||
|             } | ||||
|  | ||||
|             cpu.r[15] = cpu.fakePC() +% util.u32SignExtend(24, opcode << 2); | ||||
|             if (L) cpu.r[14] = cpu.r[15]; | ||||
|             cpu.r[15] = cpu.fakePC() +% u32SignExtend(24, opcode << 2); | ||||
|         } | ||||
|     }.inner; | ||||
| } | ||||
| @@ -21,7 +18,5 @@ pub fn branch(comptime L: bool) InstrFn { | ||||
| pub fn branchAndExchange(cpu: *Arm7tdmi, _: *Bus, opcode: u32) void { | ||||
|     const rn = opcode & 0xF; | ||||
|     cpu.cpsr.t.write(cpu.r[rn] & 1 == 1); | ||||
|  | ||||
|     // TODO: Is this how I should do it? | ||||
|     cpu.r[15] = cpu.r[rn] & 0xFFFF_FFFE; | ||||
| } | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
| const std = @import("std"); | ||||
|  | ||||
| const shifter = @import("../barrel_shifter.zig"); | ||||
| const Bus = @import("../../Bus.zig"); | ||||
| const Arm7tdmi = @import("../../cpu.zig").Arm7tdmi; | ||||
| const InstrFn = @import("../../cpu.zig").ArmInstrFn; | ||||
|  | ||||
| const rotateRight = @import("../barrel_shifter.zig").rotateRight; | ||||
| const execute = @import("../barrel_shifter.zig").execute; | ||||
|  | ||||
| pub fn dataProcessing(comptime I: bool, comptime S: bool, comptime instrKind: u4) InstrFn { | ||||
|     return struct { | ||||
|         fn inner(cpu: *Arm7tdmi, _: *Bus, opcode: u32) void { | ||||
| @@ -20,9 +20,9 @@ pub fn dataProcessing(comptime I: bool, comptime S: bool, comptime instrKind: u4 | ||||
|             var op2: u32 = undefined; | ||||
|             if (I) { | ||||
|                 const amount = @truncate(u8, (opcode >> 8 & 0xF) << 1); | ||||
|                 op2 = shifter.rotateRight(S, &cpu.cpsr, opcode & 0xFF, amount); | ||||
|                 op2 = rotateRight(S, &cpu.cpsr, opcode & 0xFF, amount); | ||||
|             } else { | ||||
|                 op2 = shifter.execute(S, cpu, opcode); | ||||
|                 op2 = execute(S, cpu, opcode); | ||||
|             } | ||||
|  | ||||
|             // Undo special condition from above | ||||
| @@ -275,7 +275,7 @@ fn setTestOpFlags(comptime S: bool, cpu: *Arm7tdmi, opcode: u32, result: u32) vo | ||||
|     cpu.cpsr.n.write(result >> 31 & 1 == 1); | ||||
|     cpu.cpsr.z.write(result == 0); | ||||
|     // Barrel Shifter should always calc CPSR C in TST | ||||
|     if (!S) _ = shifter.execute(true, cpu, opcode); | ||||
|     if (!S) _ = execute(true, cpu, opcode); | ||||
| } | ||||
|  | ||||
| fn undefinedTestBehaviour(cpu: *Arm7tdmi) void { | ||||
|   | ||||
| @@ -1,10 +1,11 @@ | ||||
| const std = @import("std"); | ||||
| const util = @import("../../util.zig"); | ||||
|  | ||||
| const Bus = @import("../../Bus.zig"); | ||||
| const Arm7tdmi = @import("../../cpu.zig").Arm7tdmi; | ||||
| const InstrFn = @import("../../cpu.zig").ArmInstrFn; | ||||
|  | ||||
| const u32SignExtend = @import("../../util.zig").u32SignExtend; | ||||
|  | ||||
| pub fn halfAndSignedDataTransfer(comptime P: bool, comptime U: bool, comptime I: bool, comptime W: bool, comptime L: bool) InstrFn { | ||||
|     return struct { | ||||
|         fn inner(cpu: *Arm7tdmi, bus: *Bus, opcode: u32) void { | ||||
| @@ -41,14 +42,14 @@ pub fn halfAndSignedDataTransfer(comptime P: bool, comptime U: bool, comptime I: | ||||
|                     }, | ||||
|                     0b10 => { | ||||
|                         // LDRSB | ||||
|                         result = util.u32SignExtend(8, bus.read8(address)); | ||||
|                         result = u32SignExtend(8, bus.read8(address)); | ||||
|                     }, | ||||
|                     0b11 => { | ||||
|                         // LDRSH | ||||
|                         const value = if (address & 1 == 1) blk: { | ||||
|                             break :blk util.u32SignExtend(8, bus.read8(address)); | ||||
|                             break :blk u32SignExtend(8, bus.read8(address)); | ||||
|                         } else blk: { | ||||
|                             break :blk util.u32SignExtend(16, bus.read16(address)); | ||||
|                             break :blk u32SignExtend(16, bus.read16(address)); | ||||
|                         }; | ||||
|  | ||||
|                         result = std.math.rotr(u32, value, 8 * (address & 1)); | ||||
|   | ||||
| @@ -1,5 +1,3 @@ | ||||
| const std = @import("std"); | ||||
|  | ||||
| const Bus = @import("../../Bus.zig"); | ||||
| const Arm7tdmi = @import("../../cpu.zig").Arm7tdmi; | ||||
| const InstrFn = @import("../../cpu.zig").ArmInstrFn; | ||||
|   | ||||
| @@ -1,5 +1,3 @@ | ||||
| const std = @import("std"); | ||||
|  | ||||
| const Bus = @import("../../Bus.zig"); | ||||
| const Arm7tdmi = @import("../../cpu.zig").Arm7tdmi; | ||||
| const InstrFn = @import("../../cpu.zig").ArmInstrFn; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user