v8/test/mjsunit/regress/wasm/regress-1124885.js
Camillo Bruni a345a442d3 [d8][mjsunit][tools] Improve d8 file API
- Add d8.file.read() and d8.file.execute() helpers
- Change tools and tests to use new d8.file helper
- Unify error throwing in v8::Shell::ReadFile

Change-Id: I5ef4cb27f217508a367106f01e872a4059d5e399
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2928505
Commit-Queue: Camillo Bruni <cbruni@chromium.org>
Reviewed-by: Maya Lekova <mslekova@chromium.org>
Reviewed-by: Marja Hölttä <marja@chromium.org>
Cr-Commit-Position: refs/heads/master@{#74883}
2021-06-01 13:37:57 +00:00

48 lines
1.5 KiB
JavaScript

// Copyright 2021 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
// This exercises an bug in scalar-lowering for load transforms. In
// particular, if the index input to v128.load32_splat was a extract_lane, the
// input wasn't correctly lowered. This caused the extract_lane node to stick
// around until code-generator, where we hit a mismatch in the register types.
d8.file.execute('test/mjsunit/wasm/wasm-module-builder.js');
(function() {
const builder = new WasmModuleBuilder();
builder.addMemory(1, 1);
builder.addFunction(undefined, kSig_i_ii)
.addBodyWithEnd([
kExprI32Const, 0,
kExprLocalGet, 0,
kExprI32StoreMem, 0, 0,
kExprI32Const, 4,
kExprLocalGet, 0,
kExprI32StoreMem, 0, 0,
kExprI32Const, 8,
kExprLocalGet, 0,
kExprI32StoreMem, 0, 0,
kExprI32Const, 12,
kExprLocalGet, 0,
kExprI32StoreMem, 0, 0,
// Memory now looks like (in bytes):
// [4, 0, 0, 0, 4, 0, 0, 0, 4, 0, 0, 0, 4, 0, 0, 0]
kExprI32Const, 0,
kSimdPrefix, kExprS128LoadMem, 0, 0,
kSimdPrefix, kExprI32x4ExtractLane, 0,
// load 32-bit from byte 4, then splat to all lanes.
kSimdPrefix, kExprS128Load32Splat, 0, 0,
kSimdPrefix, kExprI32x4ExtractLane, 3,
kExprEnd,
])
.exportAs('main');
const instance = builder.instantiate();
assertEquals(4, instance.exports.main(4));
})();