From c0046ad0e44d39f7ef33fa6a401a0d9d5a34a578 Mon Sep 17 00:00:00 2001 From: Thomas Lively Date: Mon, 29 Jan 2024 16:03:31 -0800 Subject: [Parser] Parse local.set and global.set of tuple values correctly (#6250) These instructions always pop a single value, except when tuples are involved, in which case they need special handling to know how many values to pop. --- src/wasm-ir-builder.h | 2 ++ src/wasm/wasm-ir-builder.cpp | 18 ++++++++++++++++++ 2 files changed, 20 insertions(+) (limited to 'src') diff --git a/src/wasm-ir-builder.h b/src/wasm-ir-builder.h index 77ad2490e..fce8bd431 100644 --- a/src/wasm-ir-builder.h +++ b/src/wasm-ir-builder.h @@ -223,6 +223,8 @@ public: [[nodiscard]] Result<> visitCall(Call*); [[nodiscard]] Result<> visitCallIndirect(CallIndirect*); [[nodiscard]] Result<> visitCallRef(CallRef*); + [[nodiscard]] Result<> visitLocalSet(LocalSet*); + [[nodiscard]] Result<> visitGlobalSet(GlobalSet*); [[nodiscard]] Result<> visitThrow(Throw*); [[nodiscard]] Result<> visitStringNew(StringNew*); [[nodiscard]] Result<> visitStringEncode(StringEncode*); diff --git a/src/wasm/wasm-ir-builder.cpp b/src/wasm/wasm-ir-builder.cpp index aace2b1ac..1eea777e0 100644 --- a/src/wasm/wasm-ir-builder.cpp +++ b/src/wasm/wasm-ir-builder.cpp @@ -492,6 +492,21 @@ Result<> IRBuilder::visitCallRef(CallRef* curr) { return Ok{}; } +Result<> IRBuilder::visitLocalSet(LocalSet* curr) { + auto type = func->getLocalType(curr->index); + auto val = pop(type.size()); + CHECK_ERR(val); + curr->value = *val; + return Ok{}; +} + +Result<> IRBuilder::visitGlobalSet(GlobalSet* curr) { + auto type = wasm.getGlobal(curr->name)->type; + auto val = pop(type.size()); + CHECK_ERR(val); + curr->value = *val; + return Ok{}; +} Result<> IRBuilder::visitThrow(Throw* curr) { auto numArgs = wasm.getTag(curr->tag)->sig.params.size(); curr->operands.resize(numArgs); @@ -1032,6 +1047,7 @@ Result<> IRBuilder::makeLocalGet(Index local) { Result<> IRBuilder::makeLocalSet(Index local) { LocalSet curr; + curr.index = local; CHECK_ERR(visitLocalSet(&curr)); push(builder.makeLocalSet(local, curr.value)); return Ok{}; @@ -1039,6 +1055,7 @@ Result<> IRBuilder::makeLocalSet(Index local) { Result<> IRBuilder::makeLocalTee(Index local) { LocalSet curr; + curr.index = local; CHECK_ERR(visitLocalSet(&curr)); push(builder.makeLocalTee(local, curr.value, func->getLocalType(local))); return Ok{}; @@ -1051,6 +1068,7 @@ Result<> IRBuilder::makeGlobalGet(Name global) { Result<> IRBuilder::makeGlobalSet(Name global) { GlobalSet curr; + curr.name = global; CHECK_ERR(visitGlobalSet(&curr)); push(builder.makeGlobalSet(global, curr.value)); return Ok{}; -- cgit v1.2.3