From c33a13fba8a0674fcc2d835021cc37f6cfe3d8fa Mon Sep 17 00:00:00 2001 From: Xavier Del Campo Romero Date: Thu, 6 Nov 2025 21:31:05 +0100 Subject: Add i32_store8 --- src/interp/ops.c | 2 +- src/op/CMakeLists.txt | 1 + src/op/i32_store8.c | 90 +++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 92 insertions(+), 1 deletion(-) create mode 100644 src/op/i32_store8.c (limited to 'src') diff --git a/src/interp/ops.c b/src/interp/ops.c index 6135f96..6a5f82e 100644 --- a/src/interp/ops.c +++ b/src/interp/ops.c @@ -72,7 +72,7 @@ static void (*const ops[])(struct nw_interp *) = nwp_op_i64_store, /* OP_I64_STORE */ NULL, /* OP_F32_STORE */ NULL, /* OP_F64_STORE */ - NULL, /* OP_I32_STORE8 */ + nwp_op_i32_store8, /* OP_I32_STORE8 */ NULL, /* OP_I32_STORE16 */ NULL, /* OP_I64_STORE8 */ NULL, /* OP_I64_STORE16 */ diff --git a/src/op/CMakeLists.txt b/src/op/CMakeLists.txt index 53036f0..d537327 100644 --- a/src/op/CMakeLists.txt +++ b/src/op/CMakeLists.txt @@ -29,6 +29,7 @@ target_sources(${PROJECT_NAME} PRIVATE i32_ne.c i32_or.c i32_store.c + i32_store8.c i32_sub.c i64_const.c i64_store.c diff --git a/src/op/i32_store8.c b/src/op/i32_store8.c new file mode 100644 index 0000000..ea125bf --- /dev/null +++ b/src/op/i32_store8.c @@ -0,0 +1,90 @@ +/* + * nanowasm, a tiny WebAssembly/Wasm interpreter + * Copyright (C) 2023-2025 Xavier Del Campo Romero + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at https://mozilla.org/MPL/2.0/. + */ + +#include +#include +#include +#include +#include +#include +#include +#include + +static enum nw_state store(struct nw_interp *const i) +{ + struct nw_i_sm_store *const s = &i->sm.store; + const enum nw_state n = nwp_linear_store(i, &s->io, s->addr + s->imm.offset); + + if (n) + return n; + + nwp_interp_resume(i); + return NW_AGAIN; +} + +static enum nw_state pop_addr(struct nw_interp *const i) +{ + struct nw_i_sm_store *const s = &i->sm.store; + const enum nw_state n = nwp_stack_pop(i, &s->io); + + if (n) + return n; + else + { + struct nw_sm_io io = {0}; + + io.buf = &s->value.i8; + io.n = sizeof s->value.i8; + s->io = io; + i->next = store; + } + + return NW_AGAIN; +} + +static enum nw_state pop_value(struct nw_interp *const i) +{ + struct nw_i_sm_store *const s = &i->sm.store; + const enum nw_state n = nwp_stack_pop(i, &s->io); + + if (n) + return n; + else + { + const struct nw_sm_io io = {0}; + + s->value.i8 = nwp_leuint32(&s->value.v32); + s->io = io; + s->io.buf = &s->addr; + s->io.n = sizeof s->addr; + i->next = pop_addr; + } + + return NW_AGAIN; +} + +static void prepare(struct nw_interp *const i) +{ + const struct nw_i_sm_store s = {0}; + struct nw_i_sm_store *const ps = &i->sm.store; + struct nw_sm_io *const io = &ps->io; + struct nw_i_sm_imm_out out; + + out = i->sm.imm.out; + *ps = s; + ps->imm = out; + io->buf = &ps->value.i32; + io->n = sizeof ps->value.i32; + i->next = pop_value; +} + +void nwp_op_i32_store8(struct nw_interp *const i) +{ + nwp_mem_imm(i, prepare); +} -- cgit v1.2.3