2011-02-14 00:33:10 -07:00
|
|
|
/* linux/arch/arm/mach-exynos4/init.c
|
2010-07-26 06:08:52 -06:00
|
|
|
*
|
|
|
|
* Copyright (c) 2010 Samsung Electronics Co., Ltd.
|
|
|
|
* http://www.samsung.com/
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/serial_core.h>
|
|
|
|
|
|
|
|
#include <plat/cpu.h>
|
|
|
|
#include <plat/devs.h>
|
|
|
|
#include <plat/regs-serial.h>
|
|
|
|
|
2011-02-14 00:33:10 -07:00
|
|
|
static struct s3c24xx_uart_clksrc exynos4_serial_clocks[] = {
|
2010-07-26 06:08:52 -06:00
|
|
|
[0] = {
|
|
|
|
.name = "uclk1",
|
|
|
|
.divisor = 1,
|
|
|
|
.min_baud = 0,
|
|
|
|
.max_baud = 0,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
/* uart registration process */
|
2011-02-14 00:33:10 -07:00
|
|
|
void __init exynos4_common_init_uarts(struct s3c2410_uartcfg *cfg, int no)
|
2010-07-26 06:08:52 -06:00
|
|
|
{
|
|
|
|
struct s3c2410_uartcfg *tcfg = cfg;
|
|
|
|
u32 ucnt;
|
|
|
|
|
|
|
|
for (ucnt = 0; ucnt < no; ucnt++, tcfg++) {
|
|
|
|
if (!tcfg->clocks) {
|
|
|
|
tcfg->has_fracval = 1;
|
2011-02-14 00:33:10 -07:00
|
|
|
tcfg->clocks = exynos4_serial_clocks;
|
|
|
|
tcfg->clocks_size = ARRAY_SIZE(exynos4_serial_clocks);
|
2010-07-26 06:08:52 -06:00
|
|
|
}
|
2011-05-27 20:04:03 -06:00
|
|
|
tcfg->flags |= NO_NEED_CHECK_CLKSRC;
|
2010-07-26 06:08:52 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
s3c24xx_init_uartdevs("s5pv210-uart", s5p_uart_resources, cfg, no);
|
|
|
|
}
|