summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2022-08-01 13:23:39 -0700
committerGitHub <noreply@github.com>2022-08-01 20:23:39 +0000
commit67459642f1d3cfdb74190a83aa1228cfa7332ecd (patch)
tree3ecc03bc9ffc2f7e7d74eafe36490face1ed291f /src
parentf5ea1f3a9f030d43448db41629dc9b4ae84f3b32 (diff)
downloadbinaryen-67459642f1d3cfdb74190a83aa1228cfa7332ecd.tar.gz
binaryen-67459642f1d3cfdb74190a83aa1228cfa7332ecd.tar.bz2
binaryen-67459642f1d3cfdb74190a83aa1228cfa7332ecd.zip
Add interpreter support for intrinsics (#4851)
This can give us some chance to catch bugs like #4839 in the fuzzer.
Diffstat (limited to 'src')
-rw-r--r--src/ir/intrinsics.cpp10
-rw-r--r--src/wasm-interpreter.h10
2 files changed, 17 insertions, 3 deletions
diff --git a/src/ir/intrinsics.cpp b/src/ir/intrinsics.cpp
index c2318cabf..26b624391 100644
--- a/src/ir/intrinsics.cpp
+++ b/src/ir/intrinsics.cpp
@@ -19,11 +19,17 @@
namespace wasm {
-static Name BinaryenIntrinsics("binaryen-intrinsics"),
+static Name BinaryenIntrinsicsModule("binaryen-intrinsics"),
CallWithoutEffects("call.without.effects");
bool Intrinsics::isCallWithoutEffects(Function* func) {
- return func->module == BinaryenIntrinsics && func->base == CallWithoutEffects;
+ if (func->module != BinaryenIntrinsicsModule) {
+ return false;
+ }
+ if (func->base == CallWithoutEffects) {
+ return true;
+ }
+ Fatal() << "Unrecognized intrinsic";
}
Call* Intrinsics::isCallWithoutEffects(Expression* curr) {
diff --git a/src/wasm-interpreter.h b/src/wasm-interpreter.h
index 107f38f09..65ffdbade 100644
--- a/src/wasm-interpreter.h
+++ b/src/wasm-interpreter.h
@@ -28,6 +28,7 @@
#include <sstream>
#include <variant>
+#include "ir/intrinsics.h"
#include "ir/module-utils.h"
#include "support/bits.h"
#include "support/safe_integer.h"
@@ -2757,7 +2758,14 @@ public:
}
auto* func = wasm.getFunction(curr->target);
Flow ret;
- if (func->imported()) {
+ if (Intrinsics(*self()->getModule()).isCallWithoutEffects(func)) {
+ // The call.without.effects intrinsic is a call to an import that actually
+ // calls the given function reference that is the final argument.
+ auto newArguments = arguments;
+ auto target = newArguments.back();
+ newArguments.pop_back();
+ ret.values = callFunctionInternal(target.getFunc(), newArguments);
+ } else if (func->imported()) {
ret.values = externalInterface->callImport(func, arguments);
} else {
ret.values = callFunctionInternal(curr->target, arguments);