From: Josh Poimboeuf <jpoim...@kernel.org> If the task is not a user thread, there's no user stack to unwind.
Signed-off-by: Josh Poimboeuf <jpoim...@kernel.org> Signed-off-by: Steven Rostedt (Google) <rost...@goodmis.org> --- Changes since v11: https://lore.kernel.org/20250625231622.509379...@goodmis.org - Added test against PF_USER_WORKER as well as PF_KTHREAD kernel/events/core.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/kernel/events/core.c b/kernel/events/core.c index cf35dc707ad5..a594bd01d5bc 100644 --- a/kernel/events/core.c +++ b/kernel/events/core.c @@ -8166,7 +8166,8 @@ struct perf_callchain_entry * perf_callchain(struct perf_event *event, struct pt_regs *regs) { bool kernel = !event->attr.exclude_callchain_kernel; - bool user = !event->attr.exclude_callchain_user; + bool user = !event->attr.exclude_callchain_user && + !(current->flags & (PF_KTHREAD | PF_USER_WORKER)); /* Disallow cross-task user callchains. */ bool crosstask = event->ctx->task && event->ctx->task != current; const u32 max_stack = event->attr.sample_max_stack; -- 2.47.2