| // 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. |
| |
| /** |
| * @fileoverview Parses trace_marker events that were inserted in the trace by |
| * userland. |
| */ |
| base.require('linux_perf_parser'); |
| base.exportTo('tracing', function() { |
| |
| var LinuxPerfParser = tracing.LinuxPerfParser; |
| |
| /** |
| * Parses linux trace mark events that were inserted in the trace by userland. |
| * @constructor |
| */ |
| function LinuxPerfBusParser(importer) { |
| LinuxPerfParser.call(this, importer); |
| |
| importer.registerEventHandler('memory_bus_usage', |
| LinuxPerfBusParser.prototype.traceMarkWriteBusEvent.bind(this)); |
| |
| this.model_ = importer.model_; |
| this.ppids_ = {}; |
| } |
| |
| LinuxPerfBusParser.prototype = { |
| __proto__: LinuxPerfParser.prototype, |
| |
| traceMarkWriteBusEvent: function(eventName, cpuNumber, pid, ts, |
| eventBase, threadName) { |
| var re = new RegExp('bus=(\\S+) rw_bytes=(\\d+) r_bytes=(\\d+) ' + |
| 'w_bytes=(\\d+) cycles=(\\d+) ns=(\\d+)'); |
| var event = re.exec(eventBase[5]); |
| |
| var name = event[1]; |
| var rw_bytes = parseInt(event[2]); |
| var r_bytes = parseInt(event[3]); |
| var w_bytes = parseInt(event[4]); |
| var cycles = parseInt(event[5]); |
| var ns = parseInt(event[6]); |
| |
| // BW in MB/s |
| var r_bw = r_bytes * 1000000000 / ns; |
| r_bw /= 1024 * 1024; |
| var w_bw = w_bytes * 1000000000 / ns; |
| w_bw /= 1024 * 1024; |
| |
| var ctr = this.model_.getOrCreateProcess(0) |
| .getOrCreateCounter(null, 'bus ' + name + ' read'); |
| // Initialize the counter's series fields if needed. |
| if (ctr.numSeries == 0) { |
| ctr.seriesNames.push('value'); |
| ctr.seriesColors.push( |
| tracing.getStringColorId(ctr.name + '.' + 'value')); |
| } |
| |
| // Add the sample value. |
| ctr.timestamps.push(ts); |
| ctr.samples.push(r_bw); |
| |
| ctr = this.model_.getOrCreateProcess(0) |
| .getOrCreateCounter(null, 'bus ' + name + ' write'); |
| // Initialize the counter's series fields if needed. |
| if (ctr.numSeries == 0) { |
| ctr.seriesNames.push('value'); |
| ctr.seriesColors.push( |
| tracing.getStringColorId(ctr.name + '.' + 'value')); |
| } |
| |
| // Add the sample value. |
| ctr.timestamps.push(ts); |
| ctr.samples.push(w_bw); |
| |
| return true; |
| }, |
| }; |
| |
| LinuxPerfParser.registerSubtype(LinuxPerfBusParser); |
| |
| return { |
| LinuxPerfBusParser: LinuxPerfBusParser |
| }; |
| }); |