79a1468831
Changes: - Add possibility to define and emit all reference types. - Simplify function locals definition. - Change 'type' to 'type_index' where appropiate. Bug: v8:7748 Change-Id: Ie35a6204369e678298ee2ff2ec7c7793c5315c3e Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2390144 Commit-Queue: Manos Koukoutos <manoskouk@chromium.org> Reviewed-by: Thibaud Michaud <thibaudm@chromium.org> Cr-Commit-Position: refs/heads/master@{#69814}
39 lines
1.3 KiB
JavaScript
39 lines
1.3 KiB
JavaScript
// 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: --liftoff --nowasm-tier-up
|
|
//
|
|
// This test is intended to make Liftoff generate code that uses a very large
|
|
// stack frame, and then try to call another function (which would write to the
|
|
// stack pointer location). On Windows, large frames need extra code to touch
|
|
// every page in order, because the OS only leaves a small guard area for the
|
|
// stack, and trying to access past that area, even into memory that was
|
|
// intentionally reserved for this thread's stack, will crash the program.
|
|
|
|
load('test/mjsunit/wasm/wasm-module-builder.js');
|
|
|
|
var builder = new WasmModuleBuilder();
|
|
|
|
var func_idx = builder.addFunction('helper', kSig_i_v)
|
|
.addLocals(kWasmI32, 1)
|
|
.addBody([
|
|
kExprI32Const, 0x01,
|
|
]).index;
|
|
|
|
var large_function_body = [];
|
|
const num_temporaries = 16 * 1024;
|
|
for (let i = 0; i < num_temporaries; ++i) {
|
|
large_function_body.push(kExprCallFunction, func_idx);
|
|
}
|
|
for (let i = 1; i < num_temporaries; ++i) {
|
|
large_function_body.push(kExprI32Add);
|
|
}
|
|
|
|
builder.addFunction('test', kSig_i_v)
|
|
.addBody(large_function_body)
|
|
.exportFunc();
|
|
var module = builder.instantiate();
|
|
|
|
assertEquals(num_temporaries, module.exports.test());
|