]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
serial: 8250_uniphier: flatten probe function
authorMasahiro Yamada <yamada.masahiro@socionext.com>
Fri, 28 Sep 2018 02:05:08 +0000 (11:05 +0900)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 2 Oct 2018 20:38:58 +0000 (13:38 -0700)
Currently, the DT-related settings are split out to
uniphier_of_serial_setup(), but it turned out to be not nice.
The next commit will add a DT property, but it will not fit in
the helper.  Merge the helper into the probe function.

Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/8250/8250_uniphier.c

index d292654422b245592d037ea5cea187595814deac..1028c02c5d8384b466b44009935ddd5a6ba999bc 100644 (file)
@@ -155,36 +155,6 @@ static void uniphier_serial_dl_write(struct uart_8250_port *up, int value)
        writel(value, up->port.membase + UNIPHIER_UART_DLR);
 }
 
-static int uniphier_of_serial_setup(struct device *dev, struct uart_port *port,
-                                   struct uniphier8250_priv *priv)
-{
-       int ret;
-       u32 prop;
-       struct device_node *np = dev->of_node;
-
-       ret = of_alias_get_id(np, "serial");
-       if (ret < 0) {
-               dev_err(dev, "failed to get alias id\n");
-               return ret;
-       }
-       port->line = ret;
-
-       /* Get clk rate through clk driver */
-       priv->clk = devm_clk_get(dev, NULL);
-       if (IS_ERR(priv->clk)) {
-               dev_err(dev, "failed to get clock\n");
-               return PTR_ERR(priv->clk);
-       }
-
-       ret = clk_prepare_enable(priv->clk);
-       if (ret < 0)
-               return ret;
-
-       port->uartclk = clk_get_rate(priv->clk);
-
-       return 0;
-}
-
 static int uniphier_uart_probe(struct platform_device *pdev)
 {
        struct device *dev = &pdev->dev;
@@ -217,9 +187,24 @@ static int uniphier_uart_probe(struct platform_device *pdev)
 
        memset(&up, 0, sizeof(up));
 
-       ret = uniphier_of_serial_setup(dev, &up.port, priv);
-       if (ret < 0)
+       ret = of_alias_get_id(dev->of_node, "serial");
+       if (ret < 0) {
+               dev_err(dev, "failed to get alias id\n");
                return ret;
+       }
+       up.port.line = ret;
+
+       priv->clk = devm_clk_get(dev, NULL);
+       if (IS_ERR(priv->clk)) {
+               dev_err(dev, "failed to get clock\n");
+               return PTR_ERR(priv->clk);
+       }
+
+       ret = clk_prepare_enable(priv->clk);
+       if (ret)
+               return ret;
+
+       up.port.uartclk = clk_get_rate(priv->clk);
 
        spin_lock_init(&priv->atomic_write_lock);