1#!/usr/bin/python
2
3# http://test.kernel.org/perf/kernbench.elm3b6.png
4
5import cgi, cgitb, os, sys, re, subprocess
6cgitb.enable()
7Popen = subprocess.Popen
8
9import common
10from autotest_lib.tko import db, display, frontend, plotgraph
11from autotest_lib.client.common_lib import kernel_versions
12
13released_kernel = re.compile('2\.\d\.\d+(-smp-)[0-9]{3}\.[0-9]$')
14rc_kernel = re.compile('2\.\d\.\d+(-smp-)[0-9]{3}\.[0-9]_rc[0-9]$')
15db = db.db()
16
17def main():
18    form = cgi.FieldStorage()
19
20    if form.has_key("benchmark_key"):
21        benchmark_key = form["benchmark_key"].value
22        # input is a list of benchmark:key values -- benchmark1:key1,...
23        # this loop separates this out into two lists
24        benchmark_idx = []
25        key_idx = []
26        for benchmark_key_pair in benchmark_key.split(','):
27            (benchmark, key) = benchmark_key_pair.split(':')
28            benchmark_idx.append(benchmark)
29            key_idx.append(key)
30    elif form.has_key("benchmark") and form.has_key("key"):
31        benchmarks = form["benchmark"].value
32        keys = form["key"].value
33
34        benchmark_idx = benchmarks.split(',')
35        key_idx = keys.split(',')
36    else:
37        # Ignore this for by setting benchmark_idx and key_idx to be
38        # empty lists.
39        benchmark_idx = []
40        key_idx = []
41
42    machine_idx = form["machine"].value
43    kernel = form["kernel"].value
44    if kernel == "released":
45        kernel = released_kernel
46    if kernel == "rc":
47        kernel = rc_kernel
48
49    machine = frontend.machine.select(db, {'hostname' : machine_idx})[0]
50
51    #get the machine type from machinename
52    for line in open('machines', 'r'):
53        words = line.rstrip().split('\t')
54        if words[0] == machine.hostname:
55            title = '%s (%s)' % (words[-1], machine.hostname)
56        else:
57            title = '%s' % machine.hostname
58
59    graph = plotgraph.gnuplot(title, 'Kernel', 'normalized throughput (%)', xsort = sort_kernels, size = "600,500")
60    for benchmark, key in zip(benchmark_idx, key_idx):
61        reference_value = None
62        data = {}
63        where = { 'subdir' : benchmark, 'machine_idx' : machine.idx , 'status' : 6}
64
65        #select the corresponding kernels and sort by the release version
66        kernels = set([])
67        kernels_sort = set([])
68        kernels_idx = set([])
69        for test in frontend.test.select(db, where):
70            if kernel == "all":
71                kernels.add(test.kernel().printable)
72                kernels_idx.add(str(test.kernel().idx))
73
74            elif kernel == "experimental":
75                if not re.match(released_kernel, test.kernel().printable)\
76                and not re.match(rc_kernel, test.kernel().printable):
77                    kernels.add(test.kernel().printable)
78                    kernels_idx.add(str(test.kernel().idx))
79            else:
80                if re.match(kernel, test.kernel().printable):
81                    kernels.add(test.kernel().printable)
82                    kernels_idx.add(str(test.kernel().idx))
83        kernels_sort = sort_kernels(list(kernels))
84
85        #get the base value for each benchmark
86        kernel_base = frontend.kernel.select(db, {'printable' : kernels_sort[0]})[0]
87        for test in frontend.test.select(db, { 'subdir' : benchmark, 'machine_idx' : machine.idx, 'kernel_idx' : kernel_base.idx}):
88            iterations = test.iterations()
89            if iterations.has_key(key):
90                reference_value = sum(iterations[key])/len(iterations[key])
91                break
92
93        wherein = { 'kernel_idx' : kernels_idx }
94        for test in frontend.test.select(db, where, wherein):
95            iterations = test.iterations()
96            if iterations.has_key(key):
97                # Maintain a list of every test result in data.
98                # Initialize this list, if it does not exist.
99                if not data.has_key(test.kernel().printable):
100                    data[test.kernel().printable] = list()
101
102                if benchmark == "kernbench":
103                    results = [((reference_value / i - 1)*100) for i in iterations[key]]
104                else:
105                    results = [((i / reference_value - 1)*100) for i in iterations[key]]
106                data[test.kernel().printable].extend(results)
107
108        graph.add_dataset(benchmark+' ( '+key+' ) ',data)
109
110    graph.plot(cgi_header = True)
111
112
113def sort_kernels(kernels):
114    return sorted(kernels, key = kernel_versions.version_encode)
115
116main()
117