Commit c8ee3fb4 authored by Michael Starzinger's avatar Michael Starzinger Committed by Commit Bot

[deoptimizer] Fix bogus DCHECK in OptimizedFrame::Summarize.

R=jarin@chromium.org
TEST=mjsunit/regress/regress-crbug-751715
BUG=chromium:751715

Change-Id: Ibc5d2ce958b6f0c94b41926eb215e81d70833a9d
Reviewed-on: https://chromium-review.googlesource.com/598227Reviewed-by: 's avatarJaroslav Sevcik <jarin@chromium.org>
Commit-Queue: Michael Starzinger <mstarzinger@chromium.org>
Cr-Commit-Position: refs/heads/master@{#47108}
parent b68b63fc
...@@ -1431,10 +1431,10 @@ void OptimizedFrame::Summarize(List<FrameSummary>* frames, ...@@ -1431,10 +1431,10 @@ void OptimizedFrame::Summarize(List<FrameSummary>* frames,
is_constructor = false; is_constructor = false;
} else if (it->kind() == TranslatedFrame::kConstructStub) { } else if (it->kind() == TranslatedFrame::kConstructStub) {
// The next encountered JS frame will be marked as a constructor call. // The next encountered JS frame will be marked as a constructor call.
DCHECK(!is_constructor);
is_constructor = true; is_constructor = true;
} }
} }
DCHECK(!is_constructor);
} }
......
// 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
class Base {}
class Derived extends Base {
constructor() { super(); }
}
var proxy = new Proxy(Base, { get() {} });
assertDoesNotThrow(() => Reflect.construct(Derived, []));
assertThrows(() => Reflect.construct(Derived, [], proxy), TypeError);
assertThrows(() => Reflect.construct(Derived, [], proxy), TypeError);
%OptimizeFunctionOnNextCall(Derived);
assertThrows(() => Reflect.construct(Derived, [], proxy), TypeError);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment