-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathsat.py
executable file
·105 lines (86 loc) · 2.04 KB
/
sat.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#!/bin/env python
#
# Strace-Alanyzing-Tool -- a script that helps finding out
# where CRIU spends time in the kernel while working
#
# For dump:
# # strace -o log -T criu dump ... -R
#
# For restore
# # strace -o log -f -T criu restore ... --action-script $(pwd)/scripts/fake-restore.sh
#
# Then
# # cat log | sat.py [-t|-c]
# -t -- sort by total time spent
# -c -- sort by the amount of calls performed
#
import sys
raw = False
NONE = 0
COUNT = 1
TIME = 2
sort = NONE
if len(sys.argv) >= 2:
if sys.argv[1] == "-r":
raw = True
elif sys.argv[1] == "-c":
sort = COUNT
elif sys.argv[1] == "-t":
sort = TIME
data = sys.stdin.readlines()
stats = {}
tot = (0, 0.0)
for ln in data:
ln = ln.strip()
if not ln[0].isdigit():
# No per-pid stuff
ln = "1 " + ln
# Typicall line looks like
# pid syscall(argument) = result <time>
try:
sysc = ln.split(' ', 1)[1].strip()
if sysc.startswith('---'):
continue
if sysc.startswith('+++'):
continue
if sysc.startswith('exit'):
continue
if sysc.startswith('<...'):
# Special 'resumed' line
sysc = sysc[5:].split(' ', 1)[0]
else:
sysc = sysc.split('(', 1)[0]
time = ln.rsplit(' ', 1)[1].strip().strip('<>')
if time.startswith('...'):
continue
time = float(time)
except:
print "Error converting line [%s]" % ln
sys.exit(1)
# sysc -- syscall name
# time -- time taken
if not stats.has_key(sysc):
stats[sysc] = (1, time)
else:
stats[sysc] = (stats[sysc][0] + 1, stats[sysc][1] + time)
tot = (tot[0] + 1, tot[1] + time)
stats_r = map(lambda i: (i, stats[i][0], stats[i][1]), stats)
if sort != NONE:
stats_r.sort(key=lambda t: t[sort])
if not raw:
stats_r.append(("Total", tot[0], tot[1]))
tot_prc = 0
half = False
quat = False
for k in stats_r:
prc = k[2] * 100. / tot[1]
suf = ""
if sort == TIME:
if not half and tot_prc >= 50:
half = True
suf = " <- %3.1f%%" % (100. - tot_prc)
if not quat and tot_prc >= 25:
quat = True
suf = " <- %3.1f%%" % (100. - tot_prc)
print "%20s: %8d %f (%3.1f%%)%8s" % (k[0], k[1], k[2], prc, suf)
tot_prc += prc