v8/test/mjsunit/regress/wasm/regress-1054466.js
Ng Zhi An 4c2f84b56b [wasm-simd] Rename anytrue and alltrue to follow proposal
The proposal uses the lane shape, e.g. i64x2.anytrue, and we were using
s1x2.anytrue in our opcodes. This was a legacy naming, because we were
trying to bitpack the booleans. Now that we aren't doing that, rename
these to be more consistent with the proposal.

This was done with a straightforward sed script, changing both cpp code
and also some comments in mjsunit test files.

Bug: v8:10506
Change-Id: If077ed805de23520d8580d6b3b1906c80f67b94f
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2207915
Commit-Queue: Zhi An Ng <zhin@chromium.org>
Reviewed-by: Deepti Gandluri <gdeepti@chromium.org>
Reviewed-by: Tobias Tebbi <tebbi@chromium.org>
Cr-Commit-Position: refs/heads/master@{#67945}
2020-05-21 19:03:52 +00:00

53 lines
1.7 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');
const builder = new WasmModuleBuilder();
builder.addType(makeSig([kWasmI32, kWasmI32, kWasmI32], [kWasmI32]));
// Generate function 1 (out of 1).
builder.addFunction(undefined, 0 /* sig */)
.addLocals({i32_count: 2}).addLocals({f32_count: 2})
.addBodyWithEnd([
// signature: i_iii
// body:
kExprI32Const, 0x00, // i32.const
kExprI32Const, 0x00, // i32.const
kExprI32Const, 0xf9, 0x00, // i32.const
kExprI32Ior, // i32.or
kExprI32Eqz, // i32.eqz
kExprI32Add, // i32.Add
kSimdPrefix, kExprI32x4Splat, // i32x4.splat
kExprF32Const, 0x46, 0x5d, 0x00, 0x00, // f32.const
kExprI32Const, 0x83, 0x01, // i32.const
kExprI32Const, 0x83, 0x01, // i32.const
kExprI32Const, 0x83, 0x01, // i32.const
kExprI32Add, // i32.Add
kExprI32Add, // i32.Add
kExprIf, kWasmI32, // if @33 i32
kExprI32Const, 0x00, // i32.const
kExprElse, // else @37
kExprI32Const, 0x00, // i32.const
kExprEnd, // end @40
kExprIf, kWasmI32, // if @41 i32
kExprI32Const, 0x00, // i32.const
kExprElse, // else @45
kExprI32Const, 0x00, // i32.const
kExprEnd, // end @48
kExprF32ReinterpretI32, // f32.reinterpret_i32
kExprF32Max, // f32.max
kSimdPrefix, kExprF32x4Splat, // f32x4.splat
kExprI32Const, 0x83, 0x01, // i32.const
kSimdPrefix, kExprI32x4Splat, // i32x4.splat
kSimdPrefix, kExprI32x4Eq, // i32x4.eq
kSimdPrefix, kExprI32x4Eq, // i32x4.eq
kSimdPrefix, kExprV8x16AnyTrue, // v8x16.any_true
kExprEnd, // end @64
]);
builder.addExport('main', 0);
const instance = builder.instantiate();
print(instance.exports.main(1, 2, 3));