On Wed, Sep 02, 2020 at 11:32:13AM +0200, Miroslav Benes wrote:
> Hi,
> 
> it could be a silly question, but better to ask...
> 
> > +   if (regs)
> > +           start_backtrace(&frame, regs->regs[29], regs->pc);
> > +   else
> > +           start_backtrace(&frame, thread_saved_fp(task),
> > +                           thread_saved_pc(task));
> 
> Would this also work for task == current? Given that the original code had
> 
> > -           start_backtrace(&frame,
> > -                           (unsigned long)__builtin_frame_address(0),
> > -                           (unsigned long)__save_stack_trace);

Oh whoops; I'm annoyed I didn't spot that.

With that gone this cannot work for (task == current && regs == NULL), as
we'll erroneously use stale values from the task struct.

It looks like the LKDTM tests only trigger cases with non-NULL regs, but
IIUC this should show up with show_stack(NULL, NULL, KERN_INFO), as
drivers/tty/sysrq.c does for other cpus.

Thanks,
Mark.

Reply via email to