Source code for autotest.client.profilers.cpistat.cpistat

"""
Uses perf_events to count cycles and instructions

Defaults options:
job.profilers.add('cpistat', interval=1)
"""
import os
import subprocess

from autotest.client import profiler


[docs]class cpistat(profiler.profiler): version = 1
[docs] def initialize(self, interval=1, **dargs): self.interval = interval
[docs] def start(self, test): cmd = os.path.join(self.bindir, 'site_cpistat') if not os.path.exists(cmd): cmd = os.path.join(self.bindir, 'cpistat') logfile = open(os.path.join(test.profdir, "cpistat"), 'w') p = subprocess.Popen(cmd, stdout=logfile, stderr=subprocess.STDOUT) self.pid = p.pid
[docs] def stop(self, test): os.kill(self.pid, 15)