summaryrefslogtreecommitdiff
path: root/src/wasm/wasm-validator.cpp
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2018-12-27 15:24:57 -0800
committerGitHub <noreply@github.com>2018-12-27 15:24:57 -0800
commit3f3fc857ff6204517281ed5caa3209cc8f02d4fc (patch)
treeb64969a33874f29d5f35ea546c69eda90f89edf4 /src/wasm/wasm-validator.cpp
parentfdd4cb7b11d43c6ff200c9541f8567000a8d4bcd (diff)
downloadbinaryen-3f3fc857ff6204517281ed5caa3209cc8f02d4fc.tar.gz
binaryen-3f3fc857ff6204517281ed5caa3209cc8f02d4fc.tar.bz2
binaryen-3f3fc857ff6204517281ed5caa3209cc8f02d4fc.zip
Fix fuzzing JS glue code (#1843)
After we added logging to the fuzzer, we forgot to add to the JS glue code the necessary imports so it can be run there too. Also adds legalization for the JS glue code imports and exports. Also adds a missing validator check on imports having a function type (the fuzzing code was missing one). Fixes #1842
Diffstat (limited to 'src/wasm/wasm-validator.cpp')
-rw-r--r--src/wasm/wasm-validator.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/wasm/wasm-validator.cpp b/src/wasm/wasm-validator.cpp
index ef4d90fbd..d11d02353 100644
--- a/src/wasm/wasm-validator.cpp
+++ b/src/wasm/wasm-validator.cpp
@@ -1069,6 +1069,9 @@ void FunctionValidator::visitFunction(Function* curr) {
shouldBeTrue(ft->params == curr->params, curr->name, "function params must match its declared type");
shouldBeTrue(ft->result == curr->result, curr->name, "function result must match its declared type");
}
+ if (curr->imported()) {
+ shouldBeTrue(curr->type.is(), curr->name, "imported functions must have a function type");
+ }
}
static bool checkOffset(Expression* curr, Address add, Address max) {