blob: df993c1a71e1789850c4b60fdeca3f5a91640ecc [file] [log] [blame]
mbligh34d01172008-06-05 16:26:31 +00001import signal, os
2from autotest_lib.client.bin import autotest_utils, test
3from autotest_lib.client.common_lib import utils
mblighe7a170f2006-12-05 07:48:18 +00004
5class bash_shared_mapping(test.test):
jadmanski0afbb632008-06-06 21:10:57 +00006 version = 3
mblighe7a170f2006-12-05 07:48:18 +00007
jadmanski0afbb632008-06-06 21:10:57 +00008 # http://www.zip.com.au/~akpm/linux/patches/stuff/ext3-tools.tar.gz
9 def setup(self, tarball = 'ext3-tools.tar.gz'):
10 self.tarball = utils.unmap_url(self.bindir, tarball,
11 self.tmpdir)
12 autotest_utils.extract_tarball_to_dir(self.tarball, self.srcdir)
mblighe7a170f2006-12-05 07:48:18 +000013
jadmanski0afbb632008-06-06 21:10:57 +000014 os.chdir(self.srcdir)
15 utils.system('make bash-shared-mapping usemem')
mblighe7a170f2006-12-05 07:48:18 +000016
17
jadmanski0afbb632008-06-06 21:10:57 +000018 def execute(self, testdir = None, iterations = 10000):
19 if not testdir:
20 testdir = self.tmpdir
21 os.chdir(testdir)
22 file = os.path.join(testdir, 'foo')
23 # Want to use 3/4 of all memory for each of
24 # bash-shared-mapping and usemem
25 kilobytes = (3 * autotest_utils.memtotal()) / 4
mblighe7a170f2006-12-05 07:48:18 +000026
jadmanski0afbb632008-06-06 21:10:57 +000027 # Want two usemem -m megabytes in parallel in background.
28 pid = [None, None]
29 usemem = os.path.join(self.srcdir, 'usemem')
30 args = ('usemem', '-N', '-m', '%d' % (kilobytes / 1024))
31 # print_to_tty ('2 x ' + ' '.join(args))
32 for i in (0,1):
33 pid[i] = os.spawnv(os.P_NOWAIT, usemem, args)
mblighe7a170f2006-12-05 07:48:18 +000034
jadmanski0afbb632008-06-06 21:10:57 +000035 cmd = "%s/bash-shared-mapping %s %d -t %d -n %d" % \
36 (self.srcdir, file, kilobytes,
37 count_cpus(), iterations)
38 os.system(cmd)
mblighe7a170f2006-12-05 07:48:18 +000039
jadmanski0afbb632008-06-06 21:10:57 +000040 for i in (0,1):
41 os.kill(pid[i], signal.SIGKILL)