Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(87)

Side by Side Diff: tools/perf/metrics/memory.py

Issue 321363002: Change results.Add to results.AddResult in memory metrics. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # Copyright 2013 The Chromium Authors. All rights reserved. 1 # Copyright 2013 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 import sys 5 import sys
6 6
7 from metrics import histogram_util 7 from metrics import histogram_util
8 from metrics import Metric 8 from metrics import Metric
9 from telemetry.value import scalar
10 from telemetry.value import histogram
tonyg 2014/06/11 03:29:58 nit: alphabetize
9 11
10 _HISTOGRAMS = [ 12 _HISTOGRAMS = [
11 {'name': 'V8.MemoryExternalFragmentationTotal', 'units': 'percent', 13 {'name': 'V8.MemoryExternalFragmentationTotal', 'units': 'percent',
12 'display_name': 'V8_MemoryExternalFragmentationTotal', 14 'display_name': 'V8_MemoryExternalFragmentationTotal',
13 'type': histogram_util.RENDERER_HISTOGRAM}, 15 'type': histogram_util.RENDERER_HISTOGRAM},
14 {'name': 'V8.MemoryHeapSampleTotalCommitted', 'units': 'kb', 16 {'name': 'V8.MemoryHeapSampleTotalCommitted', 'units': 'kb',
15 'display_name': 'V8_MemoryHeapSampleTotalCommitted', 17 'display_name': 'V8_MemoryHeapSampleTotalCommitted',
16 'type': histogram_util.RENDERER_HISTOGRAM}, 18 'type': histogram_util.RENDERER_HISTOGRAM},
17 {'name': 'V8.MemoryHeapSampleTotalUsed', 'units': 'kb', 19 {'name': 'V8.MemoryHeapSampleTotalUsed', 'units': 'kb',
18 'display_name': 'V8_MemoryHeapSampleTotalUsed', 20 'display_name': 'V8_MemoryHeapSampleTotalUsed',
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after
86 88
87 # Optional argument trace_name is not in base class Metric. 89 # Optional argument trace_name is not in base class Metric.
88 # pylint: disable=W0221 90 # pylint: disable=W0221
89 def AddResults(self, tab, results, trace_name=None): 91 def AddResults(self, tab, results, trace_name=None):
90 """Add results for this page to the results object.""" 92 """Add results for this page to the results object."""
91 assert self._histogram_delta, 'Must call Stop() first' 93 assert self._histogram_delta, 'Must call Stop() first'
92 for h in _HISTOGRAMS: 94 for h in _HISTOGRAMS:
93 # Histogram data may not be available 95 # Histogram data may not be available
94 if h['name'] not in self._histogram_start: 96 if h['name'] not in self._histogram_start:
95 continue 97 continue
96 results.Add(h['display_name'], h['units'], 98 results.AddValue(histogram.HistogramValue(
97 self._histogram_delta[h['name']], 99 results.current_page, h['display_name'], h['units'],
98 data_type='unimportant-histogram') 100 raw_value_json=self._histogram_delta[h['name']], important=False))
99 self._memory_stats = self._browser.memory_stats 101 self._memory_stats = self._browser.memory_stats
100 if not self._memory_stats['Browser']: 102 if not self._memory_stats['Browser']:
101 return 103 return
102 AddResultsForProcesses(results, self._memory_stats, 104 AddResultsForProcesses(results, self._memory_stats,
103 metric_trace_name=trace_name) 105 metric_trace_name=trace_name)
104 106
105 end_commit_charge = self._memory_stats['SystemCommitCharge'] 107 end_commit_charge = self._memory_stats['SystemCommitCharge']
106 commit_charge_difference = end_commit_charge - self._start_commit_charge 108 commit_charge_difference = end_commit_charge - self._start_commit_charge
107 results.Add(trace_name or 'commit_charge', 'kb', 109 results.AddValue(scalar.ScalarValue(
108 commit_charge_difference, 110 results.current_page,
109 chart_name='commit_charge', 111 'commit_charge.' + (trace_name or 'commit_charge'),
110 data_type='unimportant') 112 'kb',
111 results.Add(trace_name or 'processes', 'count', 113 commit_charge_difference))
tonyg 2014/06/11 03:29:58 important=False
112 self._memory_stats['ProcessCount'], 114 results.AddValue(scalar.ScalarValue(
113 chart_name='processes', 115 results.current_page,
114 data_type='unimportant') 116 'processes.' + (trace_name or 'processes'),
117 'count',
118 self._memory_stats['ProcessCount'],
119 important=False))
115 120
116 121
117 def AddResultsForProcesses(results, memory_stats, chart_trace_name='final', 122 def AddResultsForProcesses(results, memory_stats, chart_trace_name='final',
118 metric_trace_name=None, 123 metric_trace_name=None,
119 exclude_metrics=None): 124 exclude_metrics=None):
120 """Adds memory stats for browser, renderer and gpu processes. 125 """Adds memory stats for browser, renderer and gpu processes.
121 126
122 Args: 127 Args:
123 results: A PageMeasurement results object. 128 results: A PageMeasurement results object.
124 memory_stats: System memory stats collected. 129 memory_stats: System memory stats collected.
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
156 stats = memory_stats[process_type_memory] 161 stats = memory_stats[process_type_memory]
157 if value_name_memory in stats: 162 if value_name_memory in stats:
158 values.append(stats[value_name_memory]) 163 values.append(stats[value_name_memory])
159 if values: 164 if values:
160 if metric_trace_name: 165 if metric_trace_name:
161 current_trace = '%s_%s' % (metric_trace_name, process_type_trace) 166 current_trace = '%s_%s' % (metric_trace_name, process_type_trace)
162 chart_name = value_name_trace 167 chart_name = value_name_trace
163 else: 168 else:
164 current_trace = '%s_%s' % (value_name_trace, process_type_trace) 169 current_trace = '%s_%s' % (value_name_trace, process_type_trace)
165 chart_name = current_trace 170 chart_name = current_trace
166 results.Add(current_trace, 'kb', sum(values) / 1024, 171 results.AddValue(scalar.ScalarValue(
167 chart_name=chart_name, data_type='unimportant') 172 results.current_page, '%s.%s' % (chart_name, current_trace), 'kb',
173 sum(values) / 1024, important=False))
168 174
169 AddResult('VM', 'vm_%s_size' % chart_trace_name) 175 AddResult('VM', 'vm_%s_size' % chart_trace_name)
170 AddResult('WorkingSetSize', 'vm_%s_%s_size' % (metric, chart_trace_name)) 176 AddResult('WorkingSetSize', 'vm_%s_%s_size' % (metric, chart_trace_name))
171 AddResult('PrivateDirty', 'vm_private_dirty_%s' % chart_trace_name) 177 AddResult('PrivateDirty', 'vm_private_dirty_%s' % chart_trace_name)
172 AddResult('ProportionalSetSize', 178 AddResult('ProportionalSetSize',
173 'vm_proportional_set_size_%s' % chart_trace_name) 179 'vm_proportional_set_size_%s' % chart_trace_name)
174 AddResult('SharedDirty', 'vm_shared_dirty_%s' % chart_trace_name) 180 AddResult('SharedDirty', 'vm_shared_dirty_%s' % chart_trace_name)
175 AddResult('VMPeak', 'vm_peak_size') 181 AddResult('VMPeak', 'vm_peak_size')
176 AddResult('WorkingSetSizePeak', '%s_peak_size' % metric) 182 AddResult('WorkingSetSizePeak', '%s_peak_size' % metric)
177 183
178 AddResultsForProcessTypes(['Browser'], 'browser') 184 AddResultsForProcessTypes(['Browser'], 'browser')
179 AddResultsForProcessTypes(['Renderer'], 'renderer') 185 AddResultsForProcessTypes(['Renderer'], 'renderer')
180 AddResultsForProcessTypes(['Gpu'], 'gpu') 186 AddResultsForProcessTypes(['Gpu'], 'gpu')
181 AddResultsForProcessTypes(['Browser', 'Renderer', 'Gpu'], 'total') 187 AddResultsForProcessTypes(['Browser', 'Renderer', 'Gpu'], 'total')
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698