shithub: sms

Download patch

ref: c558f8af382c34666a5eb3c5c631813b3a864aa4
parent: f4164657be44522e31faa295b9a461092ed3380d
author: Jean-André Santoni <jean.andre.santoni@gmail.com>
date: Wed Jul 10 20:01:40 EDT 2024

Implement eda3

--- a/z80.c
+++ b/z80.c
@@ -548,6 +548,15 @@
 		if (((s[rL] + u) & 0x07) ^ s[rB]) s[rF] |= FLAGV; else s[rF] &= ~FLAGV;
 		if (s[rB] != 0) { pc -= 2; return 21; }
 		return 16;
+	case 0xa3:
+		s[rB]--;
+		u = z80read(HL());
+		z80write(s[rC], u);
+		addhl(1);
+		if (u & 0x80) s[rF] |= FLAGN; else s[rF] &= ~FLAGN;
+		if (s[rL] + u > 0xff) s[rF] |= (FLAGC|FLAGH); else s[rF] &= ~(FLAGC|FLAGH);
+		if (((s[rL] + u) & 0x07) ^ s[rB]) s[rF] |= FLAGV; else s[rF] &= ~FLAGV;
+		return 16;
 	}
 	sysfatal("undefined z80 opcode ed%.2x at pc=%#.4x", op, curpc);
 	return 0;
--