v8/test/mjsunit/compiler/truncating-store-deopt.js
jarin 0cde253c9e [turbofan] Support lazy deopt for truncating store to a typed array.
The change introduces a second frame state (for the state before
the operation) for the StoreProperty nodes. If the store writes
into a typed array, the frame state is used for lazy deopt from
the to-number conversion that is performed by the store.

BUG=v8:3963
LOG=n
R=bmeurer@chromium.org

Review URL: https://codereview.chromium.org/997983004

Cr-Commit-Position: refs/heads/master@{#27285}
2015-03-19 05:46:30 +00:00

29 lines
681 B
JavaScript

// Copyright 2015 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: --allow-natives-syntax
function g(a, b, c) {
return a + b + c;
}
var asm = (function Module(global, env, buffer) {
"use asm";
var i32 = new global.Int32Array(buffer);
// This is not valid asm.js, but we should still generate correct code.
function store(x) {
return g(1, i32[0] = x, 2);
}
return { store: store };
})({
"Int32Array": Int32Array
}, {}, new ArrayBuffer(64 * 1024));
var o = { toString : function() { %DeoptimizeFunction(asm.store); return "1"; } }
asm.store(o);