aboutsummaryrefslogtreecommitdiff
path: root/deps/v8/test/mjsunit/regress/wasm/regress-919533.js
diff options
context:
space:
mode:
Diffstat (limited to 'deps/v8/test/mjsunit/regress/wasm/regress-919533.js')
-rw-r--r--deps/v8/test/mjsunit/regress/wasm/regress-919533.js25
1 files changed, 25 insertions, 0 deletions
diff --git a/deps/v8/test/mjsunit/regress/wasm/regress-919533.js b/deps/v8/test/mjsunit/regress/wasm/regress-919533.js
new file mode 100644
index 0000000000..58273f666b
--- /dev/null
+++ b/deps/v8/test/mjsunit/regress/wasm/regress-919533.js
@@ -0,0 +1,25 @@
+// 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.
+
+load('test/mjsunit/wasm/wasm-constants.js');
+load('test/mjsunit/wasm/wasm-module-builder.js');
+
+const builder = new WasmModuleBuilder();
+builder.addFunction(undefined, kSig_v_v).addBody([]);
+builder.addFunction(undefined, kSig_i_i)
+ .addBody([
+ kExprGetLocal, 0,
+ kExprGetLocal, 0,
+ // Stack now contains two copies of the first param register.
+ // Start a loop to create a merge point (values still in registers).
+ kExprLoop, kWasmStmt,
+ // The call spills all values.
+ kExprCallFunction, 0,
+ // Break to the loop. Now the spilled values need to be loaded back *into
+ // the same register*.
+ kExprBr, 0,
+ kExprEnd,
+ kExprDrop
+]);
+builder.instantiate();