summaryrefslogtreecommitdiff
path: root/z80_to_x86.c
diff options
context:
space:
mode:
authorMike Pavone <pavone@retrodev.com>2013-05-04 18:51:53 -0700
committerMike Pavone <pavone@retrodev.com>2013-05-04 18:51:53 -0700
commite189336af3dfd68e8850d89b9819eb7f16ddf01d (patch)
tree932c3de07cb5f905797b0311988a6373db280bbd /z80_to_x86.c
parent3f1e17f9803faeab79f6dbf000b4855ba7bc894f (diff)
Implemente RLD
Diffstat (limited to 'z80_to_x86.c')
-rw-r--r--z80_to_x86.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/z80_to_x86.c b/z80_to_x86.c
index 7314afc..8ecdff1 100644
--- a/z80_to_x86.c
+++ b/z80_to_x86.c
@@ -1083,8 +1083,27 @@ uint8_t * translate_z80inst(z80inst * inst, uint8_t * dst, z80_context * context
} else {
dst = z80_save_reg(dst, inst, opts);
}
- /*case Z80_RLD:
- case Z80_RRD:*/
+ case Z80_RLD:
+ dst = zcycles(dst, 8);
+ dst = mov_rr(dst, opts->regs[Z80_HL], SCRATCH1, SZ_W);
+ dst = call(dst, (uint8_t *)z80_read_byte);
+ //Before: (HL) = 0x12, A = 0x34
+ //After: (HL) = 0x24, A = 0x31
+ dst = mov_rr(dst, opts->regs[Z80_A], SCRATCH2, SZ_B);
+ dst = shl_ir(dst, 4, SCRATCH1, SZ_W);
+ dst = and_ir(dst, 0xF, SCRATCH2, SZ_W);
+ dst = and_ir(dst, 0xFFF, SCRATCH1, SZ_W);
+ dst = and_ir(dst, 0xF0, opts->regs[Z80_A], SZ_B);
+ dst = or_rr(dst, SCRATCH2, SCRATCH1, SZ_W);
+ //SCRATCH1 = 0x0124
+ dst = ror_ir(dst, 8, SCRATCH1, SZ_W);
+ dst = zcycles(dst, 4);
+ dst = or_rr(dst, SCRATCH1, opts->regs[Z80_A], SZ_B);
+ dst = mov_rr(dst, opts->regs[Z80_HL], SCRATCH2, SZ_W);
+ dst = ror_ir(dst, 8, SCRATCH1, SZ_W);
+ dst = call(dst, (uint8_t *)z80_write_byte);
+ break;
+ //case Z80_RRD:*/
case Z80_BIT:
cycles = (inst->addr_mode == Z80_IX_DISPLACE || inst->addr_mode == Z80_IY_DISPLACE) ? 8 : 16;
dst = zcycles(dst, cycles);