Commit f6facbb2 authored by rmcilroy's avatar rmcilroy Committed by Commit bot

[Crankshaft] Always check for stubs marked to not require an eager frame.

Previously only stubs built in the snapshot were checked for having an
eager frame. This caused a regression to creap in on ia32 for
RegExpConstructResultStub. Change test to always check.

Review-Url: https://codereview.chromium.org/2089673002
Cr-Commit-Position: refs/heads/master@{#37162}
parent f45c65ca
...@@ -2061,7 +2061,12 @@ HValue* CodeStubGraphBuilder<RegExpConstructResultStub>::BuildCodeStub() { ...@@ -2061,7 +2061,12 @@ HValue* CodeStubGraphBuilder<RegExpConstructResultStub>::BuildCodeStub() {
HValue* index = GetParameter(RegExpConstructResultStub::kIndex); HValue* index = GetParameter(RegExpConstructResultStub::kIndex);
HValue* input = GetParameter(RegExpConstructResultStub::kInput); HValue* input = GetParameter(RegExpConstructResultStub::kInput);
// TODO(turbofan): This codestub has regressed to need a frame on ia32 at some
// point and wasn't caught since it wasn't built in the snapshot. We should
// probably just replace with a TurboFan stub rather than fixing it.
#if !V8_TARGET_ARCH_IA32
info()->MarkMustNotHaveEagerFrame(); info()->MarkMustNotHaveEagerFrame();
#endif
return BuildRegExpConstructResult(length, index, input); return BuildRegExpConstructResult(length, index, input);
} }
......
...@@ -469,8 +469,7 @@ Handle<Code> LChunk::Codegen() { ...@@ -469,8 +469,7 @@ Handle<Code> LChunk::Codegen() {
jit_handler_data)); jit_handler_data));
CodeGenerator::PrintCode(code, info()); CodeGenerator::PrintCode(code, info());
DCHECK(!(info()->isolate()->serializer_enabled() && DCHECK(!(info()->GetMustNotHaveEagerFrame() &&
info()->GetMustNotHaveEagerFrame() &&
generator.NeedsEagerFrame())); generator.NeedsEagerFrame()));
return code; return code;
} }
......
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