diff options
| author | Sascha Hauer <s.hauer@pengutronix.de> | 2008-07-05 10:02:58 +0200 | 
|---|---|---|
| committer | Robert Schwebel <r.schwebel@pengutronix.de> | 2008-07-05 10:02:58 +0200 | 
| commit | 604cbadce2292d979749e2f5c6c3f75ee10f4c9e (patch) | |
| tree | 33eb35487bb466fc945401099c3a8324ebbe8b66 | |
| parent | fc80a5e3d0480d416e4f53b0680aaf525b5076d8 (diff) | |
MX2 add support for mx2 in i.MX serial driver
add support for mx2 in i.MX serial driver
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
| -rw-r--r-- | arch/arm/mach-mx2/Makefile | 2 | ||||
| -rw-r--r-- | arch/arm/mach-mx2/serial.c | 177 | ||||
| -rw-r--r-- | drivers/serial/imx.c | 6 | 
3 files changed, 181 insertions, 4 deletions
| diff --git a/arch/arm/mach-mx2/Makefile b/arch/arm/mach-mx2/Makefile index db4d9c6f2738..f8f8ecb01c97 100644 --- a/arch/arm/mach-mx2/Makefile +++ b/arch/arm/mach-mx2/Makefile @@ -4,4 +4,4 @@  # Object file lists. -obj-y	:=  system.o generic.o devices.o +obj-y	:=  system.o generic.o devices.o serial.o diff --git a/arch/arm/mach-mx2/serial.c b/arch/arm/mach-mx2/serial.c new file mode 100644 index 000000000000..570c02b8e5df --- /dev/null +++ b/arch/arm/mach-mx2/serial.c @@ -0,0 +1,177 @@ +/* + * Copyright 2006-2007 Freescale Semiconductor, Inc. All Rights Reserved. + * Copyright 2008 Juergen Beisert, kernel@pengutronix.de + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, + * MA 02110-1301, USA. + */ + +#include <linux/module.h> +#include <linux/platform_device.h> +#include <linux/serial.h> +#include <asm/hardware.h> +#include <asm/arch/imx-uart.h> + +static struct resource uart0[] = { +	{ +		.start = UART1_BASE_ADDR, +		.end = UART1_BASE_ADDR + 0x0B5, +		.flags = IORESOURCE_MEM, +	}, { +		.start = MXC_INT_UART1, +		.end = MXC_INT_UART1, +		.flags = IORESOURCE_IRQ, +	}, +}; + +static struct platform_device mxc_uart_device0 = { +	.name = "imx-uart", +	.id = 0, +	.resource = uart0, +	.num_resources = ARRAY_SIZE(uart0), +}; + +static struct resource uart1[] = { +	{ +		.start = UART2_BASE_ADDR, +		.end = UART2_BASE_ADDR + 0x0B5, +		.flags = IORESOURCE_MEM, +	}, { +		.start = MXC_INT_UART2, +		.end = MXC_INT_UART2, +		.flags = IORESOURCE_IRQ, +	}, +}; + +static struct platform_device mxc_uart_device1 = { +	.name = "imx-uart", +	.id = 1, +	.resource = uart1, +	.num_resources = ARRAY_SIZE(uart1), +}; + +static struct resource uart2[] = { +	{ +		.start = UART3_BASE_ADDR, +		.end = UART3_BASE_ADDR + 0x0B5, +		.flags = IORESOURCE_MEM, +	}, { +		.start = MXC_INT_UART3, +		.end = MXC_INT_UART3, +		.flags = IORESOURCE_IRQ, +	}, +}; + +static struct platform_device mxc_uart_device2 = { +	.name = "imx-uart", +	.id = 2, +	.resource = uart2, +	.num_resources = ARRAY_SIZE(uart2), +}; + +static struct resource uart3[] = { +	{ +		.start = UART4_BASE_ADDR, +		.end = UART4_BASE_ADDR + 0x0B5, +		.flags = IORESOURCE_MEM, +	}, { +		.start = MXC_INT_UART4, +		.end = MXC_INT_UART4, +		.flags = IORESOURCE_IRQ, +	}, +}; + +static struct platform_device mxc_uart_device3 = { +	.name = "imx-uart", +	.id = 3, +	.resource = uart3, +	.num_resources = ARRAY_SIZE(uart3), +}; + +static struct resource uart4[] = { +	{ +		.start = UART5_BASE_ADDR, +		.end = UART5_BASE_ADDR + 0x0B5, +		.flags = IORESOURCE_MEM, +	}, { +		.start = MXC_INT_UART5, +		.end = MXC_INT_UART5, +		.flags = IORESOURCE_IRQ, +	}, +}; + +static struct platform_device mxc_uart_device4 = { +	.name = "imx-uart", +	.id = 4, +	.resource = uart4, +	.num_resources = ARRAY_SIZE(uart4), +}; + +static struct resource uart5[] = { +	{ +		.start = UART6_BASE_ADDR, +		.end = UART6_BASE_ADDR + 0x0B5, +		.flags = IORESOURCE_MEM, +	}, { +		.start = MXC_INT_UART6, +		.end = MXC_INT_UART6, +		.flags = IORESOURCE_IRQ, +	}, +}; + +static struct platform_device mxc_uart_device5 = { +	.name = "imx-uart", +	.id = 5, +	.resource = uart5, +	.num_resources = ARRAY_SIZE(uart5), +}; + +/* + * Register only those UARTs that physically exists + */ +int __init imx_init_uart(int uart_no, struct imxuart_platform_data *pdata) +{ +	switch (uart_no) { +	case 0: +		mxc_uart_device0.dev.platform_data = pdata; +		platform_device_register(&mxc_uart_device0); +		break; +	case 1: +		mxc_uart_device1.dev.platform_data = pdata; +		platform_device_register(&mxc_uart_device1); +		break; +#ifndef CONFIG_MXC_IRDA +	case 2: +		mxc_uart_device2.dev.platform_data = pdata; +		platform_device_register(&mxc_uart_device2); +		break; +#endif +	case 3: +		mxc_uart_device3.dev.platform_data = pdata; +		platform_device_register(&mxc_uart_device3); +		break; +	case 4: +		mxc_uart_device4.dev.platform_data = pdata; +		platform_device_register(&mxc_uart_device4); +		break; +	case 5: +		mxc_uart_device5.dev.platform_data = pdata; +		platform_device_register(&mxc_uart_device5); +		break; +	default: +		return -ENODEV; +	} + +	return 0; +} diff --git a/drivers/serial/imx.c b/drivers/serial/imx.c index 549440b098b2..64acb39a51ba 100644 --- a/drivers/serial/imx.c +++ b/drivers/serial/imx.c @@ -62,7 +62,7 @@  #define UBIR  0xa4 /* BRM Incremental Register */  #define UBMR  0xa8 /* BRM Modulator Register */  #define UBRC  0xac /* Baud Rate Count Register */ -#ifdef CONFIG_ARCH_MX3 +#if defined CONFIG_ARCH_MX3 || defined CONFIG_ARCH_MX2  #define ONEMS 0xb0 /* One Millisecond register */  #define UTS   0xb4 /* UART Test Register */  #endif @@ -99,7 +99,7 @@  #ifdef CONFIG_ARCH_IMX  #define  UCR1_UARTCLKEN  (1<<2)	 /* UART clock enabled */  #endif -#ifdef CONFIG_ARCH_MX3 +#if defined CONFIG_ARCH_MX3 || defined CONFIG_ARCH_MX2  #define  UCR1_UARTCLKEN  (0)	 /* not present on mx2/mx3 */  #endif  #define  UCR1_DOZE       (1<<1)	 /* Doze */ @@ -182,7 +182,7 @@  #define MAX_INTERNAL_IRQ	IMX_IRQS  #endif -#ifdef CONFIG_ARCH_MX3 +#if defined CONFIG_ARCH_MX3 || defined CONFIG_ARCH_MX2  #define SERIAL_IMX_MAJOR        207  #define MINOR_START	        16  #define DEV_NAME		"ttymxc" | 
