diff options
author | Alon Zakai <alonzakai@gmail.com> | 2016-06-03 13:52:26 -0700 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2016-06-03 13:52:26 -0700 |
commit | eafdf9dc78e858b6d823771a2add8302564d93ef (patch) | |
tree | c64d460b074b4b6e40023a57417d2544991eb093 | |
parent | 4f323502ff00e0ca4a45759ed958f508812a7781 (diff) | |
download | binaryen-eafdf9dc78e858b6d823771a2add8302564d93ef.tar.gz binaryen-eafdf9dc78e858b6d823771a2add8302564d93ef.tar.bz2 binaryen-eafdf9dc78e858b6d823771a2add8302564d93ef.zip |
trap on invalid call_indirects with bad arguments when no type provided
-rw-r--r-- | src/wasm-interpreter.h | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/wasm-interpreter.h b/src/wasm-interpreter.h index 0ee2aff78..82ead1d8f 100644 --- a/src/wasm-interpreter.h +++ b/src/wasm-interpreter.h @@ -359,6 +359,10 @@ private: LiteralList arguments; Flow flow = generateArguments(curr->operands, arguments); if (flow.breaking()) return flow; + if (func->params.size() != arguments.size()) trap("callIndirect: bad # of arguments"); + for (size_t i = 0; i < func->getNumLocals(); i++) { + if (func->params[i] != arguments[i].type) trap("callIndirect: bad argument type"); + } return instance.callFunctionInternal(name, arguments); } |