aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/tty/serial/sccnxp.c
diff options
context:
space:
mode:
authorThomas Bogendoerfer <tsbogend@alpha.franken.de>2017-05-31 16:21:03 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-06-03 05:48:52 -0400
commite279e6d98e0cf2c2fe008b3c29042b92f0e17b1d (patch)
tree127bd5ae03ce7db4479ed8bfb7bb664cb8828edc /drivers/tty/serial/sccnxp.c
parent8a8dabf2dd68caff842d38057097c23bc514ea6e (diff)
Fix serial console on SNI RM400 machines
sccnxp driver doesn't get the correct uart clock rate, if CONFIG_HAVE_CLOCK is disabled. Correct usage of clk API to make it work with/without it. Fixes: 90efa75f7ab0 (serial: sccnxp: Using CLK API for getting UART clock) Suggested-by: Russell King - ARM Linux <linux@armlinux.org.uk> Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/tty/serial/sccnxp.c')
-rw-r--r--drivers/tty/serial/sccnxp.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/drivers/tty/serial/sccnxp.c b/drivers/tty/serial/sccnxp.c
index fcf803ffad19..cdd2f942317c 100644
--- a/drivers/tty/serial/sccnxp.c
+++ b/drivers/tty/serial/sccnxp.c
@@ -884,14 +884,19 @@ static int sccnxp_probe(struct platform_device *pdev)
884 884
885 clk = devm_clk_get(&pdev->dev, NULL); 885 clk = devm_clk_get(&pdev->dev, NULL);
886 if (IS_ERR(clk)) { 886 if (IS_ERR(clk)) {
887 if (PTR_ERR(clk) == -EPROBE_DEFER) { 887 ret = PTR_ERR(clk);
888 ret = -EPROBE_DEFER; 888 if (ret == -EPROBE_DEFER)
889 goto err_out; 889 goto err_out;
890 } 890 uartclk = 0;
891 } else {
892 clk_prepare_enable(clk);
893 uartclk = clk_get_rate(clk);
894 }
895
896 if (!uartclk) {
891 dev_notice(&pdev->dev, "Using default clock frequency\n"); 897 dev_notice(&pdev->dev, "Using default clock frequency\n");
892 uartclk = s->chip->freq_std; 898 uartclk = s->chip->freq_std;
893 } else 899 }
894 uartclk = clk_get_rate(clk);
895 900
896 /* Check input frequency */ 901 /* Check input frequency */
897 if ((uartclk < s->chip->freq_min) || (uartclk > s->chip->freq_max)) { 902 if ((uartclk < s->chip->freq_min) || (uartclk > s->chip->freq_max)) {