提交 a1836069 编写于 作者: S Stefan Raspl 提交者: Paolo Bonzini

tools/kvm_stat: fix trace setup glitch on field updates in TracepointProvider

Updating the fields of the TracepointProvider does not propagate changes to the
tracepoints. This shows when a pid filter is enabled, whereby subsequent
extensions of the fields of the Tracepoint provider (e.g. by toggling
drilldown) will not modify the tracepoints as required.
To reproduce, select a specific process via interactive command 'p', and
enable drilldown via 'x' - none of the fields with the braces will appear
although they should.
The fix will always leave all available fields in the TracepointProvider
enabled.
Signed-off-by: NStefan Raspl <raspl@linux.vnet.ibm.com>
Based-on-text-by: NJanosch Frank <frankja@linux.vnet.ibm.com>
Signed-off-by: NRadim Krčmář <rkrcmar@redhat.com>
上级 e0ba3876
...@@ -550,6 +550,7 @@ class TracepointProvider(object): ...@@ -550,6 +550,7 @@ class TracepointProvider(object):
def setup_traces(self): def setup_traces(self):
"""Creates all event and group objects needed to be able to retrieve """Creates all event and group objects needed to be able to retrieve
data.""" data."""
fields = self.get_available_fields()
if self._pid > 0: if self._pid > 0:
# Fetch list of all threads of the monitored pid, as qemu # Fetch list of all threads of the monitored pid, as qemu
# starts a thread for each vcpu. # starts a thread for each vcpu.
...@@ -560,7 +561,7 @@ class TracepointProvider(object): ...@@ -560,7 +561,7 @@ class TracepointProvider(object):
# The constant is needed as a buffer for python libs, std # The constant is needed as a buffer for python libs, std
# streams and other files that the script opens. # streams and other files that the script opens.
newlim = len(groupids) * len(self._fields) + 50 newlim = len(groupids) * len(fields) + 50
try: try:
softlim_, hardlim = resource.getrlimit(resource.RLIMIT_NOFILE) softlim_, hardlim = resource.getrlimit(resource.RLIMIT_NOFILE)
...@@ -576,7 +577,7 @@ class TracepointProvider(object): ...@@ -576,7 +577,7 @@ class TracepointProvider(object):
for groupid in groupids: for groupid in groupids:
group = Group() group = Group()
for name in self._fields: for name in fields:
tracepoint = name tracepoint = name
tracefilter = None tracefilter = None
match = re.match(r'(.*)\((.*)\)', name) match = re.match(r'(.*)\((.*)\)', name)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册