blob: 5df5893f8a906c583452fad1252eecce8f7b857d [file] [log] [blame]
whesse@chromium.orgcec079d2010-03-22 14:44:04 +00001// Copyright 2010 the V8 project authors. All rights reserved.
2// Redistribution and use in source and binary forms, with or without
3// modification, are permitted provided that the following conditions are
4// met:
5//
6// * Redistributions of source code must retain the above copyright
7// notice, this list of conditions and the following disclaimer.
8// * Redistributions in binary form must reproduce the above
9// copyright notice, this list of conditions and the following
10// disclaimer in the documentation and/or other materials provided
11// with the distribution.
12// * Neither the name of Google Inc. nor the names of its
13// contributors may be used to endorse or promote products derived
14// from this software without specific prior written permission.
15//
16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28#ifndef V8_CPU_PROFILER_INL_H_
29#define V8_CPU_PROFILER_INL_H_
30
lrn@chromium.org25156de2010-04-06 13:10:27 +000031#include "cpu-profiler.h"
32
ricow@chromium.orgc9c80822010-04-21 08:22:37 +000033#ifdef ENABLE_LOGGING_AND_PROFILING
lrn@chromium.org25156de2010-04-06 13:10:27 +000034
whesse@chromium.orgcec079d2010-03-22 14:44:04 +000035#include "circular-queue-inl.h"
36#include "profile-generator-inl.h"
kmillikin@chromium.org9155e252010-05-26 13:27:57 +000037#include "unbound-queue-inl.h"
whesse@chromium.orgcec079d2010-03-22 14:44:04 +000038
whesse@chromium.orgcec079d2010-03-22 14:44:04 +000039namespace v8 {
40namespace internal {
41
lrn@chromium.org25156de2010-04-06 13:10:27 +000042void CodeCreateEventRecord::UpdateCodeMap(CodeMap* code_map) {
ager@chromium.org357bf652010-04-12 11:30:10 +000043 code_map->AddCode(start, entry, size);
lrn@chromium.org25156de2010-04-06 13:10:27 +000044}
45
46
47void CodeMoveEventRecord::UpdateCodeMap(CodeMap* code_map) {
ager@chromium.org357bf652010-04-12 11:30:10 +000048 code_map->MoveCode(from, to);
lrn@chromium.org25156de2010-04-06 13:10:27 +000049}
50
51
52void CodeDeleteEventRecord::UpdateCodeMap(CodeMap* code_map) {
ager@chromium.org357bf652010-04-12 11:30:10 +000053 code_map->DeleteCode(start);
lrn@chromium.org25156de2010-04-06 13:10:27 +000054}
55
56
57void CodeAliasEventRecord::UpdateCodeMap(CodeMap* code_map) {
erik.corry@gmail.com9dfbea42010-05-21 12:58:28 +000058 code_map->AddAlias(start, entry, code_start);
ager@chromium.org357bf652010-04-12 11:30:10 +000059}
60
61
62TickSampleEventRecord* TickSampleEventRecord::init(void* value) {
63 TickSampleEventRecord* result =
64 reinterpret_cast<TickSampleEventRecord*>(value);
65 result->filler = 1;
66 ASSERT(result->filler != SamplingCircularQueue::kClear);
67 // Init the required fields only.
68 result->sample.pc = NULL;
69 result->sample.frames_count = 0;
70 return result;
lrn@chromium.org25156de2010-04-06 13:10:27 +000071}
72
whesse@chromium.orgcec079d2010-03-22 14:44:04 +000073
74TickSample* ProfilerEventsProcessor::TickSampleEvent() {
ricow@chromium.orgc9c80822010-04-21 08:22:37 +000075 generator_->Tick();
whesse@chromium.orgcec079d2010-03-22 14:44:04 +000076 TickSampleEventRecord* evt =
ager@chromium.org357bf652010-04-12 11:30:10 +000077 TickSampleEventRecord::init(ticks_buffer_.Enqueue());
whesse@chromium.orgcec079d2010-03-22 14:44:04 +000078 evt->order = enqueue_order_; // No increment!
79 return &evt->sample;
80}
81
ager@chromium.org357bf652010-04-12 11:30:10 +000082
83bool ProfilerEventsProcessor::FilterOutCodeCreateEvent(
84 Logger::LogEventsAndTags tag) {
ager@chromium.org357bf652010-04-12 11:30:10 +000085 return FLAG_prof_browser_mode
86 && (tag != Logger::CALLBACK_TAG
87 && tag != Logger::FUNCTION_TAG
88 && tag != Logger::LAZY_COMPILE_TAG
fschneider@chromium.orgc20610a2010-09-22 09:44:58 +000089 && tag != Logger::REG_EXP_TAG
ager@chromium.org357bf652010-04-12 11:30:10 +000090 && tag != Logger::SCRIPT_TAG);
91}
92
whesse@chromium.orgcec079d2010-03-22 14:44:04 +000093} } // namespace v8::internal
94
ricow@chromium.orgc9c80822010-04-21 08:22:37 +000095#endif // ENABLE_LOGGING_AND_PROFILING
lrn@chromium.org25156de2010-04-06 13:10:27 +000096
whesse@chromium.orgcec079d2010-03-22 14:44:04 +000097#endif // V8_CPU_PROFILER_INL_H_