From: Vikas Manocha Date: Sun, 12 Feb 2017 18:25:46 +0000 (-0800) Subject: stm32f7: serial: use clock driver to enable clock X-Git-Tag: v2017.05-rc1~63 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=fd03b83a9912f265d9ca08a0dd542af3f9b52216;p=oweals%2Fu-boot.git stm32f7: serial: use clock driver to enable clock Signed-off-by: Vikas Manocha Reviewed-by: Simon Glass --- diff --git a/drivers/serial/serial_stm32x7.c b/drivers/serial/serial_stm32x7.c index 2e6c67688c..1907cef5b3 100644 --- a/drivers/serial/serial_stm32x7.c +++ b/drivers/serial/serial_stm32x7.c @@ -6,6 +6,7 @@ */ #include +#include #include #include #include @@ -76,6 +77,22 @@ static int stm32_serial_probe(struct udevice *dev) { struct stm32x7_serial_platdata *plat = dev->platdata; struct stm32_usart *const usart = plat->base; + +#ifdef CONFIG_CLK + int ret; + struct clk clk; + + ret = clk_get_by_index(dev, 0, &clk); + if (ret < 0) + return ret; + + ret = clk_enable(&clk); + if (ret) { + dev_err(dev, "failed to enable clock\n"); + return ret; + } +#endif + setbits_le32(&usart->cr1, USART_CR1_RE | USART_CR1_TE | USART_CR1_UE); return 0; @@ -98,6 +115,7 @@ static int stm32_serial_ofdata_to_platdata(struct udevice *dev) return -EINVAL; plat->base = (struct stm32_usart *)addr; + return 0; } #endif