Commit ce36bb6b authored by Kirill Smelkov's avatar Kirill Smelkov

execsnoop: Fix -x handling

Execsnoop's documentation says -x/--fails means "also include failed
exec()s". However it was programmed to instead skip successful execs on
-x and without -x show all - successful and unsuccessful ones.

The logic was broken in 5b47e0f8 ("execsnoop: use BPF_PERF_OUTPUT
instead of trace pipe").

Fix it.

P.S. current test_tools_smoke.py only provides basic infrastructure for
testing whether tool's BPF program won't break, without anything related
to options handling, so unfortunately the patch comes without
corresponding test.
parent ac5c03ce
...@@ -191,7 +191,7 @@ def print_event(cpu, data, size): ...@@ -191,7 +191,7 @@ def print_event(cpu, data, size):
if event.type == EventType.EVENT_ARG: if event.type == EventType.EVENT_ARG:
argv[event.pid].append(event.argv) argv[event.pid].append(event.argv)
elif event.type == EventType.EVENT_RET: elif event.type == EventType.EVENT_RET:
if args.fails and event.retval == 0: if event.retval != 0 and not args.fails:
skip = True skip = True
if args.name and not re.search(args.name, event.comm): if args.name and not re.search(args.name, event.comm):
skip = True skip = True
......
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