serial/arc: remove earlyprintk support and switch to earlycon
authorVineet Gupta <Vineet.Gupta1@synopsys.com>
Tue, 24 Jun 2014 08:25:10 +0000 (13:55 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 10 Jul 2014 22:43:27 +0000 (15:43 -0700)
Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
Reviewed-by: Rob Herring <robh@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/arc/boot/dts/angel4.dts
drivers/tty/serial/arc_uart.c

index 5bb2fdaca02f9ace5f92a3934d0be7cb79d4c697..6b57475967a6f7abef31275a9e63f090468399bb 100644 (file)
@@ -17,7 +17,7 @@
        interrupt-parent = <&intc>;
 
        chosen {
-               bootargs = "console=ttyARC0,115200n8 earlyprintk=ttyARC0";
+               bootargs = "earlycon=arc_uart,mmio32,0xc0fc1000,115200n8 console=ttyARC0,115200n8";
        };
 
        aliases {
index 41d2e351c06d8945c9b0a6170b2c8057afb4fac8..94d345bfd08dbe7c370a42a709eca54f09f5b958 100644 (file)
@@ -492,33 +492,23 @@ static int
 arc_uart_init_one(struct platform_device *pdev, int dev_id)
 {
        struct resource *res, *res2;
-       unsigned long *plat_data;
        struct arc_uart_port *uart = &arc_uart_ports[dev_id];
        struct uart_port *port = &uart->port;
 
-       plat_data = dev_get_platdata(&pdev->dev);
-       if (!plat_data)
-               return -ENODEV;
+       struct device_node *np = pdev->dev.of_node;
+       u32 val;
 
-       if (is_early_platform_device(pdev)) {
-               port->uartclk = plat_data[1];
-               uart->baud = plat_data[2];
-       } else {
-               struct device_node *np = pdev->dev.of_node;
-               u32 val;
-
-               if (of_property_read_u32(np, "clock-frequency", &val)) {
-                       dev_err(&pdev->dev, "clock-frequency property NOTset\n");
-                       return -EINVAL;
-               }
-               port->uartclk = val;
-
-               if (of_property_read_u32(np, "current-speed", &val)) {
-                       dev_err(&pdev->dev, "current-speed property NOT set\n");
-                       return -EINVAL;
-               }
-               uart->baud = val;
+       if (of_property_read_u32(np, "clock-frequency", &val)) {
+               dev_err(&pdev->dev, "clock-frequency property NOTset\n");
+               return -EINVAL;
        }
+       port->uartclk = val;
+
+       if (of_property_read_u32(np, "current-speed", &val)) {
+               dev_err(&pdev->dev, "current-speed property NOT set\n");
+               return -EINVAL;
+       }
+       uart->baud = val;
 
        res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
        if (!res)
@@ -607,38 +597,6 @@ static struct console arc_console = {
        .data   = &arc_uart_driver
 };
 
-static __init void early_serial_write(struct console *con, const char *s,
-                                       unsigned int n)
-{
-       struct uart_port *port = &arc_uart_ports[con->index].port;
-
-       uart_console_write(port, s, n, arc_serial_poll_putchar);
-}
-
-static struct console arc_early_serial_console __initdata = {
-       .name = "early_ARCuart",
-       .write = early_serial_write,
-       .flags = CON_PRINTBUFFER | CON_BOOT,
-       .index = -1
-};
-
-static int __init arc_serial_probe_earlyprintk(struct platform_device *pdev)
-{
-       int dev_id = pdev->id < 0 ? 0 : pdev->id;
-       int rc;
-
-       arc_early_serial_console.index = dev_id;
-
-       rc = arc_uart_init_one(pdev, dev_id);
-       if (rc)
-               panic("early console init failed\n");
-
-       arc_serial_console_setup(&arc_early_serial_console, NULL);
-
-       register_console(&arc_early_serial_console);
-       return 0;
-}
-
 static __init void arc_early_serial_write(struct console *con, const char *s,
                                          unsigned int n)
 {
@@ -713,27 +671,6 @@ static struct platform_driver arc_platform_driver = {
         },
 };
 
-#ifdef CONFIG_SERIAL_ARC_CONSOLE
-
-static struct platform_driver early_arc_platform_driver __initdata = {
-       .probe = arc_serial_probe_earlyprintk,
-       .remove = arc_serial_remove,
-       .driver = {
-               .name = DRIVER_NAME,
-               .owner = THIS_MODULE,
-        },
-};
-/*
- * Register an early platform driver of "earlyprintk" class.
- * ARCH platform code installs the driver and probes the early devices
- * The installation could rely on user specifying earlyprintk=xyx in cmd line
- * or it could be done independently, for all "earlyprintk" class drivers.
- * [see arch/arc/plat-arcfpga/platform.c]
- */
-early_platform_init("earlyprintk", &early_arc_platform_driver);
-
-#endif  /* CONFIG_SERIAL_ARC_CONSOLE */
-
 static int __init arc_serial_init(void)
 {
        int ret;