import os
import re
from autotest_lib.client.bin import test
from autotest_lib.client.bin import utils
import tracers
import base_tracer
class tracing_microbenchmark(test.test):
version = 1
preserve_srcdir = True
def setup(self):
os.chdir(self.srcdir)
utils.system('make CROSS_COMPILE=""')
def initialize(self, tracer='ftrace', calls=100000, **kwargs):
self.job.require_gcc()
tracer_class = getattr(tracers, tracer)
if not issubclass(tracer_class, base_tracer.Tracer):
raise TypeError
self.tracer = tracer_class()
getuid_microbench = os.path.join(self.srcdir, 'getuid_microbench')
self.cmd = '%s %d' % (getuid_microbench, calls)
def warmup(self, buffer_size_kb=8000, **kwargs):
self.tracer.warmup(buffer_size_kb)
def cleanup(self):
self.tracer.cleanup()
def run_once(self, **kwargs):
self.results = {}
self.tracer.start_tracing()
self.cmd_result = utils.run(self.cmd)
self.tracer.stop_tracing()
self.tracer.gather_stats(self.results)
self.tracer.reset_tracing()
def postprocess_iteration(self):
result_re = re.compile(r'(?P<calls>\d+) calls '
r'in (?P<time>\d+\.\d+) s '
'\((?P<ns_per_call>\d+\.\d+) ns/call\)')
match = result_re.match(self.cmd_result.stdout)
self.results.update(match.groupdict())
self.write_perf_keyval(self.results)