Commit 4e9289b1 authored by Sasha Goldshtein's avatar Sasha Goldshtein

funccount: Do not prepopulate location cache

Avoiding the prepopulation of the location cache allows us
to get rid of the `zero()` call at the end of each interval,
which would hang the program at full CPU. Replaced the
prepopulation with a `lookup_or_init` and the `zero()` call
with a call to `clear()`.
parent 06fb0fa7
...@@ -170,11 +170,9 @@ class Probe(object): ...@@ -170,11 +170,9 @@ class Probe(object):
trace_count_text = """ trace_count_text = """
int PROBE_FUNCTION(void *ctx) { int PROBE_FUNCTION(void *ctx) {
FILTER FILTER
u64 loc = LOCATION; u64 loc = LOCATION, zero = 0;
u64 *val = counts.lookup(&loc); // prepopulated on Python side u64 *val = counts.lookup_or_init(&loc, &zero);
if (val) {
(*val)++; (*val)++;
}
return 0; return 0;
} }
""" """
...@@ -200,11 +198,6 @@ BPF_HASH(counts, u64, u64); // map location number to number of calls ...@@ -200,11 +198,6 @@ BPF_HASH(counts, u64, u64); // map location number to number of calls
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 [])
# Initialize all map entries to zero
counts = self.bpf["counts"]
for location, function in self.trace_functions.items():
counts[counts.Key(location)] = counts.Leaf()
class Tool(object): class Tool(object):
def __init__(self): def __init__(self):
examples = """examples: examples = """examples:
...@@ -267,7 +260,7 @@ class Tool(object): ...@@ -267,7 +260,7 @@ class Tool(object):
continue continue
print("%-36s %8d" % print("%-36s %8d" %
(self.probe.trace_functions[k.value], v.value)) (self.probe.trace_functions[k.value], v.value))
counts.zero() counts.clear()
if exiting: if exiting:
print("Detaching...") print("Detaching...")
......
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