diff options
Diffstat (limited to 'drivers/tty/serial/imx.c')
| -rw-r--r-- | drivers/tty/serial/imx.c | 115 | 
1 files changed, 25 insertions, 90 deletions
| diff --git a/drivers/tty/serial/imx.c b/drivers/tty/serial/imx.c index cacf7266a262..425624d794dd 100644 --- a/drivers/tty/serial/imx.c +++ b/drivers/tty/serial/imx.c @@ -30,7 +30,6 @@  #include <linux/dma-mapping.h>  #include <asm/irq.h> -#include <linux/platform_data/serial-imx.h>  #include <linux/platform_data/dma-imx.h>  #include "serial_mctrl_gpio.h" @@ -263,25 +262,6 @@ static struct imx_uart_data imx_uart_devdata[] = {  	},  }; -static const struct platform_device_id imx_uart_devtype[] = { -	{ -		.name = "imx1-uart", -		.driver_data = (kernel_ulong_t) &imx_uart_devdata[IMX1_UART], -	}, { -		.name = "imx21-uart", -		.driver_data = (kernel_ulong_t) &imx_uart_devdata[IMX21_UART], -	}, { -		.name = "imx53-uart", -		.driver_data = (kernel_ulong_t) &imx_uart_devdata[IMX53_UART], -	}, { -		.name = "imx6q-uart", -		.driver_data = (kernel_ulong_t) &imx_uart_devdata[IMX6Q_UART], -	}, { -		/* sentinel */ -	} -}; -MODULE_DEVICE_TABLE(platform, imx_uart_devtype); -  static const struct of_device_id imx_uart_dt_ids[] = {  	{ .compatible = "fsl,imx6q-uart", .data = &imx_uart_devdata[IMX6Q_UART], },  	{ .compatible = "fsl,imx53-uart", .data = &imx_uart_devdata[IMX53_UART], }, @@ -1881,7 +1861,7 @@ static int imx_uart_poll_init(struct uart_port *port)  	ucr1 |= UCR1_UARTEN;  	ucr1 &= ~(UCR1_TRDYEN | UCR1_RTSDEN | UCR1_RRDYEN); -	ucr2 |= UCR2_RXEN; +	ucr2 |= UCR2_RXEN | UCR2_TXEN;  	ucr2 &= ~UCR2_ATEN;  	imx_uart_writel(sport, ucr1, UCR1); @@ -2183,70 +2163,6 @@ static struct uart_driver imx_uart_uart_driver = {  	.cons           = IMX_CONSOLE,  }; -#ifdef CONFIG_OF -/* - * This function returns 1 iff pdev isn't a device instatiated by dt, 0 iff it - * could successfully get all information from dt or a negative errno. - */ -static int imx_uart_probe_dt(struct imx_port *sport, -			     struct platform_device *pdev) -{ -	struct device_node *np = pdev->dev.of_node; -	int ret; - -	sport->devdata = of_device_get_match_data(&pdev->dev); -	if (!sport->devdata) -		/* no device tree device */ -		return 1; - -	ret = of_alias_get_id(np, "serial"); -	if (ret < 0) { -		dev_err(&pdev->dev, "failed to get alias id, errno %d\n", ret); -		return ret; -	} -	sport->port.line = ret; - -	if (of_get_property(np, "uart-has-rtscts", NULL) || -	    of_get_property(np, "fsl,uart-has-rtscts", NULL) /* deprecated */) -		sport->have_rtscts = 1; - -	if (of_get_property(np, "fsl,dte-mode", NULL)) -		sport->dte_mode = 1; - -	if (of_get_property(np, "rts-gpios", NULL)) -		sport->have_rtsgpio = 1; - -	if (of_get_property(np, "fsl,inverted-tx", NULL)) -		sport->inverted_tx = 1; - -	if (of_get_property(np, "fsl,inverted-rx", NULL)) -		sport->inverted_rx = 1; - -	return 0; -} -#else -static inline int imx_uart_probe_dt(struct imx_port *sport, -				    struct platform_device *pdev) -{ -	return 1; -} -#endif - -static void imx_uart_probe_pdata(struct imx_port *sport, -				 struct platform_device *pdev) -{ -	struct imxuart_platform_data *pdata = dev_get_platdata(&pdev->dev); - -	sport->port.line = pdev->id; -	sport->devdata = (struct imx_uart_data	*) pdev->id_entry->driver_data; - -	if (!pdata) -		return; - -	if (pdata->flags & IMXUART_HAVE_RTSCTS) -		sport->have_rtscts = 1; -} -  static enum hrtimer_restart imx_trigger_start_tx(struct hrtimer *t)  {  	struct imx_port *sport = container_of(t, struct imx_port, trigger_start_tx); @@ -2275,6 +2191,7 @@ static enum hrtimer_restart imx_trigger_stop_tx(struct hrtimer *t)  static int imx_uart_probe(struct platform_device *pdev)  { +	struct device_node *np = pdev->dev.of_node;  	struct imx_port *sport;  	void __iomem *base;  	int ret = 0; @@ -2286,11 +2203,30 @@ static int imx_uart_probe(struct platform_device *pdev)  	if (!sport)  		return -ENOMEM; -	ret = imx_uart_probe_dt(sport, pdev); -	if (ret > 0) -		imx_uart_probe_pdata(sport, pdev); -	else if (ret < 0) +	sport->devdata = of_device_get_match_data(&pdev->dev); + +	ret = of_alias_get_id(np, "serial"); +	if (ret < 0) { +		dev_err(&pdev->dev, "failed to get alias id, errno %d\n", ret);  		return ret; +	} +	sport->port.line = ret; + +	if (of_get_property(np, "uart-has-rtscts", NULL) || +	    of_get_property(np, "fsl,uart-has-rtscts", NULL) /* deprecated */) +		sport->have_rtscts = 1; + +	if (of_get_property(np, "fsl,dte-mode", NULL)) +		sport->dte_mode = 1; + +	if (of_get_property(np, "rts-gpios", NULL)) +		sport->have_rtsgpio = 1; + +	if (of_get_property(np, "fsl,inverted-tx", NULL)) +		sport->inverted_tx = 1; + +	if (of_get_property(np, "fsl,inverted-rx", NULL)) +		sport->inverted_rx = 1;  	if (sport->port.line >= ARRAY_SIZE(imx_uart_ports)) {  		dev_err(&pdev->dev, "serial%d out of range\n", @@ -2639,7 +2575,6 @@ static struct platform_driver imx_uart_platform_driver = {  	.probe = imx_uart_probe,  	.remove = imx_uart_remove, -	.id_table = imx_uart_devtype,  	.driver = {  		.name = "imx-uart",  		.of_match_table = imx_uart_dt_ids, | 
