blob: 49fe39993f968fa8e8aeb254d65ccc688146d5c8 [file] [log] [blame]
// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/timer/hi_res_timer_manager.h"
#include <algorithm>
#include "base/atomicops.h"
#include "base/metrics/histogram_macros.h"
#include "base/power_monitor/power_monitor.h"
#include "base/task/post_task.h"
#include "base/time/time.h"
namespace base {
namespace {
constexpr TimeDelta kUsageSampleInterval = TimeDelta::FromMinutes(10);
void ReportHighResolutionTimerUsage() {
UMA_HISTOGRAM_PERCENTAGE("Windows.HighResolutionTimerUsage",
Time::GetHighResolutionTimerUsage());
// Reset usage for the next interval.
Time::ResetHighResolutionTimerUsage();
}
} // namespace
HighResolutionTimerManager::HighResolutionTimerManager()
: hi_res_clock_available_(false) {
PowerMonitor* power_monitor = PowerMonitor::Get();
DCHECK(power_monitor != NULL);
power_monitor->AddObserver(this);
UseHiResClock(!power_monitor->IsOnBatteryPower());
// Start polling the high resolution timer usage.
Time::ResetHighResolutionTimerUsage();
timer_.Start(FROM_HERE, kUsageSampleInterval,
Bind(&ReportHighResolutionTimerUsage));
}
HighResolutionTimerManager::~HighResolutionTimerManager() {
PowerMonitor::Get()->RemoveObserver(this);
UseHiResClock(false);
}
void HighResolutionTimerManager::OnPowerStateChange(bool on_battery_power) {
UseHiResClock(!on_battery_power);
}
void HighResolutionTimerManager::OnSuspend() {
// Stop polling the usage to avoid including the standby time.
timer_.Stop();
}
void HighResolutionTimerManager::OnResume() {
// Resume polling the usage.
Time::ResetHighResolutionTimerUsage();
timer_.Reset();
}
void HighResolutionTimerManager::UseHiResClock(bool use) {
if (use == hi_res_clock_available_)
return;
hi_res_clock_available_ = use;
Time::EnableHighResolutionTimer(use);
}
} // namespace base