22d8d3be5a
It's no longer needed. Bug: v8:12552 Change-Id: I3522ab621001ee07ce7037888934279e4050dea9 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3484318 Auto-Submit: Jakob Gruber <jgruber@chromium.org> Reviewed-by: Leszek Swirski <leszeks@chromium.org> Commit-Queue: Leszek Swirski <leszeks@chromium.org> Cr-Commit-Position: refs/heads/main@{#79235}
28 lines
888 B
JavaScript
28 lines
888 B
JavaScript
// Copyright 2020 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 --opt
|
|
|
|
function make_closure() { return () => { return 42; } }
|
|
%PrepareFunctionForOptimization(make_closure);
|
|
%PrepareFunctionForOptimization(make_closure());
|
|
|
|
function inline_polymorphic(f) {
|
|
let answer = f();
|
|
%TurbofanStaticAssert(answer == 42);
|
|
}
|
|
|
|
%PrepareFunctionForOptimization(inline_polymorphic);
|
|
inline_polymorphic(make_closure());
|
|
inline_polymorphic(make_closure());
|
|
// Compile using top tier since we need value numbering phase for the
|
|
// TurbofanStaticAssert to deduce answer is 42 at compile time. In Turboprop
|
|
// this phase is disabled.
|
|
%OptimizeFunctionOnNextCall(inline_polymorphic);
|
|
inline_polymorphic(make_closure());
|
|
|
|
try {
|
|
inline_polymorphic(3);
|
|
} catch(e) {}
|