56a486c322
- this avoids using relative include paths which are forbidden by the style guide - makes the code more readable since it's clear which header is meant - allows for starting to use checkdeps BUG=none R=jkummerow@chromium.org, danno@chromium.org LOG=n Review URL: https://codereview.chromium.org/304153016 git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@21625 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
82 lines
1.9 KiB
C++
82 lines
1.9 KiB
C++
// Copyright 2010 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef V8_CPU_PROFILER_INL_H_
|
|
#define V8_CPU_PROFILER_INL_H_
|
|
|
|
#include "src/cpu-profiler.h"
|
|
|
|
#include <new>
|
|
#include "src/circular-queue-inl.h"
|
|
#include "src/profile-generator-inl.h"
|
|
#include "src/unbound-queue-inl.h"
|
|
|
|
namespace v8 {
|
|
namespace internal {
|
|
|
|
void CodeCreateEventRecord::UpdateCodeMap(CodeMap* code_map) {
|
|
code_map->AddCode(start, entry, size);
|
|
if (shared != NULL) {
|
|
entry->set_shared_id(code_map->GetSharedId(shared));
|
|
}
|
|
}
|
|
|
|
|
|
void CodeMoveEventRecord::UpdateCodeMap(CodeMap* code_map) {
|
|
code_map->MoveCode(from, to);
|
|
}
|
|
|
|
|
|
void CodeDisableOptEventRecord::UpdateCodeMap(CodeMap* code_map) {
|
|
CodeEntry* entry = code_map->FindEntry(start);
|
|
if (entry != NULL) {
|
|
entry->set_bailout_reason(bailout_reason);
|
|
}
|
|
}
|
|
|
|
|
|
void SharedFunctionInfoMoveEventRecord::UpdateCodeMap(CodeMap* code_map) {
|
|
code_map->MoveCode(from, to);
|
|
}
|
|
|
|
|
|
void ReportBuiltinEventRecord::UpdateCodeMap(CodeMap* code_map) {
|
|
CodeEntry* entry = code_map->FindEntry(start);
|
|
if (!entry) {
|
|
// Code objects for builtins should already have been added to the map but
|
|
// some of them have been filtered out by CpuProfiler.
|
|
return;
|
|
}
|
|
entry->SetBuiltinId(builtin_id);
|
|
}
|
|
|
|
|
|
TickSample* CpuProfiler::StartTickSample() {
|
|
if (is_profiling_) return processor_->StartTickSample();
|
|
return NULL;
|
|
}
|
|
|
|
|
|
void CpuProfiler::FinishTickSample() {
|
|
processor_->FinishTickSample();
|
|
}
|
|
|
|
|
|
TickSample* ProfilerEventsProcessor::StartTickSample() {
|
|
void* address = ticks_buffer_.StartEnqueue();
|
|
if (address == NULL) return NULL;
|
|
TickSampleEventRecord* evt =
|
|
new(address) TickSampleEventRecord(last_code_event_id_);
|
|
return &evt->sample;
|
|
}
|
|
|
|
|
|
void ProfilerEventsProcessor::FinishTickSample() {
|
|
ticks_buffer_.FinishEnqueue();
|
|
}
|
|
|
|
} } // namespace v8::internal
|
|
|
|
#endif // V8_CPU_PROFILER_INL_H_
|