blob: 2ac6c3735a6cc9677518730c8e74dd078062f7f8 [file] [log] [blame]
// Copyright (c) 2012 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 <map>
#include <memory>
#include <vector>
#include "base/lazy_instance.h"
#include "base/macros.h"
#include "base/process/process_handle.h"
#include "base/timer/timer.h"
#include "chrome/browser/performance_monitor/process_metrics_history.h"
namespace performance_monitor {
class ProcessMetricsHistory;
// PerformanceMonitor is a tool which periodically monitors performance metrics
// for histogram logging and possibly taking action upon noticing serious
// performance degradation.
class PerformanceMonitor {
// Returns the current PerformanceMonitor instance if one exists; otherwise
// constructs a new PerformanceMonitor.
static PerformanceMonitor* GetInstance();
// Start the cycle of metrics gathering.
void StartGatherCycle();
friend struct base::LazyInstanceTraitsBase<PerformanceMonitor>;
using MetricsMap =
std::map<base::ProcessHandle, std::unique_ptr<ProcessMetricsHistory>>;
// Perform any collections that are done on a timed basis.
void DoTimedCollections();
// Mark the given process as alive in the current update iteration.
// This means adding an entry to the map of watched processes if it's not
// already present.
void MarkProcessAsAlive(const ProcessMetricsMetadata& process_data,
int current_update_sequence);
void MarkProcessesAsAliveOnUIThread(
std::unique_ptr<std::vector<ProcessMetricsMetadata>> process_data_list,
int current_update_sequence);
// Updates the ProcessMetrics map with the current list of processes and
// gathers metrics from each entry.
void GatherMetricsMapOnUIThread();
void GatherMetricsMapOnIOThread(int current_update_sequence);
void UpdateMetricsOnIOThread(int current_update_sequence);
void RunTriggersUIThread();
// A map of currently running ProcessHandles to ProcessMetrics.
MetricsMap metrics_map_;
// The timer to signal PerformanceMonitor to perform its timed collections.
base::OneShotTimer repeating_timer_;
} // namespace performance_monitor