Re: [PATCH] uprobes: list all active uprobes in the system

From: Longjun Luo
Date: Fri Jan 13 2023 - 02:50:11 EST



在 1/13/2023 12:03 PM, Ravi Bangoria 写道:
+cc: Steven, Oleg, Masami

On 11-Jan-23 4:18 PM, luolongjun@xxxxxxxxxx wrote:
From: Longjun Luo <luolongjun@xxxxxxxxxx>

Since uprobes will replace instructions in the process
memory, it is necessary to provide one way to list
all active uprobes. One can access this file through
/sys/kernel/debug/uprobes/list.

Output looks like this
=====================
inode+offset/ref_ctr_offset 4160760670+0x30a10/0x0
ref 1
register_rwsem (unlocked)
consumer_rwsem (unlocked)
consumers-1
handler 0xffffffffc03ee02e(handler) uprobe
ret_handler 0x0000000000000000( )
filter 0xffffffffc03ee010(filter) uprobe
consumers-2
handler 0xffffffffc03e902e(handler_1) uprobe_1
ret_handler 0x0000000000000000( )
filter 0xffffffffc03e9010(filter_1) uprobe_1
You can list uprobes via /sys/kernel/tracing/uprobe_events. Any specific reason
to introduce another way?

Thanks,
Ravi

/sys/kernel/tracing/uprobe_events only lists tracing events, not all uprobe events.
For example, if I write a kernel module to call the uprobe_register to add a new uprobe event, it will not be listed by /sys/kernel/tracing/uprobe_events.

Compare it with the kprobe is like:
/sys/kernel/tracing/uprobe_events -> /sys/kernel/tracing/kprobe_events
/sys/kernel/debug/uprobes/list -> /sys/kernel/debug/kprobes/list

Nowadays, only the trace system uses the uprobe, so /sys/kernel/tracing/uprobe_events is enough.

But we try to extend the usage of the uprobe, and we add many uprobe events by calling the uprobe_register.

For this situation, we need a approach to see all the uprobe events in the kernel.