From 9685552a509ea460c214888443cb1c93adc58e31 Mon Sep 17 00:00:00 2001 From: Ian Moffett Date: Mon, 13 Oct 2025 10:03:53 -0400 Subject: emux64: cpu: Add emulation of DIV instruction Signed-off-by: Ian Moffett --- emux64/src/cpu/cpu_cycle.c | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) (limited to 'emux64') diff --git a/emux64/src/cpu/cpu_cycle.c b/emux64/src/cpu/cpu_cycle.c index 9f30788..dda1794 100644 --- a/emux64/src/cpu/cpu_cycle.c +++ b/emux64/src/cpu/cpu_cycle.c @@ -237,6 +237,26 @@ cpu_do_mul(struct osmx_core *core) return 0; } +static int +cpu_do_div(struct osmx_core *core) +{ + struct arithop ops; + int error; + + error = cpu_arithop(core, &ops); + if (error < 0) { + return error; + } + + if (ops.op2 == 0) { + printf("** DIVIDE ERROR **\n"); + return -1; + } + + core->xn[ops.dest_reg] = ops.op1 / ops.op2; + return 0; +} + int cpu_run(struct osmx_core *core) { @@ -282,6 +302,12 @@ cpu_run(struct osmx_core *core) continue; } break; + case OP_DIV: + if (cpu_do_div(core) < 0) { + core->run = false; + continue; + } + break; case OP_NOP: break; default: -- cgit v1.2.3