summaryrefslogtreecommitdiffstats
path: root/chrome/test/perf/mem_usage_win.cc
blob: 465b60246f12dfd441ad9c8a4ce8b0b7ac4be73f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
// 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.

#include "chrome/test/perf/mem_usage.h"

#include <windows.h>
#include <psapi.h>

#include "base/file_path.h"
#include "base/path_service.h"
#include "base/process_util.h"
#include "base/scoped_ptr.h"
#include "chrome/common/chrome_constants.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/test/chrome_process_util.h"

// GetPerformanceInfo is not available on WIN2K.  So we'll
// load it on-the-fly.
const wchar_t kPsapiDllName[] = L"psapi.dll";
typedef BOOL (WINAPI *GetPerformanceInfoFunction) (
    PPERFORMANCE_INFORMATION pPerformanceInformation,
    DWORD cb);

static BOOL InternalGetPerformanceInfo(
    PPERFORMANCE_INFORMATION pPerformanceInformation, DWORD cb) {
  static GetPerformanceInfoFunction GetPerformanceInfo_func = NULL;
  if (!GetPerformanceInfo_func) {
    HMODULE psapi_dll = ::GetModuleHandle(kPsapiDllName);
    if (psapi_dll)
      GetPerformanceInfo_func = reinterpret_cast<GetPerformanceInfoFunction>(
          GetProcAddress(psapi_dll, "GetPerformanceInfo"));

    if (!GetPerformanceInfo_func) {
      // The function could be loaded!
      memset(pPerformanceInformation, 0, cb);
      return FALSE;
    }
  }
  return GetPerformanceInfo_func(pPerformanceInformation, cb);
}


size_t GetSystemCommitCharge() {
  // Get the System Page Size.
  SYSTEM_INFO system_info;
  GetSystemInfo(&system_info);

  PERFORMANCE_INFORMATION info;
  if (InternalGetPerformanceInfo(&info, sizeof(info)))
    return info.CommitTotal * system_info.dwPageSize;
  return -1;
}

void PrintChromeMemoryUsageInfo() {
  printf("\n");

  FilePath data_dir;
  PathService::Get(chrome::DIR_USER_DATA, &data_dir);
  int browser_process_pid = ChromeBrowserProcessId(data_dir);
  ChromeProcessList chrome_processes(GetRunningChromeProcesses(data_dir));

  ChromeProcessList::const_iterator it;
  for (it = chrome_processes.begin(); it != chrome_processes.end(); ++it) {
    base::ProcessHandle process_handle;
    if (!base::OpenPrivilegedProcessHandle(*it, &process_handle)) {
      NOTREACHED();
    }

    // TODO(sgk):  if/when base::ProcessMetrics can return real memory
    // stats on mac, convert to:
    //
    // scoped_ptr<base::ProcessMetrics> process_metrics;
    // process_metrics.reset(
    //     base::ProcessMetrics::CreateProcessMetrics(process_handle));
    scoped_ptr<ChromeTestProcessMetrics> process_metrics;
    process_metrics.reset(
        ChromeTestProcessMetrics::CreateProcessMetrics(process_handle));

    size_t peak_virtual_size = process_metrics->GetPeakPagefileUsage();
    size_t current_virtual_size = process_metrics->GetPagefileUsage();
    size_t peak_working_set_size = process_metrics->GetPeakWorkingSetSize();
    size_t current_working_set_size = process_metrics->GetWorkingSetSize();

    if (*it == browser_process_pid) {
      wprintf(L"browser_vm_peak = %d\n", peak_virtual_size);
      wprintf(L"browser_vm_current = %d\n", current_virtual_size);
      wprintf(L"browser_ws_peak = %d\n", peak_working_set_size);
      wprintf(L"browser_ws_final = %d\n", current_working_set_size);
    } else {
      wprintf(L"render_vm_peak = %d\n", peak_virtual_size);
      wprintf(L"render_vm_current = %d\n", current_virtual_size);
      wprintf(L"render_ws_peak = %d\n", peak_working_set_size);
      wprintf(L"render_ws_final = %d\n", current_working_set_size);
    }
  };
}