blob: 84235e55c30b994aacd90f539cda0ad2fc81d4de [file] [log] [blame]
<!DOCTYPE html>
<!--
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.
-->
<link rel="import" href="/extras/importer/linux_perf/parser.html">
<script>
'use strict';
/**
* @fileoverview Parses cpufreq events in the Linux event trace format.
*/
tr.exportTo('tr.e.importer.linux_perf', function() {
var Parser = tr.e.importer.linux_perf.Parser;
/**
* Parses linux cpufreq trace events.
* @constructor
*/
function CpufreqParser(importer) {
Parser.call(this, importer);
importer.registerEventHandler('cpufreq_interactive_up',
CpufreqParser.prototype.cpufreqUpDownEvent.bind(this));
importer.registerEventHandler('cpufreq_interactive_down',
CpufreqParser.prototype.cpufreqUpDownEvent.bind(this));
importer.registerEventHandler('cpufreq_interactive_already',
CpufreqParser.prototype.cpufreqTargetEvent.bind(this));
importer.registerEventHandler('cpufreq_interactive_notyet',
CpufreqParser.prototype.cpufreqTargetEvent.bind(this));
importer.registerEventHandler('cpufreq_interactive_setspeed',
CpufreqParser.prototype.cpufreqTargetEvent.bind(this));
importer.registerEventHandler('cpufreq_interactive_target',
CpufreqParser.prototype.cpufreqTargetEvent.bind(this));
importer.registerEventHandler('cpufreq_interactive_boost',
CpufreqParser.prototype.cpufreqBoostUnboostEvent.bind(this));
importer.registerEventHandler('cpufreq_interactive_unboost',
CpufreqParser.prototype.cpufreqBoostUnboostEvent.bind(this));
}
function splitData(input) {
// TODO(sleffler) split by cpu
var data = {};
var args = input.split(/\s+/);
var len = args.length;
for (var i = 0; i < len; i++) {
var item = args[i].split('=');
data[item[0]] = parseInt(item[1]);
}
return data;
}
CpufreqParser.prototype = {
__proto__: Parser.prototype,
cpufreqSlice: function(ts, eventName, cpu, args) {
// TODO(sleffler) should be per-cpu
var kthread = this.importer.getOrCreatePseudoThread('cpufreq');
kthread.openSlice = eventName;
var slice = new tr.model.Slice('', kthread.openSlice,
tr.b.ui.getColorIdForGeneralPurposeString(kthread.openSlice),
ts, args, 0);
kthread.thread.sliceGroup.pushSlice(slice);
},
cpufreqBoostSlice: function(ts, eventName, args) {
var kthread = this.importer.getOrCreatePseudoThread('cpufreq_boost');
kthread.openSlice = eventName;
var slice = new tr.model.Slice('', kthread.openSlice,
tr.b.ui.getColorIdForGeneralPurposeString(kthread.openSlice),
ts, args, 0);
kthread.thread.sliceGroup.pushSlice(slice);
},
/**
* Parses cpufreq events and sets up state in the importer.
*/
cpufreqUpDownEvent: function(eventName, cpuNumber, pid, ts, eventBase) {
var data = splitData(eventBase.details);
this.cpufreqSlice(ts, eventName, data.cpu, data);
return true;
},
cpufreqTargetEvent: function(eventName, cpuNumber, pid, ts,
eventBase) {
var data = splitData(eventBase.details);
this.cpufreqSlice(ts, eventName, data.cpu, data);
return true;
},
cpufreqBoostUnboostEvent: function(eventName, cpuNumber, pid, ts,
eventBase) {
this.cpufreqBoostSlice(ts, eventName,
{
type: eventBase.details
});
return true;
}
};
Parser.register(CpufreqParser);
return {
CpufreqParser: CpufreqParser
};
});
</script>