diff options
Diffstat (limited to 'src/wasm/wasm-binary.cpp')
-rw-r--r-- | src/wasm/wasm-binary.cpp | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/src/wasm/wasm-binary.cpp b/src/wasm/wasm-binary.cpp index f92f1ae26..e85740614 100644 --- a/src/wasm/wasm-binary.cpp +++ b/src/wasm/wasm-binary.cpp @@ -4040,6 +4040,12 @@ BinaryConsts::ASTNodes WasmBinaryBuilder::readExpression(Expression*& curr) { if (maybeVisitArrayCopy(curr, opcode)) { break; } + if (maybeVisitArrayFill(curr, opcode)) { + break; + } + if (maybeVisitArrayInit(curr, opcode)) { + break; + } if (maybeVisitStringNew(curr, opcode)) { break; } @@ -7216,6 +7222,50 @@ bool WasmBinaryBuilder::maybeVisitArrayCopy(Expression*& out, uint32_t code) { return true; } +bool WasmBinaryBuilder::maybeVisitArrayFill(Expression*& out, uint32_t code) { + if (code != BinaryConsts::ArrayFill) { + return false; + } + auto heapType = getIndexedHeapType(); + auto* size = popNonVoidExpression(); + auto* value = popNonVoidExpression(); + auto* index = popNonVoidExpression(); + auto* ref = popNonVoidExpression(); + validateHeapTypeUsingChild(ref, heapType); + out = Builder(wasm).makeArrayFill(ref, index, value, size); + return true; +} + +bool WasmBinaryBuilder::maybeVisitArrayInit(Expression*& out, uint32_t code) { + ArrayInitOp op; + switch (code) { + case BinaryConsts::ArrayInitData: + op = InitData; + break; + case BinaryConsts::ArrayInitElem: + op = InitElem; + break; + default: + return false; + } + auto heapType = getIndexedHeapType(); + Index segIdx = getU32LEB(); + auto* size = popNonVoidExpression(); + auto* offset = popNonVoidExpression(); + auto* index = popNonVoidExpression(); + auto* ref = popNonVoidExpression(); + validateHeapTypeUsingChild(ref, heapType); + auto* built = + Builder(wasm).makeArrayInit(op, Name(), ref, index, offset, size); + if (op == InitData) { + dataRefs[segIdx].push_back(&built->segment); + } else { + elemRefs[segIdx].push_back(&built->segment); + } + out = built; + return true; +} + bool WasmBinaryBuilder::maybeVisitStringNew(Expression*& out, uint32_t code) { StringNewOp op; Expression* length = nullptr; |