diff options
author | Alon Zakai (kripken) <alonzakai@gmail.com> | 2017-07-28 16:26:46 -0700 |
---|---|---|
committer | Alon Zakai (kripken) <alonzakai@gmail.com> | 2017-07-29 19:18:54 -0700 |
commit | 7a06499ada2f5d0d349731595b3a09a46919c443 (patch) | |
tree | aa4d98f6299d017dc5e0b0186d6d5b945baa5862 /src | |
parent | db51c2efa3a9c2da064db199792b3bf0de4e850f (diff) | |
download | binaryen-7a06499ada2f5d0d349731595b3a09a46919c443.tar.gz binaryen-7a06499ada2f5d0d349731595b3a09a46919c443.tar.bz2 binaryen-7a06499ada2f5d0d349731595b3a09a46919c443.zip |
fix binary emitting of untaken branches, and also handle reading of unreachable stacky code which may introduce concrete elements in non-final block positoins
Diffstat (limited to 'src')
-rw-r--r-- | src/wasm/wasm-binary.cpp | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/src/wasm/wasm-binary.cpp b/src/wasm/wasm-binary.cpp index 2df7f2e26..ac8df5711 100644 --- a/src/wasm/wasm-binary.cpp +++ b/src/wasm/wasm-binary.cpp @@ -545,7 +545,7 @@ void WasmBinaryWriter::recurse(Expression*& curr) { } static bool brokenTo(Block* block) { - return block->name.is() && BranchUtils::BranchSeeker::has(block, block->name); + return block->name.is() && BranchUtils::BranchSeeker::hasNamed(block, block->name); } void WasmBinaryWriter::visitBlock(Block *curr) { @@ -636,7 +636,7 @@ int32_t WasmBinaryWriter::getBreakIndex(Name name) { // -1 if not found return breakStack.size() - 1 - i; } } - std::cerr << "bad break: " << name << std::endl; + std::cerr << "bad break: " << name << " in " << currFunction->name << std::endl; abort(); } @@ -2070,7 +2070,14 @@ void WasmBinaryBuilder::visitBlock(Block *curr) { } for (size_t i = start; i < end; i++) { if (debug) std::cerr << " " << size_t(expressionStack[i]) << "\n zz Block element " << curr->list.size() << std::endl; - curr->list.push_back(expressionStack[i]); + auto* item = expressionStack[i]; + curr->list.push_back(item); + if (i < end - 1) { + // stacky&unreachable code may introduce elements that need to be dropped in non-final positoins + if (isConcreteWasmType(item->type)) { + curr->list.back() = Builder(wasm).makeDrop(curr->list.back()); + } + } } expressionStack.resize(start); curr->finalize(curr->type); |