| 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] = { | 
|  | 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), {} }, | 
| Wu Zhangjin | e13fb77 | 2009-11-17 00:58:14 +0800 | [diff] [blame] | 48 | [MACH_LEMOTE_NAS]               {PORT_M(3), {} }, | 
| Wu Zhangjin | 6e552c9 | 2009-11-17 00:58:15 +0800 | [diff] [blame] | 49 | [MACH_LEMOTE_LL2F]              {PORT(3), {} }, | 
| Wu Zhangjin | e8be528 | 2009-10-16 14:17:18 +0800 | [diff] [blame] | 50 | [MACH_LOONGSON_END]             {}, | 
|  | 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); |