66d5cebb49
This reverts commit 9f902b7483
.
Reason for revert: Reverting due to various fuzzing issues (numfuzz issues listed in original CL comments, ochang fuzzer in https://bugs.chromium.org/p/chromium/issues/detail?id=1299418)
Original change's description:
> [turbofan] Making OSR concurrent
>
> ... to reduce compilation overhead on the main thread for OSR
>
> Bug: v8:12161
> Change-Id: I54ca5fa6201405daf92dac9cf51d5de4b46577b3
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3369361
> Reviewed-by: Jakob Gruber <jgruber@chromium.org>
> Reviewed-by: Leszek Swirski <leszeks@chromium.org>
> Commit-Queue: Fanchen Kong <fanchen.kong@intel.com>
> Cr-Commit-Position: refs/heads/main@{#79188}
Bug: v8:12161
Change-Id: Id6f6086517cd77fb1aa60b20fd03528b8e2ca686
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3477104
Auto-Submit: Leszek Swirski <leszeks@chromium.org>
Bot-Commit: Rubber Stamper <rubber-stamper@appspot.gserviceaccount.com>
Owners-Override: Leszek Swirski <leszeks@chromium.org>
Commit-Queue: Leszek Swirski <leszeks@chromium.org>
Cr-Commit-Position: refs/heads/main@{#79194}
82 lines
1.9 KiB
JavaScript
82 lines
1.9 KiB
JavaScript
// Copyright 2018 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.
|
|
|
|
Debug = debug.Debug
|
|
|
|
// Test that the side-effect check is not bypassed in optimized code.
|
|
|
|
var exception = null;
|
|
var counter = 0;
|
|
|
|
function f1() {
|
|
counter++;
|
|
}
|
|
|
|
function wrapper1() {
|
|
for (var i = 0; i < 4; i++) {
|
|
// Get this function optimized before calling to increment.
|
|
// Check that that call performs the necessary side-effect checks.
|
|
%OptimizeOsr();
|
|
%PrepareFunctionForOptimization(wrapper1);
|
|
}
|
|
f1();
|
|
}
|
|
%PrepareFunctionForOptimization(wrapper1);
|
|
|
|
function f2() {
|
|
counter++;
|
|
}
|
|
|
|
function wrapper2(call) {
|
|
if (call) f2();
|
|
}
|
|
|
|
function listener(event, exec_state, event_data, data) {
|
|
if (event != Debug.DebugEvent.Break) return;
|
|
try {
|
|
function success(expectation, source) {
|
|
assertEquals(expectation,
|
|
exec_state.frame(0).evaluate(source, true).value());
|
|
}
|
|
function fail(source) {
|
|
assertThrows(() => exec_state.frame(0).evaluate(source, true),
|
|
EvalError);
|
|
}
|
|
wrapper1();
|
|
wrapper1();
|
|
fail("wrapper1()");
|
|
|
|
%PrepareFunctionForOptimization(wrapper2);
|
|
wrapper2(true);
|
|
wrapper2(false);
|
|
wrapper2(true);
|
|
%OptimizeFunctionOnNextCall(wrapper2);
|
|
wrapper2(false);
|
|
fail("wrapper2(true)");
|
|
fail("%PrepareFunctionForOptimization(wrapper2); "+
|
|
"%OptimizeFunctionOnNextCall(wrapper2); wrapper2(true)");
|
|
|
|
%PrepareFunctionForOptimization(wrapper2);
|
|
%DisableOptimizationFinalization();
|
|
%OptimizeFunctionOnNextCall(wrapper2, "concurrent");
|
|
wrapper2(false);
|
|
fail("%FinalizeOptimization();" +
|
|
"wrapper2(true);");
|
|
} catch (e) {
|
|
exception = e;
|
|
print(e, e.stack);
|
|
}
|
|
};
|
|
|
|
// Add the debug event listener.
|
|
Debug.setListener(listener);
|
|
|
|
function f() {
|
|
debugger;
|
|
};
|
|
|
|
f();
|
|
|
|
assertNull(exception);
|