import os, re from autotest_lib.client.bin import test, utils from autotest_lib.client.common_lib import error class unixbench5(test.test): """ This test measure system wide performance by running the following tests: - Dhrystone - focuses on string handling. - Whetstone - measure floating point operations. - Execl Throughput - measure the number of execl calls per second. - File Copy - Pipe throughput - Pipe-based context switching - Process creation - number of times a process can fork and reap - Shell Scripts - number of times a process can start and reap a script - System Call Overhead - estimates the cost of entering and leaving the kernel. @see: http://code.google.com/p/byte-unixbench/ @author: Dale Curtis <dalecurtis@google.com> """ version = 1 def initialize(self): self.job.require_gcc() self.err = [] def setup(self, tarball='unixbench-5.1.3.tgz'): """ Compiles unixbench. @tarball: Path or URL to a unixbench tarball @see: http://byte-unixbench.googlecode.com/files/unixbench-5.1.3.tgz """ tarball = utils.unmap_url(self.bindir, tarball, self.tmpdir) utils.extract_tarball_to_dir(tarball, self.srcdir) os.chdir(self.srcdir) utils.system('patch -p0 < ../Makefile.patch') utils.make() def run_once(self, args=''): vars = 'UB_TMPDIR="%s" UB_RESULTDIR="%s"' % (self.tmpdir, self.resultsdir) os.chdir(self.srcdir) self.report_data = utils.system_output(vars + ' ./Run ' + args) self.results_path = os.path.join(self.resultsdir, 'raw_output_%s' % self.iteration) utils.open_write_close(self.results_path, self.report_data) def cleanup(self): """ Check error index list and throw TestError if necessary. """ if self.err: e_msg = ("No measured results for output lines: %s\nOutput:%s" % (" ".join(self.err), self.report_data)) raise error.TestError(e_msg) def process_section(self, section, suffix): keyval = {} subsections = section.split('\n\n') if len(subsections) < 3: raise error.TestError('Invalid output format. Unable to parse') # Process the subsection containing performance results first. for index, line in enumerate(subsections[1].strip().split('\n')): # Look for problems first. if re.search('no measured results', line, flags=re.IGNORECASE): self.err.append(str(index + 1)) # Every performance result line ends with 6 values, with the sixth # being the actual result. Make sure there are at least that words # in the line before processing. words = line.lower().split() if len(words) >= 6: key = re.sub('\W', '', '_'.join(words[:-6])) keyval[key + suffix] = words[-6] # The final score should be the last item in the third subsection. keyval['score' + suffix] = subsections[2].strip().split()[-1] self.write_perf_keyval(keyval) def postprocess_iteration(self): # Break up sections around dividing lines. sections = self.report_data.split('-'*72) # First section is junk to us, second has results for single CPU run. if len(sections) > 1: self.process_section(section=sections[1], suffix='') # Only machines with > 1 CPU will have a 3rd section. if len(sections) > 2: self.process_section(section=sections[2], suffix='_multi') else: raise error.TestError('Invalid output format. Unable to parse') """ Here is a sample output: # # # # # # # ##### ###### # # #### # # # # ## # # # # # # # ## # # # # # # # # # # # ## ##### ##### # # # # ###### # # # # # # ## # # # # # # # # # # # # ## # # # # # # # ## # # # # #### # # # # # ##### ###### # # #### # # Version 5.1.2 Based on the Byte Magazine Unix Benchmark Multi-CPU version Version 5 revisions by Ian Smith, Sunnyvale, CA, USA December 22, 2007 johantheghost at yahoo period com 1 x Dhrystone 2 using register variables 1 2 3 4 5 6 7 8 9 10 1 x Double-Precision Whetstone 1 2 3 4 5 6 7 8 9 10 1 x Execl Throughput 1 2 3 1 x File Copy 1024 bufsize 2000 maxblocks 1 2 3 1 x File Copy 256 bufsize 500 maxblocks 1 2 3 1 x File Copy 4096 bufsize 8000 maxblocks 1 2 3 1 x Pipe Throughput 1 2 3 4 5 6 7 8 9 10 1 x Pipe-based Context Switching 1 2 3 4 5 6 7 8 9 10 1 x Process Creation 1 2 3 1 x System Call Overhead 1 2 3 4 5 6 7 8 9 10 1 x Shell Scripts (1 concurrent) 1 2 3 1 x Shell Scripts (8 concurrent) 1 2 3 2 x Dhrystone 2 using register variables 1 2 3 4 5 6 7 8 9 10 2 x Double-Precision Whetstone 1 2 3 4 5 6 7 8 9 10 2 x Execl Throughput 1 2 3 2 x File Copy 1024 bufsize 2000 maxblocks 1 2 3 2 x File Copy 256 bufsize 500 maxblocks 1 2 3 2 x File Copy 4096 bufsize 8000 maxblocks 1 2 3 2 x Pipe Throughput 1 2 3 4 5 6 7 8 9 10 2 x Pipe-based Context Switching 1 2 3 4 5 6 7 8 9 10 2 x Process Creation 1 2 3 2 x System Call Overhead 1 2 3 4 5 6 7 8 9 10 2 x Shell Scripts (1 concurrent) 1 2 3 2 x Shell Scripts (8 concurrent) 1 2 3 ======================================================================== BYTE UNIX Benchmarks (Version 5.1.2) System: localhost: GNU/Linux OS: GNU/Linux -- 2.6.32.26+drm33.12 -- #1 SMP Wed Jan 12 16:16:05 PST 2011 Machine: i686 (GenuineIntel) Language: en_US.utf8 (charmap=, collate=) CPU 0: Intel(R) Atom(TM) CPU N455 @ 1.66GHz (3325.2 bogomips) Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT CPU 1: Intel(R) Atom(TM) CPU N455 @ 1.66GHz (3325.0 bogomips) Hyper-Threading, x86-64, MMX, Physical Address Ext, SYSENTER/SYSEXIT 14:11:59 up 1 day, 1:10, 0 users, load average: 0.47, 0.48, 0.51; runlevel ------------------------------------------------------------------------ Benchmark Run: Fri Jan 14 2011 14:11:59 - 14:41:26 2 CPUs in system; running 1 parallel copy of tests Dhrystone 2 using register variables 2264000.6 lps (10.0 s, 7 samples) Double-Precision Whetstone 507.0 MWIPS (10.1 s, 7 samples) Execl Throughput 796.7 lps (30.0 s, 2 samples) File Copy 1024 bufsize 2000 maxblocks 110924.1 KBps (30.1 s, 2 samples) File Copy 256 bufsize 500 maxblocks 32600.5 KBps (30.1 s, 2 samples) File Copy 4096 bufsize 8000 maxblocks 284236.5 KBps (30.0 s, 2 samples) Pipe Throughput 301672.5 lps (10.0 s, 7 samples) Pipe-based Context Switching 29475.3 lps (10.0 s, 7 samples) Process Creation 3124.6 lps (30.0 s, 2 samples) Shell Scripts (1 concurrent) 1753.0 lpm (60.0 s, 2 samples) Shell Scripts (8 concurrent) 305.9 lpm (60.1 s, 2 samples) System Call Overhead 592781.7 lps (10.0 s, 7 samples) System Benchmarks Index Values BASELINE RESULT INDEX Dhrystone 2 using register variables 116700.0 2264000.6 194.0 Double-Precision Whetstone 55.0 507.0 92.2 Execl Throughput 43.0 796.7 185.3 File Copy 1024 bufsize 2000 maxblocks 3960.0 110924.1 280.1 File Copy 256 bufsize 500 maxblocks 1655.0 32600.5 197.0 File Copy 4096 bufsize 8000 maxblocks 5800.0 284236.5 490.1 Pipe Throughput 12440.0 301672.5 242.5 Pipe-based Context Switching 4000.0 29475.3 73.7 Process Creation 126.0 3124.6 248.0 Shell Scripts (1 concurrent) 42.4 1753.0 413.4 Shell Scripts (8 concurrent) 6.0 305.9 509.8 System Call Overhead 15000.0 592781.7 395.2 ======== System Benchmarks Index Score 238.0 ------------------------------------------------------------------------ Benchmark Run: Fri Jan 14 2011 14:41:26 - 15:09:23 2 CPUs in system; running 2 parallel copies of tests Dhrystone 2 using register variables 3411919.6 lps (10.0 s, 7 samples) Double-Precision Whetstone 964.3 MWIPS (10.1 s, 7 samples) Execl Throughput 2053.5 lps (30.0 s, 2 samples) File Copy 1024 bufsize 2000 maxblocks 158308.0 KBps (30.0 s, 2 samples) File Copy 256 bufsize 500 maxblocks 46249.5 KBps (30.0 s, 2 samples) File Copy 4096 bufsize 8000 maxblocks 389881.9 KBps (30.0 s, 2 samples) Pipe Throughput 410193.1 lps (10.0 s, 7 samples) Pipe-based Context Switching 113780.0 lps (10.0 s, 7 samples) Process Creation 7609.0 lps (30.0 s, 2 samples) Shell Scripts (1 concurrent) 2355.0 lpm (60.0 s, 2 samples) Shell Scripts (8 concurrent) 308.1 lpm (60.2 s, 2 samples) System Call Overhead 1057063.2 lps (10.0 s, 7 samples) System Benchmarks Index Values BASELINE RESULT INDEX Dhrystone 2 using register variables 116700.0 3411919.6 292.4 Double-Precision Whetstone 55.0 964.3 175.3 Execl Throughput 43.0 2053.5 477.6 File Copy 1024 bufsize 2000 maxblocks 3960.0 158308.0 399.8 File Copy 256 bufsize 500 maxblocks 1655.0 46249.5 279.5 File Copy 4096 bufsize 8000 maxblocks 5800.0 389881.9 672.2 Pipe Throughput 12440.0 410193.1 329.7 Pipe-based Context Switching 4000.0 113780.0 284.5 Process Creation 126.0 7609.0 603.9 Shell Scripts (1 concurrent) 42.4 2355.0 555.4 Shell Scripts (8 concurrent) 6.0 308.1 513.5 System Call Overhead 15000.0 1057063.2 704.7 ======== System Benchmarks Index Score 407.4 """