drivers/tty: Explicitly pass current to show_stack
authorMark Rutland <mark.rutland@arm.com>
Mon, 26 Sep 2016 15:16:18 +0000 (16:16 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 27 Sep 2016 10:55:27 +0000 (12:55 +0200)
As noted in commit:

  81539169f283329f ("x86/dumpstack: Remove NULL task pointer convention")

... having a NULL task parameter imply current leads to subtle bugs in stack
walking code (so far seen on both 86 and arm64), makes callsites harder to
read, and is unnecessary as all callers have access to current.

As a step towards removing the problematic NULL-implies-current idiom entirely,
have the sysrq code explicitly pass current to show_stack.

Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Jiri Slaby <jslaby@suse.com>
Cc: Josh Poimboeuf <jpoimboe@redhat.com>
Cc: linux-kernel@vger.kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/sysrq.c

index 52bbd27e93ae7a83af92489b6d27fe0309437afe..5b1e0edacb84d79cd199a226b827521732014bd6 100644 (file)
@@ -224,7 +224,7 @@ static void showacpu(void *dummy)
 
        spin_lock_irqsave(&show_lock, flags);
        pr_info("CPU%d:\n", smp_processor_id());
-       show_stack(NULL, NULL);
+       show_stack(current, NULL);
        spin_unlock_irqrestore(&show_lock, flags);
 }