BACKPORT: FROMGIT: binder: add tracepoint for netlink reports

Add a tracepoint to capture the same details that are being sent through
the generic netlink interface during transaction failures. This provides
a useful debugging tool to observe the events independently from the
netlink listeners.

Signed-off-by: Carlos Llamas <cmllamas@google.com>
Link: https://lore.kernel.org/r/20250727182932.2499194-6-cmllamas@google.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

Bug: 372832477
(cherry picked from commit 8a61a53b07f23ff12330086b293b6b492d35b8a0
 git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc.git char-misc-next)
Change-Id: I5185383180787d1a237b8f583306055081a9f0d9
[cmllamas: fixed missing t->is_reply]
Signed-off-by: Carlos Llamas <cmllamas@google.com>
This commit is contained in:
Carlos Llamas
2025-07-27 18:29:08 +00:00
committed by Treehugger Robot
parent 4b0bb18d1f
commit e6cf4b4e36
2 changed files with 40 additions and 0 deletions
+2
View File
@@ -3211,6 +3211,8 @@ static void binder_netlink_report(struct binder_proc *proc,
BINDER_NLGRP_REPORT))
return;
trace_binder_netlink_report(context, t, data_size, error, is_reply);
skb = genlmsg_new(GENLMSG_DEFAULT_SIZE, GFP_KERNEL);
if (!skb)
return;
+38
View File
@@ -447,6 +447,44 @@ TRACE_EVENT(binder_return,
"unknown")
);
TRACE_EVENT(binder_netlink_report,
TP_PROTO(const char *context,
struct binder_transaction *t,
u32 data_size,
u32 error,
int is_reply),
TP_ARGS(context, t, data_size, error, is_reply),
TP_STRUCT__entry(
__field(const char *, context)
__field(u32, error)
__field(int, from_pid)
__field(int, from_tid)
__field(int, to_pid)
__field(int, to_tid)
__field(bool, is_reply)
__field(unsigned int, flags)
__field(unsigned int, code)
__field(size_t, data_size)
),
TP_fast_assign(
__entry->context = context;
__entry->error = error;
__entry->from_pid = t->from_pid;
__entry->from_tid = t->from_tid;
__entry->to_pid = t->to_proc ? t->to_proc->pid : 0;
__entry->to_tid = t->to_thread ? t->to_thread->pid : 0;
__entry->is_reply = is_reply;
__entry->flags = t->flags;
__entry->code = t->code;
__entry->data_size = data_size;
),
TP_printk("from %d:%d to %d:%d context=%s error=%d is_reply=%d flags=0x%x code=0x%x size=%zu",
__entry->from_pid, __entry->from_tid,
__entry->to_pid, __entry->to_tid,
__entry->context, __entry->error, __entry->is_reply,
__entry->flags, __entry->code, __entry->data_size)
);
#endif /* _BINDER_TRACE_H */
#undef TRACE_INCLUDE_PATH