blob: 8878ec560a5f62cd12db231edfe1b1428220e11f [file] [log] [blame]
ager@chromium.org9258b6b2008-09-11 09:11:10 +00001// Copyright 2007-2008 the V8 project authors. All rights reserved.
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +00002// 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#include "v8.h"
29
30#include "counters.h"
31#include "platform.h"
32
33namespace v8 { namespace internal {
34
35CounterLookupCallback StatsTable::lookup_function_ = NULL;
36
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000037// Start the timer.
38void StatsCounterTimer::Start() {
kasperl@chromium.orgb9123622008-09-17 14:05:56 +000039 if (!counter_.Enabled())
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000040 return;
41 stop_time_ = 0;
42 start_time_ = OS::Ticks();
43}
44
45// Stop the timer and record the results.
46void StatsCounterTimer::Stop() {
kasperl@chromium.orgb9123622008-09-17 14:05:56 +000047 if (!counter_.Enabled())
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000048 return;
49 stop_time_ = OS::Ticks();
kasperl@chromium.orgb9123622008-09-17 14:05:56 +000050
51 // Compute the delta between start and stop, in milliseconds.
52 int milliseconds = static_cast<int>(stop_time_ - start_time_) / 1000;
53 counter_.Increment(milliseconds);
christian.plesner.hansen43d26ec2008-07-03 15:10:15 +000054}
55
56} } // namespace v8::internal