]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/commitdiff
tty: serial: msm_serial: Remove __init from msm_console_setup()
authorJeffrey Hugo <jhugo@codeaurora.org>
Sun, 17 Feb 2019 05:05:52 +0000 (22:05 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 19 Feb 2019 12:42:08 +0000 (13:42 +0100)
Due to the complexities of modern Qualcomm SoCs, about a half dozen drivers
must successfully probe before the clocks for the console are present, and
the console can successfully probe.  Depending on several random factors
such as probe order and modules vs builtin, msm_serial may not be able to
successfully probe for some, at which point, __init annotated functions
may become unmapped.  If this occurs, msm_console_setup() will be called
from the probe path, but will no longer exist, resulting in a kernel
panic.

Resolve this issue by removing the __init annotation from
msm_console_setup().

Signed-off-by: Jeffrey Hugo <jhugo@codeaurora.org>
Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/msm_serial.c

index 736b74fd6623760b997a223190ddbc4355f43411..109096033bb17a76e99369edc1cec534ebd93afe 100644 (file)
@@ -1634,7 +1634,7 @@ static void msm_console_write(struct console *co, const char *s,
        __msm_console_write(port, s, count, msm_port->is_uartdm);
 }
 
-static int __init msm_console_setup(struct console *co, char *options)
+static int msm_console_setup(struct console *co, char *options)
 {
        struct uart_port *port;
        int baud = 115200;