-
由 Andy Shevchenko 提交于
The comment near to uart_port_spin_lock_init() says: Ensure that the serial console lock is initialised early. If this port is a console, then the spinlock is already initialised. and there is nothing about enabled or disabled consoles. The commit a3cb39d2 ("serial: core: Allow detach and attach serial device for console") made a change, which follows the comment, and also to prevent reinitialisation of the lock in use, when user detaches and attaches back the same console device. But this change discovers another issue, that uart_add_one_port() tries to access a spin lock that now may be uninitialised. This happens when a driver expects the serial core to register a console on its behalf. In this case we must initialise a spin lock before use. Fixes: a3cb39d2 ("serial: core: Allow detach and attach serial device for console") Reported-by: NMarc Zyngier <maz@kernel.org> Reported-by: NLad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com> Reported-by: NGuenter Roeck <linux@roeck-us.net> Reported-by: NAnatoly Pugachev <matorola@gmail.com> Acked-by: NMarc Zyngier <maz@kernel.org> Tested-by: NTony Lindgren <tony@atomide.com> Cc: Geert Uytterhoeven <geert@linux-m68k.org> Signed-off-by: NAndy Shevchenko <andriy.shevchenko@linux.intel.com> Tested-by: NLad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com> Link: https://lore.kernel.org/r/20200706214903.56148-1-andriy.shevchenko@linux.intel.comSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
f743061a