9f13a30034
The kContextRegister can alias allocated registers - when setting it, take care not to unintentionally clobber. Bug: v8:7700 Change-Id: I0635d334fb14fa15540582a4873d4186fffa2199 Fixed: chromium:1363450 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3897634 Auto-Submit: Jakob Linke <jgruber@chromium.org> Reviewed-by: Leszek Swirski <leszeks@chromium.org> Commit-Queue: Leszek Swirski <leszeks@chromium.org> Cr-Commit-Position: refs/heads/main@{#83212}
23 lines
603 B
JavaScript
23 lines
603 B
JavaScript
// Copyright 2022 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
|
|
|
|
class C extends (class {}) {
|
|
constructor() {
|
|
var f = () => {
|
|
try { C.__proto__ = null; } catch {}
|
|
try { super(); } catch {}
|
|
};
|
|
%PrepareFunctionForOptimization(f);
|
|
f();
|
|
%OptimizeMaglevOnNextCall(f);
|
|
}
|
|
}
|
|
try { new C(); } catch {}
|
|
// The next 2 calls deopt before reaching relevant bits.
|
|
try { new C(); } catch {}
|
|
try { new C(); } catch {}
|
|
try { new C(); } catch {}
|