// 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 }; });