8d921ca7f3
This removes the --turbo flag and solely relies on the filter pattern provided via --turbo-filter when deciding whether to use TurboFan. Note that disabling optimization wholesale can still be done with --no-opt, which should be used in favor of --no-turbo everywhere. Also note that this contains semantic changes to the TurboFan activation criteria. We respect the filter pattern more stringently and no longer activate TurboFan just because the source contains patterns forcing use of Ignition via {AstNumberingVisitor::DisableFullCodegenAndCrankshaft}. R=rmcilroy@chromium.org BUG=v8:6408 Change-Id: I0c855f6a62350eb62283a3431c8cc1baa750950e Reviewed-on: https://chromium-review.googlesource.com/528121 Reviewed-by: Jaroslav Sevcik <jarin@chromium.org> Reviewed-by: Michael Stanton <mvstanton@chromium.org> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org> Commit-Queue: Michael Starzinger <mstarzinger@chromium.org> Cr-Commit-Position: refs/heads/master@{#46167}
88 lines
3.1 KiB
JavaScript
88 lines
3.1 KiB
JavaScript
// Copyright 2013 the V8 project authors. All rights reserved.
|
|
// Copyright (C) 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights reserved.
|
|
//
|
|
// Redistribution and use in source and binary forms, with or without
|
|
// modification, are permitted provided that the following conditions
|
|
// are met:
|
|
// 1. Redistributions of source code must retain the above copyright
|
|
// notice, this list of conditions and the following disclaimer.
|
|
// 2. Redistributions in binary form must reproduce the above copyright
|
|
// notice, this list of conditions and the following disclaimer in the
|
|
// documentation and/or other materials provided with the distribution.
|
|
//
|
|
// THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND ANY
|
|
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
// DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY
|
|
// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
// Flags: --allow-natives-syntax
|
|
|
|
var stackOverflowIn20ArgFn = false, gotRegexCatch = false, gotDateCatch = false;
|
|
|
|
function funcWith20Args(arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8,
|
|
arg9, arg10, arg11, arg12, arg13, arg14, arg15,
|
|
arg16, arg17, arg18, arg19, arg20)
|
|
{
|
|
assertUnreachable("shouldn't arrive in non-inlined 20 arg function after stack overflow");
|
|
}
|
|
|
|
// If we should run with TurboFan, then make sure {funcWith20Args} does
|
|
// not get inlined.
|
|
%NeverOptimizeFunction(funcWith20Args);
|
|
|
|
function mutual_recursion_1()
|
|
{
|
|
try {
|
|
mutual_recursion_2();
|
|
} catch (err) {
|
|
// Should get here because of stack overflow,
|
|
// now cause a stack overflow exception due to arity processing
|
|
try {
|
|
var dummy = new RegExp('a|b|c');
|
|
} catch(err) {
|
|
// (1) It is dependent on the stack size if we arrive here, in (2) or
|
|
// both.
|
|
gotRegexCatch = true;
|
|
}
|
|
|
|
try {
|
|
funcWith20Args(1, 2, 3);
|
|
} catch (err2) {
|
|
stackOverflowIn20ArgFn = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
function mutual_recursion_2()
|
|
{
|
|
try {
|
|
var dummy = new Date();
|
|
} catch(err) {
|
|
// (2) It is dependent on the stack size if we arrive here, in (1) or
|
|
// both.
|
|
gotDateCatch = true;
|
|
}
|
|
|
|
try {
|
|
mutual_recursion_1();
|
|
} catch (err) {
|
|
// Should get here because of stack overflow,
|
|
// now cause a stack overflow exception due to arity processing
|
|
try {
|
|
funcWith20Args(1, 2, 3, 4, 5, 6);
|
|
} catch (err2) {
|
|
stackOverflowIn20ArgFn = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
mutual_recursion_1();
|
|
|
|
assertTrue(stackOverflowIn20ArgFn);
|