aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips/loongson/common/serial.c
diff options
context:
space:
mode:
authorWu Zhangjin <wuzhangjin@gmail.com>2009-10-16 02:17:18 -0400
committerRalf Baechle <ralf@linux-mips.org>2009-12-16 20:57:04 -0500
commite8be5283881cb96bafb751e1f9ea34c4e6fc2845 (patch)
tree83e28f874ea451b7c1a024cf265f9913ef3125e7 /arch/mips/loongson/common/serial.c
parentdb54ff246eae5acb6b7dffec2c05e682f91e0f4e (diff)
MIPS: Loongson: Add serial port support
This patch add serial port support for all of the existing loongson family machines. most of the board specific part are put in serial.c, and the base address of the serial ports are defined as macros in machine.h for sharing it between serial.c and early_printk.c Signed-off-by: Wu Zhangjin <wuzhangjin@gmail.com> Cc: Linux-MIPS <linux-mips@linux-mips.org> Cc: yanh@lemote.com Cc: huhb@lemote.com Cc: Zhang Le <r0bertz@gentoo.org> Cc: zhangfx@lemote.com Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips/loongson/common/serial.c')
-rw-r--r--arch/mips/loongson/common/serial.c71
1 files changed, 71 insertions, 0 deletions
diff --git a/arch/mips/loongson/common/serial.c b/arch/mips/loongson/common/serial.c
new file mode 100644
index 000000000000..6d341e426f64
--- /dev/null
+++ b/arch/mips/loongson/common/serial.c
@@ -0,0 +1,71 @@
1/*
2 * This file is subject to the terms and conditions of the GNU General Public
3 * License. See the file "COPYING" in the main directory of this archive
4 * for more details.
5 *
6 * Copyright (C) 2007 Ralf Baechle (ralf@linux-mips.org)
7 *
8 * Copyright (C) 2009 Lemote, Inc.
9 * Author: Yan hua (yanhua@lemote.com)
10 * Author: Wu Zhangjin (wuzj@lemote.com)
11 */
12
13#include <linux/io.h>
14#include <linux/init.h>
15#include <linux/serial_8250.h>
16
17#include <asm/bootinfo.h>
18
19#include <loongson.h>
20#include <machine.h>
21
22#define PORT(int) \
23{ \
24 .irq = int, \
25 .uartclk = 1843200, \
26 .iobase = (LOONGSON_UART_BASE - LOONGSON_PCIIO_BASE),\
27 .iotype = UPIO_PORT, \
28 .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST, \
29 .regshift = 0, \
30}
31
32#define PORT_M(int) \
33{ \
34 .irq = MIPS_CPU_IRQ_BASE + (int), \
35 .uartclk = 3686400, \
36 .iotype = UPIO_MEM, \
37 .membase = (void __iomem *)NULL, \
38 .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST, \
39 .regshift = 0, \
40}
41
42static struct plat_serial8250_port uart8250_data[][2] = {
43 [MACH_LOONGSON_UNKNOWN] {},
44 [MACH_LEMOTE_FL2E] {PORT(4), {} },
45 [MACH_LEMOTE_FL2F] {PORT(3), {} },
46 [MACH_LEMOTE_ML2F7] {PORT_M(3), {} },
47 [MACH_LEMOTE_YL2F89] {PORT_M(3), {} },
48 [MACH_DEXXON_GDIUM2F10] {PORT_M(3), {} },
49 [MACH_LOONGSON_END] {},
50};
51
52static struct platform_device uart8250_device = {
53 .name = "serial8250",
54 .id = PLAT8250_DEV_PLATFORM,
55 .dev = {
56 .platform_data = uart8250_data[LOONGSON_MACHTYPE],
57 },
58};
59
60static int __init serial_init(void)
61{
62 if (uart8250_data[LOONGSON_MACHTYPE][0].iotype == UPIO_MEM)
63 uart8250_data[LOONGSON_MACHTYPE][0].membase =
64 ioremap_nocache(LOONGSON_UART_BASE, 8);
65
66 platform_device_register(&uart8250_device);
67
68 return 0;
69}
70
71device_initcall(serial_init);