diff options
author | Thomas Bogendoerfer <tsbogend@alpha.franken.de> | 2017-05-31 16:21:03 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2017-06-03 05:48:52 -0400 |
commit | e279e6d98e0cf2c2fe008b3c29042b92f0e17b1d (patch) | |
tree | 127bd5ae03ce7db4479ed8bfb7bb664cb8828edc /drivers/tty/serial/sccnxp.c | |
parent | 8a8dabf2dd68caff842d38057097c23bc514ea6e (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.c | 15 |
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)) { |