v8/test/mjsunit/wasm/simd-call.js
Ng Zhi An cccbd5f123 Reland "[wasm-simd][liftoff] Check CpuFeatures for SIMD support"
This relands commit 7c32fa05df.

Some test cases need to be updated, since we will bail out to TurboFan
where previously Liftoff was happy to run, when SIMD is not supported.

Original change's description:
> [wasm-simd][liftoff] Check CpuFeatures for SIMD support
>
> If Wasm simd128 is not supported on this particular hardware, we bail
> out to TurboFan.
>
> Bug: v8:9909
> Change-Id: Ie46e154426783ba099b7c0facc906670cda1bdd0
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2029427
> Reviewed-by: Clemens Backes <clemensb@chromium.org>
> Commit-Queue: Zhi An Ng <zhin@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#66055}

Bug: v8:9909
Bug: v8:10169
Change-Id: I850e1fe6bfbd12fb2eec052aa8367624c09f7a08
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2030354
Commit-Queue: Zhi An Ng <zhin@chromium.org>
Reviewed-by: Clemens Backes <clemensb@chromium.org>
Cr-Commit-Position: refs/heads/master@{#66090}
2020-02-03 19:43:09 +00:00

67 lines
2.0 KiB
JavaScript

// Copyright 2020 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: --experimental-wasm-simd
load('test/mjsunit/wasm/wasm-module-builder.js');
// Tests function calls containing s128 parameters. It also checks that
// lowering of simd calls are correct, so we create 2 functions with s128
// arguments: function 2 has a single s128 parameter, function 3 has a i32 then
// s128, to ensure that the arguments in different indices are correctly lowered.
(function TestSimd128Params() {
const builder = new WasmModuleBuilder();
builder.addImportedMemory('m', 'imported_mem', 1, 2);
builder
.addFunction("main", makeSig([], []))
.addBodyWithEnd([
kExprI32Const, 0,
kSimdPrefix, kExprS128LoadMem, 0, 0,
kExprCallFunction, 0x01,
kExprEnd,
]);
// Writes s128 argument to memory starting byte 16.
builder
.addFunction("function2", makeSig([kWasmS128], []))
.addBodyWithEnd([
kExprI32Const, 16,
kExprLocalGet, 0,
kSimdPrefix, kExprS128StoreMem, 0, 0,
kExprI32Const, 9, // This constant doesn't matter.
kExprLocalGet, 0,
kExprCallFunction, 0x02,
kExprEnd,
]);
// Writes s128 argument to memory starting byte 32.
builder
.addFunction("function3", makeSig([kWasmI32, kWasmS128], []))
.addBodyWithEnd([
kExprI32Const, 32,
kExprLocalGet, 1,
kSimdPrefix, kExprS128StoreMem, 0, 0,
kExprEnd,
]);
builder.addExport('main', 0);
var memory = new WebAssembly.Memory({initial:1, maximum:2});
const instance = builder.instantiate({m: {imported_mem: memory}});
const arr = new Uint8Array(memory.buffer);
// Fill the initial memory with some values, this is read by main and passed
// as arguments to function2, and then to function3.
for (let i = 0; i < 16; i++) {
arr[i] = i * 2;
}
instance.exports.main();
for (let i = 0; i < 16; i++) {
assertEquals(arr[i], arr[i+16]);
assertEquals(arr[i], arr[i+32]);
}
})();