Commit c66a3f95 authored by yangguo@chromium.org's avatar yangguo@chromium.org

Revert "Optimize function across closures."

This reverts r25102.

TBR=mvstanton@chromium.org

Review URL: https://codereview.chromium.org/699143002

Cr-Commit-Position: refs/heads/master@{#25104}
git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@25104 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent e6cfe350
...@@ -1533,67 +1533,47 @@ HValue* CodeStubGraphBuilder<FastNewClosureStub>::BuildCodeStub() { ...@@ -1533,67 +1533,47 @@ HValue* CodeStubGraphBuilder<FastNewClosureStub>::BuildCodeStub() {
AddIncrementCounter(counters->fast_new_closure_total()); AddIncrementCounter(counters->fast_new_closure_total());
IfBuilder optimize_now(this); // Create a new closure from the given function info in new space
HInstruction* compile_hint = Add<HLoadNamedField>( HValue* size = Add<HConstant>(JSFunction::kSize);
shared_info, static_cast<HValue*>(NULL), HObjectAccess::ForCompileHint()); HInstruction* js_function = Add<HAllocate>(size, HType::JSObject(),
HValue* hint_mask = Add<HConstant>( NOT_TENURED, JS_FUNCTION_TYPE);
static_cast<int32_t>(1 << SharedFunctionInfo::kOptimizeNextClosure));
HInstruction* optimize = int map_index = Context::FunctionMapIndex(casted_stub()->strict_mode(),
AddUncasted<HBitwise>(Token::BIT_AND, compile_hint, hint_mask); casted_stub()->kind());
optimize_now.If<HCompareNumericAndBranch>(optimize, hint_mask, Token::EQ);
optimize_now.Then(); // Compute the function map in the current native context and set that
{ // as the map of the allocated object.
Add<HPushArguments>(context(), shared_info, graph()->GetConstantFalse()); HInstruction* native_context = BuildGetNativeContext();
Push(Add<HCallRuntime>(isolate()->factory()->empty_string(), HInstruction* map_slot_value = Add<HLoadNamedField>(
Runtime::FunctionForId(Runtime::kNewClosure), 3)); native_context, static_cast<HValue*>(NULL),
} HObjectAccess::ForContextSlot(map_index));
optimize_now.Else(); Add<HStoreNamedField>(js_function, HObjectAccess::ForMap(), map_slot_value);
{
// Create a new closure from the given function info in new space // Initialize the rest of the function.
HValue* size = Add<HConstant>(JSFunction::kSize); Add<HStoreNamedField>(js_function, HObjectAccess::ForPropertiesPointer(),
HInstruction* js_function = empty_fixed_array);
Add<HAllocate>(size, HType::JSObject(), NOT_TENURED, JS_FUNCTION_TYPE); Add<HStoreNamedField>(js_function, HObjectAccess::ForElementsPointer(),
empty_fixed_array);
int map_index = Context::FunctionMapIndex(casted_stub()->strict_mode(), Add<HStoreNamedField>(js_function, HObjectAccess::ForLiteralsPointer(),
casted_stub()->kind()); empty_fixed_array);
Add<HStoreNamedField>(js_function, HObjectAccess::ForPrototypeOrInitialMap(),
// Compute the function map in the current native context and set that graph()->GetConstantHole());
// as the map of the allocated object. Add<HStoreNamedField>(js_function,
HInstruction* native_context = BuildGetNativeContext(); HObjectAccess::ForSharedFunctionInfoPointer(),
HInstruction* map_slot_value = shared_info);
Add<HLoadNamedField>(native_context, static_cast<HValue*>(NULL), Add<HStoreNamedField>(js_function, HObjectAccess::ForFunctionContextPointer(),
HObjectAccess::ForContextSlot(map_index)); context());
Add<HStoreNamedField>(js_function, HObjectAccess::ForMap(), map_slot_value);
// Initialize the code pointer in the function to be the one
// Initialize the rest of the function. // found in the shared function info object.
Add<HStoreNamedField>(js_function, HObjectAccess::ForPropertiesPointer(), // But first check if there is an optimized version for our context.
empty_fixed_array); if (FLAG_cache_optimized_code) {
Add<HStoreNamedField>(js_function, HObjectAccess::ForElementsPointer(), BuildInstallFromOptimizedCodeMap(js_function, shared_info, native_context);
empty_fixed_array); } else {
Add<HStoreNamedField>(js_function, HObjectAccess::ForLiteralsPointer(), BuildInstallCode(js_function, shared_info);
empty_fixed_array);
Add<HStoreNamedField>(js_function,
HObjectAccess::ForPrototypeOrInitialMap(),
graph()->GetConstantHole());
Add<HStoreNamedField>(js_function,
HObjectAccess::ForSharedFunctionInfoPointer(),
shared_info);
Add<HStoreNamedField>(
js_function, HObjectAccess::ForFunctionContextPointer(), context());
// Initialize the code pointer in the function to be the one
// found in the shared function info object.
// But first check if there is an optimized version for our context.
if (FLAG_cache_optimized_code) {
BuildInstallFromOptimizedCodeMap(js_function, shared_info,
native_context);
} else {
BuildInstallCode(js_function, shared_info);
}
Push(js_function);
} }
optimize_now.End();
return Pop(); return js_function;
} }
......
...@@ -1361,7 +1361,6 @@ MaybeHandle<Code> Compiler::GetOptimizedCode(Handle<JSFunction> function, ...@@ -1361,7 +1361,6 @@ MaybeHandle<Code> Compiler::GetOptimizedCode(Handle<JSFunction> function,
PostponeInterruptsScope postpone(isolate); PostponeInterruptsScope postpone(isolate);
Handle<SharedFunctionInfo> shared = info->shared_info(); Handle<SharedFunctionInfo> shared = info->shared_info();
shared->set_optimize_next_closure(false);
if (shared->code()->kind() != Code::FUNCTION || if (shared->code()->kind() != Code::FUNCTION ||
ScopeInfo::Empty(isolate) == shared->scope_info()) { ScopeInfo::Empty(isolate) == shared->scope_info()) {
// The function was never compiled. Compile it unoptimized first. // The function was never compiled. Compile it unoptimized first.
......
...@@ -1358,14 +1358,6 @@ Handle<JSObject> Factory::NewFunctionPrototype(Handle<JSFunction> function) { ...@@ -1358,14 +1358,6 @@ Handle<JSObject> Factory::NewFunctionPrototype(Handle<JSFunction> function) {
} }
static bool ShouldOptimizeNewClosure(Isolate* isolate,
Handle<SharedFunctionInfo> info) {
return isolate->use_crankshaft() && !info->is_toplevel() &&
info->allows_lazy_compilation() && !info->optimization_disabled() &&
!isolate->DebuggerHasBreakPoints();
}
Handle<JSFunction> Factory::NewFunctionFromSharedFunctionInfo( Handle<JSFunction> Factory::NewFunctionFromSharedFunctionInfo(
Handle<SharedFunctionInfo> info, Handle<SharedFunctionInfo> info,
Handle<Context> context, Handle<Context> context,
...@@ -1403,15 +1395,14 @@ Handle<JSFunction> Factory::NewFunctionFromSharedFunctionInfo( ...@@ -1403,15 +1395,14 @@ Handle<JSFunction> Factory::NewFunctionFromSharedFunctionInfo(
return result; return result;
} }
if (FLAG_always_opt && ShouldOptimizeNewClosure(isolate(), info)) { if (isolate()->use_crankshaft() &&
FLAG_always_opt &&
result->is_compiled() &&
!info->is_toplevel() &&
info->allows_lazy_compilation() &&
!info->optimization_disabled() &&
!isolate()->DebuggerHasBreakPoints()) {
result->MarkForOptimization(); result->MarkForOptimization();
} else if (info->optimize_next_closure() &&
ShouldOptimizeNewClosure(isolate(), info)) {
if (isolate()->concurrent_recompilation_enabled()) {
result->MarkForConcurrentOptimization();
} else {
result->MarkForOptimization();
}
} }
return result; return result;
} }
......
...@@ -6121,11 +6121,6 @@ class HObjectAccess FINAL { ...@@ -6121,11 +6121,6 @@ class HObjectAccess FINAL {
SharedFunctionInfo::kOptimizedCodeMapOffset); SharedFunctionInfo::kOptimizedCodeMapOffset);
} }
static HObjectAccess ForCompileHint() {
return HObjectAccess(kInobject, SharedFunctionInfo::kCompilerHintsOffset,
Representation::Smi());
}
static HObjectAccess ForFunctionContextPointer() { static HObjectAccess ForFunctionContextPointer() {
return HObjectAccess(kInobject, JSFunction::kContextOffset); return HObjectAccess(kInobject, JSFunction::kContextOffset);
} }
......
...@@ -5493,9 +5493,9 @@ BOOL_ACCESSORS(SharedFunctionInfo, start_position_and_type, is_expression, ...@@ -5493,9 +5493,9 @@ BOOL_ACCESSORS(SharedFunctionInfo, start_position_and_type, is_expression,
BOOL_ACCESSORS(SharedFunctionInfo, start_position_and_type, is_toplevel, BOOL_ACCESSORS(SharedFunctionInfo, start_position_and_type, is_toplevel,
kIsTopLevelBit) kIsTopLevelBit)
BOOL_ACCESSORS(SharedFunctionInfo, compiler_hints, optimize_next_closure, BOOL_ACCESSORS(SharedFunctionInfo,
kOptimizeNextClosure) compiler_hints,
BOOL_ACCESSORS(SharedFunctionInfo, compiler_hints, allows_lazy_compilation, allows_lazy_compilation,
kAllowLazyCompilation) kAllowLazyCompilation)
BOOL_ACCESSORS(SharedFunctionInfo, BOOL_ACCESSORS(SharedFunctionInfo,
compiler_hints, compiler_hints,
......
...@@ -6783,8 +6783,6 @@ class SharedFunctionInfo: public HeapObject { ...@@ -6783,8 +6783,6 @@ class SharedFunctionInfo: public HeapObject {
inline int ic_age(); inline int ic_age();
inline void set_ic_age(int age); inline void set_ic_age(int age);
DECL_BOOLEAN_ACCESSORS(optimize_next_closure)
// Indicates if this function can be lazy compiled. // Indicates if this function can be lazy compiled.
// This is used to determine if we can safely flush code from a function // This is used to determine if we can safely flush code from a function
// when doing GC if we expect that the function will no longer be used. // when doing GC if we expect that the function will no longer be used.
...@@ -7075,7 +7073,6 @@ class SharedFunctionInfo: public HeapObject { ...@@ -7075,7 +7073,6 @@ class SharedFunctionInfo: public HeapObject {
enum CompilerHints { enum CompilerHints {
kAllowLazyCompilation, kAllowLazyCompilation,
kAllowLazyCompilationWithoutContext, kAllowLazyCompilationWithoutContext,
kOptimizeNextClosure,
kOptimizationDisabled, kOptimizationDisabled,
kStrictModeFunction, kStrictModeFunction,
kUsesArguments, kUsesArguments,
......
...@@ -106,7 +106,7 @@ void RuntimeProfiler::Optimize(JSFunction* function, const char* reason) { ...@@ -106,7 +106,7 @@ void RuntimeProfiler::Optimize(JSFunction* function, const char* reason) {
PrintF("]\n"); PrintF("]\n");
} }
function->shared()->set_optimize_next_closure(true);
if (isolate_->concurrent_recompilation_enabled() && if (isolate_->concurrent_recompilation_enabled() &&
!isolate_->bootstrapper()->IsActive()) { !isolate_->bootstrapper()->IsActive()) {
if (isolate_->concurrent_osr_enabled() && if (isolate_->concurrent_osr_enabled() &&
......
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