blob: 7e7137f16cacd49fde16d84e3b3eac8b38248181 [file] [log] [blame]
// Copyright (c) 2006-2008 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.
#ifndef CHROME_TEST_PERF_MEM_USAGE_H__
#define CHROME_TEST_PERF_MEM_USAGE_H__
// Get memory information for the process with given process ID.
//
// The Windows psapi provides memory information of a process through structure
// RPROCESS_MEMORY_COUNTERS_EX. Relevant fields are:
// PagefileUsage: private (not shared) committed virtual space in process.
// This is "VM Size" in task manager processes tab.
// PeakPagefileUsage: peak value of PagefileUsage.
// WorkingSetSize: physical memory allocated to process including shared pages.
// This is "Memory Usage" in task manager processes tab.
// Contrary to its name, this value is not much useful for
// tracking the memory demand of an application.
// PeakWorkingSetSize: peak value of WorkingSetSize.
// This is "Peak Memory Usage" in task manager processes
// tab.
// PrivateUsage: The current amount of memory that cannot be shared with other
// processes. Private bytes include memory that is committed and
// marked MEM_PRIVATE, data that is not mapped, and executable
// pages that have been written to. It usually gives the same
// value as PagefileUsage. No equivalent part in task manager.
//
// The measurements we use are PagefileUsage (returned by current_virtual_size)
// and PeakPagefileUsage (returned by peak_virtual_size), Working Set and
// Peak working Set.
bool GetMemoryInfo(uint32 process_id,
size_t *peak_virtual_size,
size_t *current_virtual_size,
size_t *peak_working_set_size,
size_t *current_working_set_size);
// Get the number of bytes currently committed by the system.
// Returns -1 on failure.
size_t GetSystemCommitCharge();
// Get and print memory usage information for running chrome processes.
void PrintChromeMemoryUsageInfo();
#endif // CHROME_TEST_PERF_MEM_USAGE_H__