Commit 2e07ddc5 authored by Paul Chaignon's avatar Paul Chaignon

memleak: linter cleanup

parent 7297af05
...@@ -281,7 +281,7 @@ int posix_memalign_exit(struct pt_regs *ctx) { ...@@ -281,7 +281,7 @@ int posix_memalign_exit(struct pt_regs *ctx) {
memptrs.delete(&pid); memptrs.delete(&pid);
if (bpf_probe_read(&addr, sizeof(void*), (void*)(size_t)*memptr64) != 0) if (bpf_probe_read(&addr, sizeof(void*), (void*)(size_t)*memptr64))
return 0; return 0;
u64 addr64 = (u64)(size_t)addr; u64 addr64 = (u64)(size_t)addr;
...@@ -382,7 +382,7 @@ if not kernel_trace: ...@@ -382,7 +382,7 @@ if not kernel_trace:
stack_flags += "|BPF_F_USER_STACK" stack_flags += "|BPF_F_USER_STACK"
bpf_source = bpf_source.replace("STACK_FLAGS", stack_flags) bpf_source = bpf_source.replace("STACK_FLAGS", stack_flags)
bpf_program = BPF(text=bpf_source) bpf = BPF(text=bpf_source)
if not kernel_trace: if not kernel_trace:
print("Attaching to pid %d, Ctrl+C to quit." % pid) print("Attaching to pid %d, Ctrl+C to quit." % pid)
...@@ -392,12 +392,12 @@ if not kernel_trace: ...@@ -392,12 +392,12 @@ if not kernel_trace:
fn_prefix = sym fn_prefix = sym
try: try:
bpf_program.attach_uprobe(name=obj, sym=sym, bpf.attach_uprobe(name=obj, sym=sym,
fn_name=fn_prefix+"_enter", fn_name=fn_prefix + "_enter",
pid=pid) pid=pid)
bpf_program.attach_uretprobe(name=obj, sym=sym, bpf.attach_uretprobe(name=obj, sym=sym,
fn_name=fn_prefix+"_exit", fn_name=fn_prefix + "_exit",
pid=pid) pid=pid)
except Exception: except Exception:
if can_fail: if can_fail:
return return
...@@ -411,8 +411,8 @@ if not kernel_trace: ...@@ -411,8 +411,8 @@ if not kernel_trace:
attach_probes("valloc") attach_probes("valloc")
attach_probes("memalign") attach_probes("memalign")
attach_probes("pvalloc") attach_probes("pvalloc")
attach_probes("aligned_alloc", can_fail=True) # added in C11 attach_probes("aligned_alloc", can_fail=True) # added in C11
bpf_program.attach_uprobe(name=obj, sym="free", fn_name="free_enter", bpf.attach_uprobe(name=obj, sym="free", fn_name="free_enter",
pid=pid) pid=pid)
else: else:
...@@ -423,11 +423,12 @@ else: ...@@ -423,11 +423,12 @@ else:
# #
# Memory allocations in Linux kernel are not limited to malloc/free # Memory allocations in Linux kernel are not limited to malloc/free
# equivalents. It's also common to allocate a memory page or multiple # equivalents. It's also common to allocate a memory page or multiple
# pages. Page allocator have two interfaces, one working with page frame # pages. Page allocator have two interfaces, one working with page
# numbers (PFN), while other working with page addresses. It's possible # frame numbers (PFN), while other working with page addresses. It's
# to allocate pages with one kind of functions, and free them with # possible to allocate pages with one kind of functions, and free them
# another. Code in kernel can easy convert PFNs to addresses and back, # with another. Code in kernel can easy convert PFNs to addresses and
# but it's hard to do the same in eBPF kprobe without fragile hacks. # back, but it's hard to do the same in eBPF kprobe without fragile
# hacks.
# #
# Fortunately, Linux exposes tracepoints for memory allocations, which # Fortunately, Linux exposes tracepoints for memory allocations, which
# can be instrumented by eBPF programs. Tracepoint for page allocations # can be instrumented by eBPF programs. Tracepoint for page allocations
...@@ -438,8 +439,8 @@ def print_outstanding(): ...@@ -438,8 +439,8 @@ def print_outstanding():
print("[%s] Top %d stacks with outstanding allocations:" % print("[%s] Top %d stacks with outstanding allocations:" %
(datetime.now().strftime("%H:%M:%S"), top_stacks)) (datetime.now().strftime("%H:%M:%S"), top_stacks))
alloc_info = {} alloc_info = {}
allocs = bpf_program["allocs"] allocs = bpf["allocs"]
stack_traces = bpf_program["stack_traces"] stack_traces = bpf["stack_traces"]
for address, info in sorted(allocs.items(), key=lambda a: a[1].size): for address, info in sorted(allocs.items(), key=lambda a: a[1].size):
if BPF.monotonic_time() - min_age_ns < info.timestamp_ns: if BPF.monotonic_time() - min_age_ns < info.timestamp_ns:
continue continue
...@@ -451,7 +452,7 @@ def print_outstanding(): ...@@ -451,7 +452,7 @@ def print_outstanding():
stack = list(stack_traces.walk(info.stack_id)) stack = list(stack_traces.walk(info.stack_id))
combined = [] combined = []
for addr in stack: for addr in stack:
combined.append(bpf_program.sym(addr, pid, combined.append(bpf.sym(addr, pid,
show_module=True, show_offset=True)) show_module=True, show_offset=True))
alloc_info[info.stack_id] = Allocation(combined, alloc_info[info.stack_id] = Allocation(combined,
info.size) info.size)
...@@ -465,8 +466,8 @@ def print_outstanding(): ...@@ -465,8 +466,8 @@ def print_outstanding():
(alloc.size, alloc.count, "\n\t\t".join(alloc.stack))) (alloc.size, alloc.count, "\n\t\t".join(alloc.stack)))
def print_outstanding_combined(): def print_outstanding_combined():
stack_traces = bpf_program["stack_traces"] stack_traces = bpf["stack_traces"]
stacks = sorted(bpf_program["combined_allocs"].items(), stacks = sorted(bpf["combined_allocs"].items(),
key=lambda a: -a[1].total_size) key=lambda a: -a[1].total_size)
cnt = 1 cnt = 1
entries = [] entries = []
...@@ -474,7 +475,7 @@ def print_outstanding_combined(): ...@@ -474,7 +475,7 @@ def print_outstanding_combined():
try: try:
trace = [] trace = []
for addr in stack_traces.walk(stack_id.value): for addr in stack_traces.walk(stack_id.value):
sym = bpf_program.sym(addr, pid, sym = bpf.sym(addr, pid,
show_module=True, show_module=True,
show_offset=True) show_offset=True)
trace.append(sym) trace.append(sym)
...@@ -498,7 +499,7 @@ def print_outstanding_combined(): ...@@ -498,7 +499,7 @@ def print_outstanding_combined():
count_so_far = 0 count_so_far = 0
while True: while True:
if trace_all: if trace_all:
print(bpf_program.trace_fields()) print(bpf.trace_fields())
else: else:
try: try:
sleep(interval) sleep(interval)
......
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