Commit 8e6109bf authored by Sasha Goldshtein's avatar Sasha Goldshtein Committed by 4ast

funccount: Bail early if there are no matching functions (#792)

funccount now bails early with an error if there are no
functions matching the specified pattern (the same applies
to tracepoints and USDT probes). For example:

```
No functions matched by pattern ^sched:sched_fork$
```

Fixes #789.
parent b0468d92
...@@ -107,10 +107,6 @@ class Probe(object): ...@@ -107,10 +107,6 @@ class Probe(object):
elif self.type == "u": elif self.type == "u":
pass # Nothing to do -- attach already happened in `load` pass # Nothing to do -- attach already happened in `load`
if self.matched == 0:
raise Exception("No functions matched by pattern %s" %
self.pattern)
def _add_function(self, template, probe_name): def _add_function(self, template, probe_name):
new_func = "trace_count_%d" % self.matched new_func = "trace_count_%d" % self.matched
text = template.replace("PROBE_FUNCTION", new_func) text = template.replace("PROBE_FUNCTION", new_func)
...@@ -199,6 +195,10 @@ BPF_TABLE("array", int, u64, counts, NUMLOCATIONS); ...@@ -199,6 +195,10 @@ BPF_TABLE("array", int, u64, counts, NUMLOCATIONS);
if debug: if debug:
print(bpf_text) print(bpf_text)
if self.matched == 0:
raise Exception("No functions matched by pattern %s" %
self.pattern)
self.bpf = BPF(text=bpf_text, self.bpf = BPF(text=bpf_text,
usdt_contexts=[self.usdt] if self.usdt else []) usdt_contexts=[self.usdt] if self.usdt else [])
self.clear() # Initialize all array items to zero self.clear() # Initialize all array items to zero
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment