Commit 9d95db6f authored by loislo@chromium.org's avatar loislo@chromium.org

CPUProfiler: remove copy&paste from CodeCreateEvent.

This is the next patch on the way of simplifying profiler API.
It is extracting the common parts of the serialization process.

TEST=current test set
R=svenpanne@chromium.org

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

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@15276 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent f830fbea
...@@ -903,18 +903,39 @@ void Logger::SetterCallbackEvent(Name* name, Address entry_point) { ...@@ -903,18 +903,39 @@ void Logger::SetterCallbackEvent(Name* name, Address entry_point) {
} }
void Logger::CodeCreateEvent(LogEventsAndTags tag, void Logger::AppendName(Name* name) {
Code* code, if (name->IsString()) {
const char* comment) { name_buffer_->AppendString(String::cast(name));
if (!is_logging_code_events()) return; } else {
if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) { Symbol* symbol = Symbol::cast(name);
name_buffer_->AppendBytes("symbol(");
if (!symbol->name()->IsUndefined()) {
name_buffer_->AppendBytes("\"");
name_buffer_->AppendString(String::cast(symbol->name()));
name_buffer_->AppendBytes("\" ");
}
name_buffer_->AppendBytes("hash ");
name_buffer_->AppendHex(symbol->Hash());
name_buffer_->AppendByte(')');
}
}
void Logger::InitNameBuffer(LogEventsAndTags tag) {
name_buffer_->Reset(); name_buffer_->Reset();
name_buffer_->AppendBytes(kLogEventsNames[tag]); name_buffer_->AppendBytes(kLogEventsNames[tag]);
name_buffer_->AppendByte(':'); name_buffer_->AppendByte(':');
name_buffer_->AppendBytes(comment); }
}
void Logger::LogRecordedBuffer(Code* code, SharedFunctionInfo* shared) {
if (code_event_handler_ != NULL) { if (code_event_handler_ != NULL) {
IssueCodeAddedEvent(code, NULL, name_buffer_->get(), name_buffer_->size()); Script* script = shared && shared->script()->IsScript() ?
Script::cast(shared->script()) : NULL;
IssueCodeAddedEvent(code,
script,
name_buffer_->get(),
name_buffer_->size());
} }
if (!log_->IsEnabled()) return; if (!log_->IsEnabled()) return;
if (FLAG_ll_prof) { if (FLAG_ll_prof) {
...@@ -923,7 +944,20 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag, ...@@ -923,7 +944,20 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag,
if (Serializer::enabled()) { if (Serializer::enabled()) {
RegisterSnapshotCodeName(code, name_buffer_->get(), name_buffer_->size()); RegisterSnapshotCodeName(code, name_buffer_->get(), name_buffer_->size());
} }
if (!FLAG_log_code) return; }
void Logger::CodeCreateEvent(LogEventsAndTags tag,
Code* code,
const char* comment) {
if (!is_logging_code_events()) return;
if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) {
InitNameBuffer(tag);
name_buffer_->AppendBytes(comment);
LogRecordedBuffer(code, NULL);
}
if (!FLAG_log_code || !log_->IsEnabled()) return;
LogMessageBuilder msg(this); LogMessageBuilder msg(this);
msg.Append("%s,%s,%d,", msg.Append("%s,%s,%d,",
kLogEventsNames[CODE_CREATION_EVENT], kLogEventsNames[CODE_CREATION_EVENT],
...@@ -948,35 +982,12 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag, ...@@ -948,35 +982,12 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag,
Name* name) { Name* name) {
if (!is_logging_code_events()) return; if (!is_logging_code_events()) return;
if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) { if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) {
name_buffer_->Reset(); InitNameBuffer(tag);
name_buffer_->AppendBytes(kLogEventsNames[tag]); AppendName(name);
name_buffer_->AppendByte(':'); LogRecordedBuffer(code, NULL);
if (name->IsString()) {
name_buffer_->AppendString(String::cast(name));
} else {
Symbol* symbol = Symbol::cast(name);
name_buffer_->AppendBytes("symbol(");
if (!symbol->name()->IsUndefined()) {
name_buffer_->AppendBytes("\"");
name_buffer_->AppendString(String::cast(symbol->name()));
name_buffer_->AppendBytes("\" ");
}
name_buffer_->AppendBytes("hash ");
name_buffer_->AppendHex(symbol->Hash());
name_buffer_->AppendByte(')');
}
}
if (code_event_handler_ != NULL) {
IssueCodeAddedEvent(code, NULL, name_buffer_->get(), name_buffer_->size());
} }
if (!log_->IsEnabled()) return;
if (FLAG_ll_prof) { if (!FLAG_log_code || !log_->IsEnabled()) return;
LowLevelCodeCreateEvent(code, name_buffer_->get(), name_buffer_->size());
}
if (Serializer::enabled()) {
RegisterSnapshotCodeName(code, name_buffer_->get(), name_buffer_->size());
}
if (!FLAG_log_code) return;
LogMessageBuilder msg(this); LogMessageBuilder msg(this);
msg.Append("%s,%s,%d,", msg.Append("%s,%s,%d,",
kLogEventsNames[CODE_CREATION_EVENT], kLogEventsNames[CODE_CREATION_EVENT],
...@@ -1020,41 +1031,13 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag, ...@@ -1020,41 +1031,13 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag,
Name* name) { Name* name) {
if (!is_logging_code_events()) return; if (!is_logging_code_events()) return;
if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) { if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) {
name_buffer_->Reset(); InitNameBuffer(tag);
name_buffer_->AppendBytes(kLogEventsNames[tag]);
name_buffer_->AppendByte(':');
name_buffer_->AppendBytes(ComputeMarker(code)); name_buffer_->AppendBytes(ComputeMarker(code));
if (name->IsString()) { AppendName(name);
name_buffer_->AppendString(String::cast(name)); LogRecordedBuffer(code, shared);
} else {
Symbol* symbol = Symbol::cast(name);
name_buffer_->AppendBytes("symbol(");
if (!symbol->name()->IsUndefined()) {
name_buffer_->AppendBytes("\"");
name_buffer_->AppendString(String::cast(symbol->name()));
name_buffer_->AppendBytes("\" ");
}
name_buffer_->AppendBytes("hash ");
name_buffer_->AppendHex(symbol->Hash());
name_buffer_->AppendByte(')');
}
}
if (code_event_handler_ != NULL) {
Script* script =
shared->script()->IsScript() ? Script::cast(shared->script()) : NULL;
IssueCodeAddedEvent(code,
script,
name_buffer_->get(),
name_buffer_->size());
} }
if (!log_->IsEnabled()) return;
if (FLAG_ll_prof) { if (!FLAG_log_code || !log_->IsEnabled()) return;
LowLevelCodeCreateEvent(code, name_buffer_->get(), name_buffer_->size());
}
if (Serializer::enabled()) {
RegisterSnapshotCodeName(code, name_buffer_->get(), name_buffer_->size());
}
if (!FLAG_log_code) return;
if (code == Isolate::Current()->builtins()->builtin( if (code == Isolate::Current()->builtins()->builtin(
Builtins::kLazyCompile)) Builtins::kLazyCompile))
return; return;
...@@ -1098,9 +1081,7 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag, ...@@ -1098,9 +1081,7 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag,
Name* source, int line) { Name* source, int line) {
if (!is_logging_code_events()) return; if (!is_logging_code_events()) return;
if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) { if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) {
name_buffer_->Reset(); InitNameBuffer(tag);
name_buffer_->AppendBytes(kLogEventsNames[tag]);
name_buffer_->AppendByte(':');
name_buffer_->AppendBytes(ComputeMarker(code)); name_buffer_->AppendBytes(ComputeMarker(code));
name_buffer_->AppendString(shared->DebugName()); name_buffer_->AppendString(shared->DebugName());
name_buffer_->AppendByte(' '); name_buffer_->AppendByte(' ');
...@@ -1113,23 +1094,10 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag, ...@@ -1113,23 +1094,10 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag,
} }
name_buffer_->AppendByte(':'); name_buffer_->AppendByte(':');
name_buffer_->AppendInt(line); name_buffer_->AppendInt(line);
LogRecordedBuffer(code, shared);
} }
if (code_event_handler_ != NULL) {
Script* script = if (!FLAG_log_code || !log_->IsEnabled()) return;
shared->script()->IsScript() ? Script::cast(shared->script()) : NULL;
IssueCodeAddedEvent(code,
script,
name_buffer_->get(),
name_buffer_->size());
}
if (!log_->IsEnabled()) return;
if (FLAG_ll_prof) {
LowLevelCodeCreateEvent(code, name_buffer_->get(), name_buffer_->size());
}
if (Serializer::enabled()) {
RegisterSnapshotCodeName(code, name_buffer_->get(), name_buffer_->size());
}
if (!FLAG_log_code) return;
LogMessageBuilder msg(this); LogMessageBuilder msg(this);
SmartArrayPointer<char> name = SmartArrayPointer<char> name =
shared->DebugName()->ToCString(DISALLOW_NULLS, ROBUST_STRING_TRAVERSAL); shared->DebugName()->ToCString(DISALLOW_NULLS, ROBUST_STRING_TRAVERSAL);
...@@ -1164,22 +1132,12 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag, ...@@ -1164,22 +1132,12 @@ void Logger::CodeCreateEvent(LogEventsAndTags tag,
void Logger::CodeCreateEvent(LogEventsAndTags tag, Code* code, int args_count) { void Logger::CodeCreateEvent(LogEventsAndTags tag, Code* code, int args_count) {
if (!is_logging_code_events()) return; if (!is_logging_code_events()) return;
if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) { if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) {
name_buffer_->Reset(); InitNameBuffer(tag);
name_buffer_->AppendBytes(kLogEventsNames[tag]);
name_buffer_->AppendByte(':');
name_buffer_->AppendInt(args_count); name_buffer_->AppendInt(args_count);
LogRecordedBuffer(code, NULL);
} }
if (code_event_handler_ != NULL) {
IssueCodeAddedEvent(code, NULL, name_buffer_->get(), name_buffer_->size()); if (!FLAG_log_code || !log_->IsEnabled()) return;
}
if (!log_->IsEnabled()) return;
if (FLAG_ll_prof) {
LowLevelCodeCreateEvent(code, name_buffer_->get(), name_buffer_->size());
}
if (Serializer::enabled()) {
RegisterSnapshotCodeName(code, name_buffer_->get(), name_buffer_->size());
}
if (!FLAG_log_code) return;
LogMessageBuilder msg(this); LogMessageBuilder msg(this);
msg.Append("%s,%s,%d,", msg.Append("%s,%s,%d,",
kLogEventsNames[CODE_CREATION_EVENT], kLogEventsNames[CODE_CREATION_EVENT],
...@@ -1202,22 +1160,12 @@ void Logger::CodeMovingGCEvent() { ...@@ -1202,22 +1160,12 @@ void Logger::CodeMovingGCEvent() {
void Logger::RegExpCodeCreateEvent(Code* code, String* source) { void Logger::RegExpCodeCreateEvent(Code* code, String* source) {
if (!is_logging_code_events()) return; if (!is_logging_code_events()) return;
if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) { if (FLAG_ll_prof || Serializer::enabled() || code_event_handler_ != NULL) {
name_buffer_->Reset(); InitNameBuffer(REG_EXP_TAG);
name_buffer_->AppendBytes(kLogEventsNames[REG_EXP_TAG]);
name_buffer_->AppendByte(':');
name_buffer_->AppendString(source); name_buffer_->AppendString(source);
LogRecordedBuffer(code, NULL);
} }
if (code_event_handler_ != NULL) {
IssueCodeAddedEvent(code, NULL, name_buffer_->get(), name_buffer_->size()); if (!FLAG_log_code || !log_->IsEnabled()) return;
}
if (!log_->IsEnabled()) return;
if (FLAG_ll_prof) {
LowLevelCodeCreateEvent(code, name_buffer_->get(), name_buffer_->size());
}
if (Serializer::enabled()) {
RegisterSnapshotCodeName(code, name_buffer_->get(), name_buffer_->size());
}
if (!FLAG_log_code) return;
LogMessageBuilder msg(this); LogMessageBuilder msg(this);
msg.Append("%s,%s,-2,", msg.Append("%s,%s,-2,",
kLogEventsNames[CODE_CREATION_EVENT], kLogEventsNames[CODE_CREATION_EVENT],
......
...@@ -413,6 +413,15 @@ class Logger { ...@@ -413,6 +413,15 @@ class Logger {
// Used for logging stubs found in the snapshot. // Used for logging stubs found in the snapshot.
void LogCodeObject(Object* code_object); void LogCodeObject(Object* code_object);
// Helper method. It resets name_buffer_ and add tag name into it.
void InitNameBuffer(LogEventsAndTags tag);
// Helper method. It push recorded buffer into different handlers.
void LogRecordedBuffer(Code*, SharedFunctionInfo*);
// Helper method. It dumps name into name_buffer_.
void AppendName(Name* name);
// Emits general information about generated code. // Emits general information about generated code.
void LogCodeInfo(); void LogCodeInfo();
......
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