Add a tracefs_kprobe_raw() to facilitate adding kprobe events. It's denoted as "raw" because it still requires knowing the complex format of a kprobe, but at least it helps with other formats: p:[[system/]event] addr fmt The user only needs to know the "fmt" part above, and not worry about what file to open, or how to open it. Also add a tracefs_kprobe_clear() to clear all kprobes and a tracefs_kprobe_clear_probe() to clear an individual kprobe. Both have a "force" parameter, that if set, will then try to disable the kprobe in all instances (including the top) and then remove the kprobe(s). Changes since v6: https://lore.kernel.org/linux-trace-devel/20210702185616.167778-1-rostedt@xxxxxxxxxxx/ - Fixed some utest cases that used strcmp() when it should have used !strcmp(). This should be the last version before I push (I hope!) Steven Rostedt (VMware) (10): libtracefs: Implement tracefs_instances() libtracefs: Implement tracefs_kprobe_raw() libtracefs: Implement tracefs_kretprobe_raw() libtracefs: Implement tracefs_get_kprobes() libtracefs: Add helper function to parse kprobes libtracefs: Implement tracefs_kprobe_info() libtracefs: Implement tracefs_kprobe_clear_all() to remove all kprobes libtracefs: Implement tracefs_kprobe_clear_probe() libtracefs: Add man pages for kprobe functions libtracefs: Update the unit tests to use the kprobe API instead Documentation/libtracefs-kprobes.txt | 297 ++++++++++++++++ include/tracefs.h | 17 + src/Makefile | 1 + src/tracefs-instance.c | 76 +++++ src/tracefs-kprobes.c | 485 +++++++++++++++++++++++++++ utest/tracefs-utest.c | 195 +++++++++-- 6 files changed, 1042 insertions(+), 29 deletions(-) create mode 100644 Documentation/libtracefs-kprobes.txt create mode 100644 src/tracefs-kprobes.c -- 2.30.2