-
Notifications
You must be signed in to change notification settings - Fork 341
/
Copy pathevent-rmap.py
executable file
·92 lines (88 loc) · 2.89 KB
/
event-rmap.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
#!/usr/bin/env python3
# print currently running events on cpu (default 0)
# event-rmap [cpu-num]
# xxx no extra modi for now, racy with multi plexing
from __future__ import print_function
import sys
import msr
import ocperf
from pmudef import (MSR_PEBS_ENABLE, MSR_EVNTSEL, EVENTSEL_ENABLE, EVMASK,
EVENTSEL_CMASK,
EVENTSEL_EDGE, EVENTSEL_ANY, EVENTSEL_INV, EVENTSEL_PC,
MSR_IA32_FIXED_CTR_CTRL)
fixednames = (
"inst_retired.any",
"cpu_clk_unhalted.thread",
"cpu_clk_unhalted.ref_tsc"
)
cpu = 0
if len(sys.argv) > 1:
cpu = int(sys.argv[1])
emap = ocperf.find_emap()
if not emap:
print("Unknown CPU or cannot find CPU event table")
found = 0
try:
pebs_enable = msr.readmsr(MSR_PEBS_ENABLE, cpu)
except OSError:
pebs_enable = 0
for i in range(0, 8):
try:
evsel = msr.readmsr(MSR_EVNTSEL + i, cpu)
except OSError:
break
found += 1
if evsel & EVENTSEL_ENABLE:
print("%d: %016x: " % (i, evsel), end="")
evsel &= EVMASK
if emap is None:
name = "r%04x", evsel & 0xffff
elif evsel in emap.codes:
ev = emap.codes[evsel]
if ev.msr:
try:
extra = msr.readmsr(ev.msr)
except OSError:
print("Cannot read extra MSR %x for %s" % (ev.msr, ev.name))
continue
for j in emap.codes.keys():
if j == evsel and extra == emap.codes[j].msrvalue:
print(j.name, "msr:%x" % (extra), end="")
break
else:
print("no exact match for %s, msr %x value %x" % (ev.name,
ev.msr, ev.msrvalue), end="")
else:
print(ev.name, end="")
else:
name = ""
for j in emap.codes.keys():
if j & 0xff == evsel & 0xff:
name += "%s[%x] " % (emap.codes[j].name, j)
if name:
print("[no exact match] " + name, end=" ")
else:
print("r%x" % (evsel), end=" ")
if evsel & EVENTSEL_CMASK:
print("cmask=%x" % (evsel >> 24), end=" ")
if evsel & EVENTSEL_EDGE:
print("edge=1", end=" ")
if evsel & EVENTSEL_ANY:
print("any=1", end=" ")
if evsel & EVENTSEL_INV:
print("inv=1", end=" ")
if evsel & EVENTSEL_PC:
print("pc=1", end=" ")
if pebs_enable & (1 << i):
print("precise=1", end=" ")
print()
if found == 0:
print("Cannot read any MSRs")
try:
fixed = msr.readmsr(MSR_IA32_FIXED_CTR_CTRL)
except OSError:
print("Cannot read fixed counter MSR")
fixed = 0
for i in range(0, 2):
if fixed & (1 << (i*4)):
print("fixed %d: %s" % (i, fixednames[i]))