Wu Zhangjin | e8be528 | 2009-10-16 14:17:18 +0800 | [diff] [blame] | 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) |
Wu Zhangjin | f7a904d | 2010-01-04 17:16:51 +0800 | [diff] [blame] | 10 | * Author: Wu Zhangjin (wuzhangjin@gmail.com) |
Wu Zhangjin | e8be528 | 2009-10-16 14:17:18 +0800 | [diff] [blame] | 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, \ |
Wu Zhangjin | e8be528 | 2009-10-16 14:17:18 +0800 | [diff] [blame] | 26 | .iotype = UPIO_PORT, \ |
| 27 | .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST, \ |
| 28 | .regshift = 0, \ |
| 29 | } |
| 30 | |
| 31 | #define PORT_M(int) \ |
| 32 | { \ |
| 33 | .irq = MIPS_CPU_IRQ_BASE + (int), \ |
| 34 | .uartclk = 3686400, \ |
| 35 | .iotype = UPIO_MEM, \ |
| 36 | .membase = (void __iomem *)NULL, \ |
| 37 | .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST, \ |
| 38 | .regshift = 0, \ |
| 39 | } |
| 40 | |
| 41 | static struct plat_serial8250_port uart8250_data[][2] = { |
Ralf Baechle | 7034228 | 2013-01-22 12:59:30 +0100 | [diff] [blame^] | 42 | [MACH_LOONGSON_UNKNOWN] {}, |
| 43 | [MACH_LEMOTE_FL2E] {PORT(4), {} }, |
| 44 | [MACH_LEMOTE_FL2F] {PORT(3), {} }, |
| 45 | [MACH_LEMOTE_ML2F7] {PORT_M(3), {} }, |
| 46 | [MACH_LEMOTE_YL2F89] {PORT_M(3), {} }, |
| 47 | [MACH_DEXXON_GDIUM2F10] {PORT_M(3), {} }, |
| 48 | [MACH_LEMOTE_NAS] {PORT_M(3), {} }, |
| 49 | [MACH_LEMOTE_LL2F] {PORT(3), {} }, |
| 50 | [MACH_LOONGSON_END] {}, |
Wu Zhangjin | e8be528 | 2009-10-16 14:17:18 +0800 | [diff] [blame] | 51 | }; |
| 52 | |
| 53 | static struct platform_device uart8250_device = { |
| 54 | .name = "serial8250", |
| 55 | .id = PLAT8250_DEV_PLATFORM, |
Wu Zhangjin | e8be528 | 2009-10-16 14:17:18 +0800 | [diff] [blame] | 56 | }; |
| 57 | |
| 58 | static int __init serial_init(void) |
| 59 | { |
Wu Zhangjin | c3d8d85 | 2009-11-28 14:21:50 +0800 | [diff] [blame] | 60 | unsigned char iotype; |
| 61 | |
| 62 | iotype = uart8250_data[mips_machtype][0].iotype; |
| 63 | |
| 64 | if (UPIO_MEM == iotype) |
Wu Zhangjin | a3ed495 | 2009-11-06 18:35:34 +0800 | [diff] [blame] | 65 | uart8250_data[mips_machtype][0].membase = |
| 66 | (void __iomem *)_loongson_uart_base; |
Wu Zhangjin | c3d8d85 | 2009-11-28 14:21:50 +0800 | [diff] [blame] | 67 | else if (UPIO_PORT == iotype) |
Wu Zhangjin | a3ed495 | 2009-11-06 18:35:34 +0800 | [diff] [blame] | 68 | uart8250_data[mips_machtype][0].iobase = |
Wu Zhangjin | c3d8d85 | 2009-11-28 14:21:50 +0800 | [diff] [blame] | 69 | loongson_uart_base - LOONGSON_PCIIO_BASE; |
Wu Zhangjin | e8be528 | 2009-10-16 14:17:18 +0800 | [diff] [blame] | 70 | |
Wu Zhangjin | a3ed495 | 2009-11-06 18:35:34 +0800 | [diff] [blame] | 71 | uart8250_device.dev.platform_data = uart8250_data[mips_machtype]; |
Wu Zhangjin | e8be528 | 2009-10-16 14:17:18 +0800 | [diff] [blame] | 72 | |
Wu Zhangjin | a3ed495 | 2009-11-06 18:35:34 +0800 | [diff] [blame] | 73 | return platform_device_register(&uart8250_device); |
Wu Zhangjin | e8be528 | 2009-10-16 14:17:18 +0800 | [diff] [blame] | 74 | } |
| 75 | |
| 76 | device_initcall(serial_init); |