diff --git a/check.py b/check.py index 9c10e49b605..f4891d8e9b5 100755 --- a/check.py +++ b/check.py @@ -433,6 +433,8 @@ def fix(x): # we must ignore some binary format splits splits_to_skip = { + 'func.wast': [2], + 'return.wast': [2] } # check binary format. here we can verify execution of the final result, no need for an output verification diff --git a/src/wasm-binary.h b/src/wasm-binary.h index 8e9534973a0..dcbe7d6db68 100644 --- a/src/wasm-binary.h +++ b/src/wasm-binary.h @@ -1313,7 +1313,7 @@ class WasmBinaryWriter : public Visitor { if (curr->value) { recurse(curr->value); } - o << int8_t(BinaryConsts::Return) << U32LEB(curr->value ? 1 : 0); + o << int8_t(BinaryConsts::Return); } void visitHost(Host *curr) { if (debug) std::cerr << "zz node: Host" << std::endl; @@ -2378,9 +2378,7 @@ class WasmBinaryBuilder { } void visitReturn(Return *curr) { if (debug) std::cerr << "zz node: Return" << std::endl; - auto arity = getU32LEB(); - assert(arity == 0 || arity == 1); - if (arity == 1) { + if (currFunction->result != none) { curr->value = popExpression(); } }