Commit 76d57ce6 authored by Sekhar Nori's avatar Sekhar Nori

ARM: davinci: serial: provide API to initialze UART clocks

Provide an API to initialize a UART clock. Refactor existing
davinci_serial_init() to separate out the part which enables
the clock.

This will later be used to help DA850 DT boot support.
Signed-off-by: default avatarSekhar Nori <nsekhar@ti.com>
parent b6f1ffed
...@@ -43,6 +43,7 @@ struct davinci_uart_config { ...@@ -43,6 +43,7 @@ struct davinci_uart_config {
}; };
extern int davinci_serial_init(struct davinci_uart_config *); extern int davinci_serial_init(struct davinci_uart_config *);
extern int davinci_serial_setup_clk(unsigned instance, unsigned int *rate);
#endif #endif
#endif /* __ASM_ARCH_SERIAL_H */ #endif /* __ASM_ARCH_SERIAL_H */
...@@ -70,11 +70,33 @@ static void __init davinci_serial_reset(struct plat_serial8250_port *p) ...@@ -70,11 +70,33 @@ static void __init davinci_serial_reset(struct plat_serial8250_port *p)
UART_DM646X_SCR_TX_WATERMARK); UART_DM646X_SCR_TX_WATERMARK);
} }
int __init davinci_serial_init(struct davinci_uart_config *info) /* Enable UART clock and obtain its rate */
int __init davinci_serial_setup_clk(unsigned instance, unsigned int *rate)
{ {
int i;
char name[16]; char name[16];
struct clk *uart_clk; struct clk *clk;
struct davinci_soc_info *soc_info = &davinci_soc_info;
struct device *dev = &soc_info->serial_dev->dev;
sprintf(name, "uart%d", instance);
clk = clk_get(dev, name);
if (IS_ERR(clk)) {
pr_err("%s:%d: failed to get UART%d clock\n",
__func__, __LINE__, instance);
return PTR_ERR(clk);
}
clk_prepare_enable(clk);
if (rate)
*rate = clk_get_rate(clk);
return 0;
}
int __init davinci_serial_init(struct davinci_uart_config *info)
{
int i, ret;
struct davinci_soc_info *soc_info = &davinci_soc_info; struct davinci_soc_info *soc_info = &davinci_soc_info;
struct device *dev = &soc_info->serial_dev->dev; struct device *dev = &soc_info->serial_dev->dev;
struct plat_serial8250_port *p = dev->platform_data; struct plat_serial8250_port *p = dev->platform_data;
...@@ -87,16 +109,9 @@ int __init davinci_serial_init(struct davinci_uart_config *info) ...@@ -87,16 +109,9 @@ int __init davinci_serial_init(struct davinci_uart_config *info)
if (!(info->enabled_uarts & (1 << i))) if (!(info->enabled_uarts & (1 << i)))
continue; continue;
sprintf(name, "uart%d", i); ret = davinci_serial_setup_clk(i, &p->uartclk);
uart_clk = clk_get(dev, name); if (ret)
if (IS_ERR(uart_clk)) {
printk(KERN_ERR "%s:%d: failed to get UART%d clock\n",
__func__, __LINE__, i);
continue; continue;
}
clk_prepare_enable(uart_clk);
p->uartclk = clk_get_rate(uart_clk);
if (!p->membase && p->mapbase) { if (!p->membase && p->mapbase) {
p->membase = ioremap(p->mapbase, SZ_4K); p->membase = ioremap(p->mapbase, SZ_4K);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment