[wasm] Support anyref for external calls in interpreter.

This adds support for passing/returning reference type parameter/return
values when the interpreter is calling extern functions. It expands the
existing test coverage to the interpreter.

R=clemensh@chromium.org
TEST=mjsunit/wasm/anyref-interpreter,mjsunit/wasm/anyfunc-interpreter
BUG=v8:8091,v8:7581

Change-Id: I377e9d28aa36866c0441683ffd6a48160b721ec1
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1559853
Reviewed-by: Clemens Hammacher <clemensh@chromium.org>
Commit-Queue: Michael Starzinger <mstarzinger@chromium.org>
Cr-Commit-Position: refs/heads/master@{#60715}
This commit is contained in:
Michael Starzinger 2019-04-09 14:59:57 +02:00 committed by Commit Bot
parent 31b49aeeb0
commit b077d88e12
3 changed files with 37 additions and 0 deletions

View File

@ -3517,6 +3517,12 @@ class ThreadImpl {
case kWasmF64: case kWasmF64:
WriteUnalignedValue(address, arg.to<double>()); WriteUnalignedValue(address, arg.to<double>());
break; break;
case kWasmAnyRef:
case kWasmAnyFunc:
case kWasmExceptRef:
DCHECK_EQ(kSystemPointerSize, param_size);
WriteUnalignedValue<Object>(address, *arg.to_anyref());
break;
default: default:
UNIMPLEMENTED(); UNIMPLEMENTED();
} }
@ -3588,6 +3594,13 @@ class ThreadImpl {
case kWasmF64: case kWasmF64:
Push(WasmValue(ReadUnalignedValue<double>(address))); Push(WasmValue(ReadUnalignedValue<double>(address)));
break; break;
case kWasmAnyRef:
case kWasmAnyFunc:
case kWasmExceptRef: {
Handle<Object> ref(ReadUnalignedValue<Object>(address), isolate);
Push(WasmValue(ref));
break;
}
default: default:
UNIMPLEMENTED(); UNIMPLEMENTED();
} }

View File

@ -0,0 +1,12 @@
// Copyright 2019 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --expose-wasm --experimental-wasm-anyref --expose-gc
// Flags: --wasm-interpret-all
// This is just a wrapper for an existing reference types test case that runs
// with the --wasm-interpret-all flag added. If we ever decide to add a test
// variant for this, then we can remove this file.
load("test/mjsunit/wasm/anyfunc.js");

View File

@ -0,0 +1,12 @@
// Copyright 2019 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --expose-wasm --experimental-wasm-anyref --expose-gc
// Flags: --wasm-interpret-all
// This is just a wrapper for an existing reference types test case that runs
// with the --wasm-interpret-all flag added. If we ever decide to add a test
// variant for this, then we can remove this file.
load("test/mjsunit/wasm/anyref.js");