forked from awslabs/damo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdamo_report_raw.py
108 lines (91 loc) · 3.71 KB
/
damo_report_raw.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
106
107
108
# SPDX-License-Identifier: GPL-2.0
import argparse
import json
import os
import sys
import _damo_fmt_str
import _damon_result
def filter_snapshots(records, start_time_sec, end_time_sec):
for record in records:
if len(record.snapshots) == 0:
continue
base_time = record.snapshots[0].start_time
filtered_snapshots = []
for snapshot in record.snapshots:
offset_sec = (snapshot.start_time - base_time) / 1000000000
if offset_sec < start_time_sec:
continue
if offset_sec > end_time_sec:
break
filtered_snapshots.append(snapshot)
record.snapshots = filtered_snapshots
def pr_records(args, records):
if args.duration:
filter_snapshots(records, args.duration[0], args.duration[1])
if args.json:
print(json.dumps([r.to_kvpairs(args.raw_number)
for r in records], indent=4))
exit(0)
for record in records:
snapshots = record.snapshots
if len(snapshots) == 0:
continue
base_time = snapshots[0].start_time
print('base_time_absolute: %s\n' %
_damo_fmt_str.format_time_ns(base_time, args.raw_number))
for snapshot in snapshots:
print('monitoring_start: %16s' %
_damo_fmt_str.format_time_ns(
snapshot.start_time - base_time, args.raw_number))
print('monitoring_end: %16s' %
_damo_fmt_str.format_time_ns(
snapshot.end_time - base_time, args.raw_number))
print('monitoring_duration: %16s' %
_damo_fmt_str.format_time_ns(
snapshot.end_time - snapshot.start_time,
args.raw_number))
print('target_id: %s' % record.target_id)
print('nr_regions: %s' % len(snapshot.regions))
print('# %10s %12s %12s %11s %5s' %
('start_addr', 'end_addr', 'length', 'nr_accesses', 'age'))
for r in snapshot.regions:
print("%012x-%012x (%12s) %11d %5d" %
(r.start, r.end,
_damo_fmt_str.format_sz(r.size(), args.raw_number),
r.nr_accesses.samples, r.age.aggr_intervals
if r.age.aggr_intervals != None else -1))
print('')
def set_argparser(parser):
parser.add_argument('--input', '-i', type=str, metavar='<file>',
default='damon.data', help='input file name')
parser.add_argument('--duration', type=float, metavar='<seconds>', nargs=2,
help='start and end time offset for record to parse')
parser.add_argument('--raw_number', action='store_true',
help='use machine-friendly raw numbers')
parser.add_argument('--json', action='store_true',
help='print in json format')
parser.description='Show raw data of the monitoring results record file'
def main(args=None):
if not args:
parser = argparse.ArgumentParser()
set_argparser(parser)
args = parser.parse_args()
file_path = args.input
if not os.path.isfile(file_path):
print('input file (%s) is not exist' % file_path)
exit(1)
records, err = _damon_result.parse_records_file(file_path)
if err:
print('parsing damon result file (%s) failed (%s)' %
(file_path, err))
exit(1)
if len(records) == 0:
print('no monitoring result in the file')
exit(1)
try:
pr_records(args, records)
except BrokenPipeError as e:
# maybe user piped to 'less' like pager and quit from it
pass
if __name__ == '__main__':
main()