diff options
author | Derek Schuff <dschuff@chromium.org> | 2016-06-10 13:08:58 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-06-10 13:08:58 -0700 |
commit | 996262dcdb88388717aab72bd8f37841aaabb24c (patch) | |
tree | 638216583c72db4b2dcffb77dc39e045742dc803 /src/tools/s2wasm.cpp | |
parent | 59542c98459771905ef25c5fe48079f3353d6869 (diff) | |
download | binaryen-996262dcdb88388717aab72bd8f37841aaabb24c.tar.gz binaryen-996262dcdb88388717aab72bd8f37841aaabb24c.tar.bz2 binaryen-996262dcdb88388717aab72bd8f37841aaabb24c.zip |
s2wasm: Validate the result module (#574)
Add an s2wasm option `--no-validate` to disable validation for debugging purposes.
Also fix several validation errors by adding calls to `finalize()` after creating expressions, and ensuring that an import is created earlier in `Linker::getImportThunk`.
Diffstat (limited to 'src/tools/s2wasm.cpp')
-rw-r--r-- | src/tools/s2wasm.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/tools/s2wasm.cpp b/src/tools/s2wasm.cpp index a6bbdea18..54404c478 100644 --- a/src/tools/s2wasm.cpp +++ b/src/tools/s2wasm.cpp @@ -24,6 +24,7 @@ #include "s2wasm.h" #include "wasm-linker.h" #include "wasm-printing.h" +#include "wasm-validator.h" using namespace cashew; using namespace wasm; @@ -31,6 +32,7 @@ using namespace wasm; int main(int argc, const char *argv[]) { bool ignoreUnknownSymbols = false; bool generateEmscriptenGlue = false; + bool validateOutput = true; std::string startFunction; std::vector<std::string> archiveLibraries; Options options("s2wasm", "Link .s file into .wast"); @@ -81,6 +83,11 @@ int main(int argc, const char *argv[]) { [&archiveLibraries](Options *o, const std::string &argument) { archiveLibraries.push_back(argument); }) + .add("--no-validate", "", "Disable validation of the output module", + Options::Arguments::Zero, + [&validateOutput](Options *, const std::string &) { + validateOutput = false; + }) .add_positional("INFILE", Options::Arguments::One, [](Options *o, const std::string &argument) { o->extra["infile"] = argument; @@ -131,10 +138,16 @@ int main(int argc, const char *argv[]) { linker.emscriptenGlue(meta); } + if (options.debug) std::cerr << "Validating..." << std::endl; + if (validateOutput && !wasm::WasmValidator().validate(linker.getOutput().wasm)) { + Fatal() << "Error: linked module is not valid.\n"; + } + if (options.debug) std::cerr << "Printing..." << std::endl; Output output(options.extra["output"], Flags::Text, options.debug ? Flags::Debug : Flags::Release); WasmPrinter::printModule(&linker.getOutput().wasm, output.getStream()); output << meta.str(); if (options.debug) std::cerr << "Done." << std::endl; + return 0; } |