v8/test/mjsunit/regress/regress-996161.js
Mythri A ecf178a159 Fix EmitGenericPropertyStore to bailout on stores to TypedArrays
We don't handle all cases for stores to typed arrays in the builtins
related to storing a property. Bailout to runtime when storing into
a typed array if the property is not found on the object.

Bug: chromium:996161
Change-Id: I684c7c4f526b15cdfb5bfe3fd23218910486a59e
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1789396
Commit-Queue: Mythri Alle <mythria@chromium.org>
Reviewed-by: Jakob Kummerow <jkummerow@chromium.org>
Cr-Commit-Position: refs/heads/master@{#63639}
2019-09-10 10:13:38 +00:00

44 lines
988 B
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: --allow-natives-syntax
function checkOwnProperties(v, count) {
var properties = Object.getOwnPropertyNames(v);
assertEquals(properties.length, count);
}
function testStoreNoFeedback() {
arr = new Int32Array(10);
function f(a) { a["-1"] = 15; }
for (var i = 0; i < 3; i++) {
arr.__defineGetter__("x", function() { });
checkOwnProperties(arr, 11);
f(arr);
}
}
testStoreNoFeedback();
function testStoreGeneric() {
arr = new Int32Array(10);
var index = "-1";
function f1(a) { a[index] = 15; }
%EnsureFeedbackVectorForFunction(f1);
// Make a[index] in f1 megamorphic
f1({a: 1});
f1({b: 1});
f1({c: 1});
f1({d: 1});
for (var i = 0; i < 3; i++) {
arr.__defineGetter__("x", function() { });
checkOwnProperties(arr, 11);
f1(arr);
}
}
testStoreGeneric();