OLD | NEW |
1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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/log.h" | 5 #include "src/log.h" |
6 | 6 |
7 #include <cstdarg> | 7 #include <cstdarg> |
8 #include <memory> | 8 #include <memory> |
9 #include <sstream> | 9 #include <sstream> |
10 | 10 |
11 #include "src/bailout-reason.h" | 11 #include "src/bailout-reason.h" |
12 #include "src/base/platform/platform.h" | 12 #include "src/base/platform/platform.h" |
13 #include "src/bootstrapper.h" | 13 #include "src/bootstrapper.h" |
14 #include "src/code-stubs.h" | 14 #include "src/code-stubs.h" |
15 #include "src/counters.h" | 15 #include "src/counters.h" |
16 #include "src/deoptimizer.h" | 16 #include "src/deoptimizer.h" |
17 #include "src/global-handles.h" | 17 #include "src/global-handles.h" |
18 #include "src/interpreter/bytecodes.h" | 18 #include "src/interpreter/bytecodes.h" |
19 #include "src/interpreter/interpreter.h" | 19 #include "src/interpreter/interpreter.h" |
20 #include "src/libsampler/sampler.h" | 20 #include "src/libsampler/sampler.h" |
21 #include "src/log-inl.h" | 21 #include "src/log-inl.h" |
22 #include "src/log-utils.h" | 22 #include "src/log-utils.h" |
23 #include "src/macro-assembler.h" | 23 #include "src/macro-assembler.h" |
24 #include "src/perf-jit.h" | 24 #include "src/perf-jit.h" |
25 #include "src/profiler/profiler-listener.h" | 25 #include "src/profiler/profiler-listener.h" |
26 #include "src/profiler/tick-sample.h" | 26 #include "src/profiler/tick-sample.h" |
27 #include "src/runtime-profiler.h" | 27 #include "src/runtime-profiler.h" |
| 28 #include "src/source-position-table.h" |
28 #include "src/string-stream.h" | 29 #include "src/string-stream.h" |
29 #include "src/vm-state-inl.h" | 30 #include "src/vm-state-inl.h" |
30 | 31 |
31 namespace v8 { | 32 namespace v8 { |
32 namespace internal { | 33 namespace internal { |
33 | 34 |
34 #define DECLARE_EVENT(ignore1, name) name, | 35 #define DECLARE_EVENT(ignore1, name) name, |
35 static const char* kLogEventsNames[CodeEventListener::NUMBER_OF_LOG_EVENTS] = { | 36 static const char* kLogEventsNames[CodeEventListener::NUMBER_OF_LOG_EVENTS] = { |
36 LOG_EVENTS_AND_TAGS_LIST(DECLARE_EVENT)}; | 37 LOG_EVENTS_AND_TAGS_LIST(DECLARE_EVENT)}; |
37 #undef DECLARE_EVENT | 38 #undef DECLARE_EVENT |
(...skipping 370 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
408 USE(rv); | 409 USE(rv); |
409 } | 410 } |
410 | 411 |
411 | 412 |
412 void LowLevelLogger::CodeMovingGCEvent() { | 413 void LowLevelLogger::CodeMovingGCEvent() { |
413 const char tag = kCodeMovingGCTag; | 414 const char tag = kCodeMovingGCTag; |
414 | 415 |
415 LogWriteBytes(&tag, sizeof(tag)); | 416 LogWriteBytes(&tag, sizeof(tag)); |
416 } | 417 } |
417 | 418 |
418 | |
419 #define JIT_LOG(Call) if (jit_logger_) jit_logger_->Call; | |
420 | |
421 | |
422 class JitLogger : public CodeEventLogger { | 419 class JitLogger : public CodeEventLogger { |
423 public: | 420 public: |
424 explicit JitLogger(JitCodeEventHandler code_event_handler); | 421 explicit JitLogger(JitCodeEventHandler code_event_handler); |
425 | 422 |
426 void CodeMoveEvent(AbstractCode* from, Address to) override; | 423 void CodeMoveEvent(AbstractCode* from, Address to) override; |
427 void CodeDisableOptEvent(AbstractCode* code, | 424 void CodeDisableOptEvent(AbstractCode* code, |
428 SharedFunctionInfo* shared) override {} | 425 SharedFunctionInfo* shared) override {} |
429 void AddCodeLinePosInfoEvent(void* jit_handler_data, int pc_offset, | 426 void AddCodeLinePosInfoEvent(void* jit_handler_data, int pc_offset, |
430 int position, | 427 int position, |
431 JitCodeEvent::PositionType position_type); | 428 JitCodeEvent::PositionType position_type); |
(...skipping 762 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1194 msg.AppendDetailed(source, false); | 1191 msg.AppendDetailed(source, false); |
1195 msg.Append('"'); | 1192 msg.Append('"'); |
1196 msg.WriteToLogFile(); | 1193 msg.WriteToLogFile(); |
1197 } | 1194 } |
1198 | 1195 |
1199 void Logger::CodeMoveEvent(AbstractCode* from, Address to) { | 1196 void Logger::CodeMoveEvent(AbstractCode* from, Address to) { |
1200 if (!is_logging_code_events()) return; | 1197 if (!is_logging_code_events()) return; |
1201 MoveEventInternal(CodeEventListener::CODE_MOVE_EVENT, from->address(), to); | 1198 MoveEventInternal(CodeEventListener::CODE_MOVE_EVENT, from->address(), to); |
1202 } | 1199 } |
1203 | 1200 |
1204 void Logger::CodeLinePosInfoAddPositionEvent(void* jit_handler_data, | 1201 void Logger::CodeLinePosInfoRecordEvent(AbstractCode* code, |
1205 int pc_offset, int position) { | 1202 ByteArray* source_position_table) { |
1206 JIT_LOG(AddCodeLinePosInfoEvent(jit_handler_data, | 1203 if (jit_logger_) { |
1207 pc_offset, | 1204 void* jit_handler_data = jit_logger_->StartCodePosInfoEvent(); |
1208 position, | 1205 for (SourcePositionTableIterator iter(source_position_table); !iter.done(); |
1209 JitCodeEvent::POSITION)); | 1206 iter.Advance()) { |
| 1207 if (iter.is_statement()) { |
| 1208 jit_logger_->AddCodeLinePosInfoEvent( |
| 1209 jit_handler_data, iter.code_offset(), iter.source_position(), |
| 1210 JitCodeEvent::STATEMENT_POSITION); |
| 1211 } |
| 1212 jit_logger_->AddCodeLinePosInfoEvent(jit_handler_data, iter.code_offset(), |
| 1213 iter.source_position(), |
| 1214 JitCodeEvent::POSITION); |
| 1215 } |
| 1216 jit_logger_->EndCodePosInfoEvent(code, jit_handler_data); |
| 1217 } |
1210 } | 1218 } |
1211 | 1219 |
1212 | |
1213 void Logger::CodeLinePosInfoAddStatementPositionEvent(void* jit_handler_data, | |
1214 int pc_offset, | |
1215 int position) { | |
1216 JIT_LOG(AddCodeLinePosInfoEvent(jit_handler_data, | |
1217 pc_offset, | |
1218 position, | |
1219 JitCodeEvent::STATEMENT_POSITION)); | |
1220 } | |
1221 | |
1222 void Logger::CodeStartLinePosInfoRecordEvent(void** jit_handler_data_out) { | |
1223 *jit_handler_data_out = | |
1224 (jit_logger_ == NULL) ? NULL : jit_logger_->StartCodePosInfoEvent(); | |
1225 } | |
1226 | |
1227 void Logger::CodeEndLinePosInfoRecordEvent(AbstractCode* code, | |
1228 void* jit_handler_data) { | |
1229 JIT_LOG(EndCodePosInfoEvent(code, jit_handler_data)); | |
1230 } | |
1231 | |
1232 | |
1233 void Logger::CodeNameEvent(Address addr, int pos, const char* code_name) { | 1220 void Logger::CodeNameEvent(Address addr, int pos, const char* code_name) { |
1234 if (code_name == NULL) return; // Not a code object. | 1221 if (code_name == NULL) return; // Not a code object. |
1235 Log::MessageBuilder msg(log_); | 1222 Log::MessageBuilder msg(log_); |
1236 msg.Append("%s,%d,", | 1223 msg.Append("%s,%d,", |
1237 kLogEventsNames[CodeEventListener::SNAPSHOT_CODE_NAME_EVENT], pos); | 1224 kLogEventsNames[CodeEventListener::SNAPSHOT_CODE_NAME_EVENT], pos); |
1238 msg.AppendDoubleQuotedString(code_name); | 1225 msg.AppendDoubleQuotedString(code_name); |
1239 msg.WriteToLogFile(); | 1226 msg.WriteToLogFile(); |
1240 } | 1227 } |
1241 | 1228 |
1242 | 1229 |
(...skipping 607 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1850 | 1837 |
1851 if (profiler_listener_.get() != nullptr) { | 1838 if (profiler_listener_.get() != nullptr) { |
1852 removeCodeEventListener(profiler_listener_.get()); | 1839 removeCodeEventListener(profiler_listener_.get()); |
1853 } | 1840 } |
1854 | 1841 |
1855 return log_->Close(); | 1842 return log_->Close(); |
1856 } | 1843 } |
1857 | 1844 |
1858 } // namespace internal | 1845 } // namespace internal |
1859 } // namespace v8 | 1846 } // namespace v8 |
OLD | NEW |