2 import sys, re, struct, mmap, time
3 from bup import git, options
4 from bup.helpers import *
8 def s_from_bytes(bytes):
9 clist = [chr(b) for b in bytes]
16 fields = ['VmSize', 'VmRSS', 'VmData', 'VmStk', 'ms']
18 for line in open('/proc/self/status').readlines():
19 l = re.split(r':\s*', line.strip(), 1)
22 d['ms'] = int((now - last) * 1000)
25 fields = [d[k] for k in fields]
29 print ('%9s ' + ('%10s ' * len(fields))) % tuple([e1] + fields)
35 bup memtest [-n elements] [-c cycles]
37 n,number= number of objects per cycle [10000]
38 c,cycles= number of cycles to run [100]
39 ignore-midx ignore .midx files, use only .idx files
41 o = options.Options('bup memtest', optspec)
42 (opt, flags, extra) = o.parse(sys.argv[1:])
45 o.fatal('no arguments expected')
47 git.ignore_midx = opt.ignore_midx
49 git.check_repo_or_die()
50 m = git.PackIdxList(git.repo('objects/pack'))
53 f = open('/dev/urandom')
56 for c in xrange(opt.cycles):
57 for n in xrange(opt.number):
60 bytes = list(struct.unpack('!BBB', b)) + [0]*17
62 bin = struct.pack('!20s', s_from_bytes(bytes))
65 a[2] = chr(ord(b[2]) & 0xf0)
67 #print bin.encode('hex')
69 report((c+1)*opt.number)
71 print 'Total time: %.3fs' % (time.time() - start)