55e8d61391
With bytecode flushing and lazy feedback allocation, we need to call %PrepareForOptimization before we call %OptimizeFunctionOnNextCall Bug: v8:8801, v8:8394 Change-Id: I1f84477a8cef27b4cff61b54daf6fe1a9e5f8e76 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1591775 Commit-Queue: Ross McIlroy <rmcilroy@chromium.org> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org> Cr-Commit-Position: refs/heads/master@{#61148}
49 lines
1.2 KiB
JavaScript
49 lines
1.2 KiB
JavaScript
// Copyright 2017 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 Baseline() {
|
|
let array = new Uint8Array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]);
|
|
|
|
let it = array[Symbol.iterator]();
|
|
assertEquals(0, it.next().value);
|
|
assertEquals(1, it.next().value);
|
|
assertEquals(2, it.next().value);
|
|
%ArrayBufferDetach(array.buffer);
|
|
it.next();
|
|
};
|
|
%NeverOptimizeFunction(Baseline);
|
|
|
|
assertThrows(Baseline, TypeError,
|
|
"Cannot perform Array Iterator.prototype.next on a neutered ArrayBuffer");
|
|
|
|
function Turbo(count = 10000) {
|
|
let array = Array(10000);
|
|
for (let i = 0; i < 10000; ++i) {
|
|
array[i] = 254;
|
|
}
|
|
array[5000] = 255;
|
|
array = new Uint8Array(array);
|
|
|
|
let sum = 0;
|
|
let it = array[Symbol.iterator]();
|
|
for (let i = 0; i < count; ++i) {
|
|
let result = it.next();
|
|
if (result.value === 255) {
|
|
%ArrayBufferDetach(array.buffer);
|
|
}
|
|
sum += result.value;
|
|
}
|
|
return sum;
|
|
}
|
|
|
|
%PrepareFunctionForOptimization(Turbo);
|
|
Turbo(10);
|
|
Turbo(10);
|
|
%OptimizeFunctionOnNextCall(Turbo);
|
|
|
|
assertThrows(Turbo, TypeError,
|
|
"Cannot perform Array Iterator.prototype.next on a neutered ArrayBuffer");
|