RE: [PATCH 1/1] x86: dumpstack: take stack reference before accessing it

From: Maninder Singh

Date: Mon Mar 23 2026 - 01:05:51 EST



ping! Any inputs to this, if it is an actual issue or not ?

> --------- Original Message ---------
> Sender : Maninder Singh <maninder1.s@xxxxxxxxxxx>
> Date : 2026-03-11 10:51 (GMT+5:30)
> Title : [PATCH 1/1] x86: dumpstack: take stack reference before accessing it
>
>
> with THREAD_INFO_IN_TASK, stack of task can be
> freed earlier than task (even if task's reference is taken),
> and it needs separate reference with try_get_task_stack()
> before using the stack.
>
> Added a dummy code to save task_struct to reproduce the race in kernel:
>
> $ sleep 10 &
> $ take reference of sleep in kernel code in parallel
>
>       rcu_read_lock();
>       for_each_process(p) {
>               if (!strcmp(p->comm, "sleep")) {
>                       check_task = p;
>                       get_task_struct(check_task);
>               }
>       }
>       rcu_read_unlock();
>
> // in mean time here sleep binary will be exited,
> now call show_stack for it.
>
>       show_stack(check_task,  NULL, KERN_EMERG);
>
> //OOPs here
>
> [  49.887151] BUG: unable to handle page fault for address: ffffb57400213de8
> ...
> [  49.889329] CPU: 0 UID: 0 PID: 68 Comm: cat Not tainted 7.0.0-rc2-next-20260302-00003-gb7e059f3a5ae-dirty #49 PREEMPT(lazy)
> [  49.889789] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.15.0-1 04/01/2014
> [  49.890204] RIP: 0010:__unwind_start+0x118/0x1c0
> ....
> [  49.893485] Call Trace:
> [  49.893700]  <TASK>
> [  49.893810]  __show_trace_log_lvl+0x31f/0x360
> [  49.893988]  ? mas_store_prealloc+0x99/0x2c0
> [  49.894169]  meminfo_proc_show+0xdd/0x9a0
> [  49.894312]  ? seq_open+0x3b/0x60
> [  49.894435]  ? __pfx_meminfo_proc_show+0x10/0x10
> [  49.894568]  ? file_ra_state_init+0x10/0x30
> [  49.894731]  ? __pte_offset_map+0x16/0xd0
> [  49.894871]  ? seq_read_iter+0x38e/0x4b0
> [  49.895004]  seq_read_iter+0x109/0x4b0
> [  49.895125]  copy_splice_read+0x18f/0x330
> [  49.895272]  splice_direct_to_actor+0xb4/0x250
>
> Thus taking reference of task's stack before accessing it in
> show_stack() similar to get_wchan() and stack_trace_save_tsk().
>
> Fixes: 68f24b08ee89 ("sched/core: Free the stack early if CONFIG_THREAD_INFO_IN_TASK")
> Signed-off-by: Maninder Singh <maninder1.s@xxxxxxxxxxx>
> ---
> original discussion for sending this patch for comment: https://lkml.org/lkml/2026/3/5/299
>
> arch/x86/kernel/dumpstack.c | 5 +++++
> 1 file changed, 5 insertions(+)
>
> diff --git a/arch/x86/kernel/dumpstack.c b/arch/x86/kernel/dumpstack.c
> index b10684dedc58..3d44db836cd3 100644
> --- a/arch/x86/kernel/dumpstack.c
> +++ b/arch/x86/kernel/dumpstack.c
> @@ -190,6 +190,9 @@ static void __show_trace_log_lvl(struct task_struct *task, struct pt_regs *regs,
>          int graph_idx = 0;
>          bool partial = false;
>
> +        if (!try_get_task_stack(task))
> +                return;
> +
>          printk("%sCall Trace:\n", log_lvl);
>
>          unwind_start(&state, task, regs, stack);
> @@ -301,6 +304,8 @@ static void __show_trace_log_lvl(struct task_struct *task, struct pt_regs *regs,
>                  if (stack_name)
>                          printk("%s </%s>\n", log_lvl, stack_name);
>          }
> +
> +        put_task_stack(task);
> }
>
> static void show_trace_log_lvl(struct task_struct *task, struct pt_regs *regs,
> --
> 2.34.1