Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(244)

Side by Side Diff: src/parsing/parser.cc

Issue 2187693002: [Tracing] Embed V8 runtime call stats into tracing. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2012 the V8 project authors. All rights reserved. 1 // Copyright 2012 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "src/parsing/parser.h" 5 #include "src/parsing/parser.h"
6 6
7 #include <memory> 7 #include <memory>
8 8
9 #include "src/api.h" 9 #include "src/api.h"
10 #include "src/ast/ast.h" 10 #include "src/ast/ast.h"
(...skipping 849 matching lines...) Expand 10 before | Expand all | Expand 10 after
860 FunctionLiteral* Parser::ParseProgram(Isolate* isolate, ParseInfo* info) { 860 FunctionLiteral* Parser::ParseProgram(Isolate* isolate, ParseInfo* info) {
861 // TODO(bmeurer): We temporarily need to pass allow_nesting = true here, 861 // TODO(bmeurer): We temporarily need to pass allow_nesting = true here,
862 // see comment for HistogramTimerScope class. 862 // see comment for HistogramTimerScope class.
863 863
864 // It's OK to use the Isolate & counters here, since this function is only 864 // It's OK to use the Isolate & counters here, since this function is only
865 // called in the main thread. 865 // called in the main thread.
866 DCHECK(parsing_on_main_thread_); 866 DCHECK(parsing_on_main_thread_);
867 867
868 HistogramTimerScope timer_scope(isolate->counters()->parse(), true); 868 HistogramTimerScope timer_scope(isolate->counters()->parse(), true);
869 RuntimeCallTimerScope runtime_timer(isolate, &RuntimeCallStats::Parse); 869 RuntimeCallTimerScope runtime_timer(isolate, &RuntimeCallStats::Parse);
870 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("v8.compile"), "V8.Parse"); 870 TRACE_EVENT_RUNTIME_CALL_STATS_TRACING_SCOPED(
871 isolate, &tracing::TraceEventStatsTable::Parse);
871 Handle<String> source(String::cast(info->script()->source())); 872 Handle<String> source(String::cast(info->script()->source()));
872 isolate->counters()->total_parse_size()->Increment(source->length()); 873 isolate->counters()->total_parse_size()->Increment(source->length());
873 base::ElapsedTimer timer; 874 base::ElapsedTimer timer;
874 if (FLAG_trace_parse) { 875 if (FLAG_trace_parse) {
875 timer.Start(); 876 timer.Start();
876 } 877 }
877 fni_ = new (zone()) FuncNameInferrer(ast_value_factory(), zone()); 878 fni_ = new (zone()) FuncNameInferrer(ast_value_factory(), zone());
878 879
879 // Initialize parser state. 880 // Initialize parser state.
880 CompleteParserRecorder recorder; 881 CompleteParserRecorder recorder;
(...skipping 149 matching lines...) Expand 10 before | Expand all | Expand 10 after
1030 return result; 1031 return result;
1031 } 1032 }
1032 1033
1033 1034
1034 FunctionLiteral* Parser::ParseLazy(Isolate* isolate, ParseInfo* info) { 1035 FunctionLiteral* Parser::ParseLazy(Isolate* isolate, ParseInfo* info) {
1035 // It's OK to use the Isolate & counters here, since this function is only 1036 // It's OK to use the Isolate & counters here, since this function is only
1036 // called in the main thread. 1037 // called in the main thread.
1037 DCHECK(parsing_on_main_thread_); 1038 DCHECK(parsing_on_main_thread_);
1038 RuntimeCallTimerScope runtime_timer(isolate, &RuntimeCallStats::ParseLazy); 1039 RuntimeCallTimerScope runtime_timer(isolate, &RuntimeCallStats::ParseLazy);
1039 HistogramTimerScope timer_scope(isolate->counters()->parse_lazy()); 1040 HistogramTimerScope timer_scope(isolate->counters()->parse_lazy());
1040 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("v8.compile"), "V8.ParseLazy"); 1041 TRACE_EVENT_RUNTIME_CALL_STATS_TRACING_SCOPED(
1042 isolate, &tracing::TraceEventStatsTable::ParseLazy);
1041 Handle<String> source(String::cast(info->script()->source())); 1043 Handle<String> source(String::cast(info->script()->source()));
1042 isolate->counters()->total_parse_size()->Increment(source->length()); 1044 isolate->counters()->total_parse_size()->Increment(source->length());
1043 base::ElapsedTimer timer; 1045 base::ElapsedTimer timer;
1044 if (FLAG_trace_parse) { 1046 if (FLAG_trace_parse) {
1045 timer.Start(); 1047 timer.Start();
1046 } 1048 }
1047 Handle<SharedFunctionInfo> shared_info = info->shared_info(); 1049 Handle<SharedFunctionInfo> shared_info = info->shared_info();
1048 1050
1049 // Initialize parser state. 1051 // Initialize parser state.
1050 source = String::Flatten(source); 1052 source = String::Flatten(source);
(...skipping 6043 matching lines...) Expand 10 before | Expand all | Expand 10 after
7094 node->Print(Isolate::Current()); 7096 node->Print(Isolate::Current());
7095 } 7097 }
7096 #endif // DEBUG 7098 #endif // DEBUG
7097 7099
7098 #undef CHECK_OK 7100 #undef CHECK_OK
7099 #undef CHECK_OK_VOID 7101 #undef CHECK_OK_VOID
7100 #undef CHECK_FAILED 7102 #undef CHECK_FAILED
7101 7103
7102 } // namespace internal 7104 } // namespace internal
7103 } // namespace v8 7105 } // namespace v8
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698