blob: 7762ab47d4c647bf6ba0bd11089ceafc0b552a8f [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.
/**
* @fileoverview Parses exynos events in the Linux event trace format.
*/
base.require('linux_perf_parser');
base.exportTo('tracing', function() {
var LinuxPerfParser = tracing.LinuxPerfParser;
/**
* Parses linux exynos trace events.
* @constructor
*/
function LinuxPerfExynosParser(importer) {
LinuxPerfParser.call(this, importer);
importer.registerEventHandler('exynos_flip_request',
LinuxPerfExynosParser.prototype.flipEvent.bind(this));
importer.registerEventHandler('exynos_flip_complete',
LinuxPerfExynosParser.prototype.flipEvent.bind(this));
importer.registerEventHandler('exynos_busfreq_target_int',
LinuxPerfExynosParser.prototype.busfreqTargetIntEvent.bind(this));
importer.registerEventHandler('exynos_busfreq_target_mif',
LinuxPerfExynosParser.prototype.busfreqTargetMifEvent.bind(this));
}
LinuxPerfExynosParser.prototype = {
__proto__: LinuxPerfParser.prototype,
exynosFlipOpenSlice: function(ts, pipe) {
// use pipe?
var kthread = this.importer.getOrCreatePseudoThread('exynos_flip');
kthread.openSliceTS = ts;
kthread.openSlice = 'flip:' + pipe;
},
exynosFlipCloseSlice: function(ts, args) {
var kthread = this.importer.getOrCreatePseudoThread('exynos_flip');
if (kthread.openSlice) {
var slice = new tracing.TimelineSlice('', kthread.openSlice,
tracing.getStringColorId(kthread.openSlice),
kthread.openSliceTS,
args,
ts - kthread.openSliceTS);
kthread.thread.pushSlice(slice);
}
kthread.openSlice = undefined;
},
/**
* Parses exynos events and sets up state in the importer.
*/
flipEvent: function(eventName, cpuNumber, pid, ts, eventBase) {
var event = /pipe=(\d+)/.exec(eventBase[5]);
if (!event)
return false;
var pipe = parseInt(event[1]);
if (eventName == 'exynos_flip_request')
this.exynosFlipOpenSlice(ts, pipe);
else
this.exynosFlipCloseSlice(ts,
{
pipe: pipe
});
return true;
},
exynosBusfreqSample: function(name, ts, frequency) {
var targetCpu = this.importer.getOrCreateCpuState(0);
var counter = targetCpu.cpu.getOrCreateCounter('', name);
if (counter.numSeries == 0) {
counter.seriesNames.push('frequency');
counter.seriesColors.push(
tracing.getStringColorId(counter.name + '.' + 'frequency'));
}
counter.timestamps.push(ts);
counter.samples.push(frequency);
},
/**
* Parses exynos_busfreq_target_int events and sets up state.
*/
busfreqTargetIntEvent: function(eventName, cpuNumber, pid, ts, eventBase) {
var event = /frequency=(\d+)/.exec(eventBase[5]);
if (!event)
return false;
this.exynosBusfreqSample('INT Frequency', ts, parseInt(event[1]));
return true;
},
/**
* Parses exynos_busfreq_target_mif events and sets up state.
*/
busfreqTargetMifEvent: function(eventName, cpuNumber, pid, ts, eventBase) {
var event = /frequency=(\d+)/.exec(eventBase[5]);
if (!event)
return false;
this.exynosBusfreqSample('MIF Frequency', ts, parseInt(event[1]));
return true;
},
};
LinuxPerfParser.registerSubtype(LinuxPerfExynosParser);
return {
LinuxPerfExynosParser: LinuxPerfExynosParser
};
});