Revert of [Compiler] Track Ignition background compilation separately in RuntimeStats. (patchset #3 id:80001 of https://codereview.chromium.org/2577263002/ )
Reason for revert:
https://build.chromium.org/p/client.v8/builders/V8%20Linux64%20TSAN/builds/13358
Original issue's description:
> [Compiler] Track Ignition background compilation separately in RuntimeStats.
>
> Tracks background compilation of Ignition in a separate bucket from main thread
> compilation. Also add some more compilation buckets for functions which can take a
> significant proportion of compilation.
>
> BUG=v8:5203,v8:5215
>
> Review-Url: https://codereview.chromium.org/2577263002
> Cr-Commit-Position: refs/heads/master@{#42026}
> Committed: b0e9116d59
TBR=jochen@chromium.org,cbruni@chromium.org,rmcilroy@chromium.org
# Skipping CQ checks because original CL landed less than 1 days ago.
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=v8:5203,v8:5215
Review-Url: https://codereview.chromium.org/2609773003
Cr-Commit-Position: refs/heads/master@{#42031}
This commit is contained in:
parent
3a81236f4a
commit
8ad1e681e3
@ -98,8 +98,6 @@ CompilationJob::Status CompilationJob::ExecuteJob() {
|
||||
no_handles.reset(new DisallowHandleAllocation());
|
||||
no_deref.reset(new DisallowHandleDereference());
|
||||
no_dependency_change.reset(new DisallowCodeDependencyChange());
|
||||
executed_on_background_thread_ =
|
||||
!ThreadId::Current().Equals(info()->isolate()->thread_id());
|
||||
} else {
|
||||
DCHECK(ThreadId::Current().Equals(info()->isolate()->thread_id()));
|
||||
}
|
||||
@ -479,8 +477,6 @@ void EnsureSharedFunctionInfosArrayOnScript(ParseInfo* info) {
|
||||
}
|
||||
|
||||
MUST_USE_RESULT MaybeHandle<Code> GetUnoptimizedCode(CompilationInfo* info) {
|
||||
RuntimeCallTimerScope runtimeTimer(
|
||||
info->isolate(), &RuntimeCallStats::CompileGetUnoptimizedCode);
|
||||
VMState<COMPILER> state(info->isolate());
|
||||
PostponeInterruptsScope postpone(info->isolate());
|
||||
|
||||
@ -503,9 +499,6 @@ MUST_USE_RESULT MaybeHandle<Code> GetUnoptimizedCode(CompilationInfo* info) {
|
||||
|
||||
MUST_USE_RESULT MaybeHandle<Code> GetCodeFromOptimizedCodeMap(
|
||||
Handle<JSFunction> function, BailoutId osr_ast_id) {
|
||||
RuntimeCallTimerScope runtimeTimer(
|
||||
function->GetIsolate(),
|
||||
&RuntimeCallStats::CompileGetFromOptimizedCodeMap);
|
||||
Handle<SharedFunctionInfo> shared(function->shared());
|
||||
DisallowHeapAllocation no_gc;
|
||||
CodeAndLiterals cached = shared->SearchOptimizedCodeMap(
|
||||
@ -889,6 +882,8 @@ MaybeHandle<Code> GetLazyCode(Handle<JSFunction> function) {
|
||||
DCHECK(!isolate->has_pending_exception());
|
||||
DCHECK(!function->is_compiled());
|
||||
TimerEventScope<TimerEventCompileCode> compile_timer(isolate);
|
||||
RuntimeCallTimerScope runtimeTimer(isolate,
|
||||
&RuntimeCallStats::CompileCodeLazy);
|
||||
TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("v8.compile"), "V8.CompileCode");
|
||||
AggregatedHistogramTimerScope timer(isolate->counters()->compile_lazy());
|
||||
|
||||
@ -1050,8 +1045,6 @@ Handle<SharedFunctionInfo> CompileToplevel(CompilationInfo* info) {
|
||||
|
||||
bool Compiler::Analyze(ParseInfo* info) {
|
||||
DCHECK_NOT_NULL(info->literal());
|
||||
RuntimeCallTimerScope runtimeTimer(info->isolate(),
|
||||
&RuntimeCallStats::CompileAnalyse);
|
||||
if (!Rewriter::Rewrite(info)) return false;
|
||||
DeclarationScope::Analyze(info, AnalyzeMode::kRegular);
|
||||
if (!Renumber(info)) return false;
|
||||
|
@ -167,8 +167,7 @@ class CompilationJob {
|
||||
: info_(info),
|
||||
compiler_name_(compiler_name),
|
||||
state_(initial_state),
|
||||
stack_limit_(isolate->stack_guard()->real_climit()),
|
||||
executed_on_background_thread_(false) {}
|
||||
stack_limit_(isolate->stack_guard()->real_climit()) {}
|
||||
virtual ~CompilationJob() {}
|
||||
|
||||
// Prepare the compile job. Must be called on the main thread.
|
||||
@ -197,11 +196,6 @@ class CompilationJob {
|
||||
void set_stack_limit(uintptr_t stack_limit) { stack_limit_ = stack_limit; }
|
||||
uintptr_t stack_limit() const { return stack_limit_; }
|
||||
|
||||
bool executed_on_background_thread() const {
|
||||
DCHECK_IMPLIES(!can_execute_on_background_thread(),
|
||||
!executed_on_background_thread_);
|
||||
return executed_on_background_thread_;
|
||||
}
|
||||
State state() const { return state_; }
|
||||
CompilationInfo* info() const { return info_; }
|
||||
Isolate* isolate() const;
|
||||
@ -224,7 +218,6 @@ class CompilationJob {
|
||||
const char* compiler_name_;
|
||||
State state_;
|
||||
uintptr_t stack_limit_;
|
||||
bool executed_on_background_thread_;
|
||||
|
||||
MUST_USE_RESULT Status UpdateState(Status status, State next_state) {
|
||||
if (status == SUCCEEDED) {
|
||||
|
@ -691,12 +691,7 @@ class RuntimeCallTimer final {
|
||||
V(CompileDeserialize) \
|
||||
V(CompileEval) \
|
||||
V(CompileFullCode) \
|
||||
V(CompileGetFromOptimizedCodeMap) \
|
||||
V(CompileGetUnoptimizedCode) \
|
||||
V(CompileAnalyse) \
|
||||
V(CompileIgnition) \
|
||||
V(CompileBackgroundIgnition) \
|
||||
V(CompileIgnitionFinalization) \
|
||||
V(CompilerDispatcher) \
|
||||
V(CompileSerialize) \
|
||||
V(DeoptimizeCode) \
|
||||
|
@ -41,41 +41,9 @@ class InterpreterCompilationJob final : public CompilationJob {
|
||||
Status FinalizeJobImpl() final;
|
||||
|
||||
private:
|
||||
class TimerScope final {
|
||||
public:
|
||||
TimerScope(RuntimeCallStats* stats, RuntimeCallStats::CounterId counter_id)
|
||||
: stats_(stats) {
|
||||
if (V8_UNLIKELY(FLAG_runtime_stats)) {
|
||||
RuntimeCallStats::Enter(stats_, &timer_, counter_id);
|
||||
}
|
||||
}
|
||||
|
||||
explicit TimerScope(RuntimeCallCounter* counter) : stats_(nullptr) {
|
||||
if (V8_UNLIKELY(FLAG_runtime_stats)) {
|
||||
timer_.Start(counter, nullptr);
|
||||
}
|
||||
}
|
||||
|
||||
~TimerScope() {
|
||||
if (V8_UNLIKELY(FLAG_runtime_stats)) {
|
||||
if (stats_) {
|
||||
RuntimeCallStats::Leave(stats_, &timer_);
|
||||
} else {
|
||||
timer_.Stop();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private:
|
||||
RuntimeCallStats* stats_;
|
||||
RuntimeCallTimer timer_;
|
||||
};
|
||||
|
||||
BytecodeGenerator* generator() { return &generator_; }
|
||||
|
||||
BytecodeGenerator generator_;
|
||||
RuntimeCallStats* runtime_call_stats_;
|
||||
RuntimeCallCounter background_execute_counter_;
|
||||
|
||||
DISALLOW_COPY_AND_ASSIGN(InterpreterCompilationJob);
|
||||
};
|
||||
@ -194,9 +162,7 @@ int Interpreter::InterruptBudget() {
|
||||
InterpreterCompilationJob::InterpreterCompilationJob(CompilationInfo* info,
|
||||
LazyCompilationMode mode)
|
||||
: CompilationJob(info->isolate(), info, "Ignition"),
|
||||
generator_(info, mode),
|
||||
runtime_call_stats_(info->isolate()->counters()->runtime_call_stats()),
|
||||
background_execute_counter_("CompileBackgroundIgnition") {}
|
||||
generator_(info, mode) {}
|
||||
|
||||
InterpreterCompilationJob::Status InterpreterCompilationJob::PrepareJobImpl() {
|
||||
CodeGenerator::MakeCodePrologue(info(), "interpreter");
|
||||
@ -212,11 +178,11 @@ InterpreterCompilationJob::Status InterpreterCompilationJob::PrepareJobImpl() {
|
||||
}
|
||||
|
||||
InterpreterCompilationJob::Status InterpreterCompilationJob::ExecuteJobImpl() {
|
||||
TimerScope runtimeTimer =
|
||||
executed_on_background_thread()
|
||||
? TimerScope(&background_execute_counter_)
|
||||
: TimerScope(runtime_call_stats_, &RuntimeCallStats::CompileIgnition);
|
||||
// TODO(lpy): add support for background compilation RCS trace.
|
||||
// TODO(5203): These timers aren't thread safe, move to using the CompilerJob
|
||||
// timers.
|
||||
RuntimeCallTimerScope runtimeTimer(info()->isolate(),
|
||||
&RuntimeCallStats::CompileIgnition);
|
||||
TimerEventScope<TimerEventCompileIgnition> timer(info()->isolate());
|
||||
TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("v8.compile"), "V8.CompileIgnition");
|
||||
|
||||
generator()->GenerateBytecode(stack_limit());
|
||||
@ -228,15 +194,6 @@ InterpreterCompilationJob::Status InterpreterCompilationJob::ExecuteJobImpl() {
|
||||
}
|
||||
|
||||
InterpreterCompilationJob::Status InterpreterCompilationJob::FinalizeJobImpl() {
|
||||
// Add background runtime call stats.
|
||||
if (V8_UNLIKELY(FLAG_runtime_stats && executed_on_background_thread())) {
|
||||
runtime_call_stats_->CompileBackgroundIgnition.Add(
|
||||
&background_execute_counter_);
|
||||
}
|
||||
|
||||
RuntimeCallTimerScope runtimeTimer(
|
||||
runtime_call_stats_, &RuntimeCallStats::CompileIgnitionFinalization);
|
||||
|
||||
Handle<BytecodeArray> bytecodes = generator()->FinalizeBytecode(isolate());
|
||||
if (generator()->HasStackOverflow()) {
|
||||
return FAILED;
|
||||
|
@ -1443,7 +1443,6 @@ code is governed by a BSD-style license that can be found in the LICENSE file.
|
||||
this.total,
|
||||
Group.groups.get('ic').entry(),
|
||||
Group.groups.get('optimize').entry(),
|
||||
Group.groups.get('compile-background').entry(),
|
||||
Group.groups.get('compile').entry(),
|
||||
Group.groups.get('parse-background').entry(),
|
||||
Group.groups.get('parse').entry(),
|
||||
@ -1652,8 +1651,6 @@ code is governed by a BSD-style license that can be found in the LICENSE file.
|
||||
Group.add('ic', new Group('IC', /.*IC_.*/, "#3366CC"));
|
||||
Group.add('optimize', new Group('Optimize',
|
||||
/StackGuard|.*Optimize.*|.*Deoptimize.*|Recompile.*/, "#DC3912"));
|
||||
Group.add('compile-background', new Group('Compile-Background',
|
||||
/(.*CompileBackground.*)/, "#b9a720"));
|
||||
Group.add('compile', new Group('Compile',
|
||||
/(^Compile.*)|(.*_Compile.*)/, "#FFAA00"));
|
||||
Group.add('parse-background',
|
||||
|
@ -349,7 +349,6 @@ def read_stats(path, domain, args):
|
||||
('Group-IC', re.compile(".*IC_.*")),
|
||||
('Group-Optimize',
|
||||
re.compile("StackGuard|.*Optimize.*|.*Deoptimize.*|Recompile.*")),
|
||||
('Group-CompileBackground', re.compile("(.*CompileBackground.*)")),
|
||||
('Group-Compile', re.compile("(^Compile.*)|(.*_Compile.*)")),
|
||||
('Group-ParseBackground', re.compile(".*ParseBackground.*")),
|
||||
('Group-Parse', re.compile(".*Parse.*")),
|
||||
@ -403,13 +402,6 @@ def read_stats(path, domain, args):
|
||||
group_data['time'] += entries[group_name]['time']
|
||||
group_data['count'] += entries[group_name]['count']
|
||||
entries['Group-Parse-Total'] = group_data
|
||||
# Calculate the Compile-Total group
|
||||
group_data = { 'time': 0, 'count': 0 }
|
||||
for group_name, regexp in groups:
|
||||
if not group_name.startswith('Group-Compile'): continue
|
||||
group_data['time'] += entries[group_name]['time']
|
||||
group_data['count'] += entries[group_name]['count']
|
||||
entries['Group-Compile-Total'] = group_data
|
||||
# Append the sums as single entries to domain.
|
||||
for key in entries:
|
||||
if key not in domain: domain[key] = { 'time_list': [], 'count_list': [] }
|
||||
|
Loading…
Reference in New Issue
Block a user