Commit 928e9263 authored by Michal Simek's avatar Michal Simek Committed by Greg Kroah-Hartman

tty: xuartps: Initialize ports according to aliases

Register port numbers according to order in DT aliases.
If aliases are not defined, order in DT is used.
If aliases are defined, register port id based
on that.
This patch ensures proper ttyPS0/1 assignment.

[soren]: Combined integer declarations in probe(), removed warning message
if no alias is found.
Signed-off-by: default avatarMichal Simek <michal.simek@xilinx.com>
Signed-off-by: default avatarSoren Brinkmann <soren.brinkmann@xilinx.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 489810a1
...@@ -1031,17 +1031,21 @@ static struct uart_port xuartps_port[2]; ...@@ -1031,17 +1031,21 @@ static struct uart_port xuartps_port[2];
* xuartps_get_port - Configure the port from the platform device resource * xuartps_get_port - Configure the port from the platform device resource
* info * info
* *
* @id: Port id
*
* Return: a pointer to a uart_port or NULL for failure * Return: a pointer to a uart_port or NULL for failure
*/ */
static struct uart_port *xuartps_get_port(void) static struct uart_port *xuartps_get_port(int id)
{ {
struct uart_port *port; struct uart_port *port;
int id;
/* Find the next unused port */ /* Try the given port id if failed use default method */
for (id = 0; id < XUARTPS_NR_PORTS; id++) if (xuartps_port[id].mapbase != 0) {
if (xuartps_port[id].mapbase == 0) /* Find the next unused port */
break; for (id = 0; id < XUARTPS_NR_PORTS; id++)
if (xuartps_port[id].mapbase == 0)
break;
}
if (id >= XUARTPS_NR_PORTS) if (id >= XUARTPS_NR_PORTS)
return NULL; return NULL;
...@@ -1329,7 +1333,7 @@ static SIMPLE_DEV_PM_OPS(xuartps_dev_pm_ops, xuartps_suspend, xuartps_resume); ...@@ -1329,7 +1333,7 @@ static SIMPLE_DEV_PM_OPS(xuartps_dev_pm_ops, xuartps_suspend, xuartps_resume);
*/ */
static int xuartps_probe(struct platform_device *pdev) static int xuartps_probe(struct platform_device *pdev)
{ {
int rc; int rc, id;
struct uart_port *port; struct uart_port *port;
struct resource *res, *res2; struct resource *res, *res2;
struct xuartps *xuartps_data; struct xuartps *xuartps_data;
...@@ -1380,9 +1384,13 @@ static int xuartps_probe(struct platform_device *pdev) ...@@ -1380,9 +1384,13 @@ static int xuartps_probe(struct platform_device *pdev)
&xuartps_data->clk_rate_change_nb)) &xuartps_data->clk_rate_change_nb))
dev_warn(&pdev->dev, "Unable to register clock notifier.\n"); dev_warn(&pdev->dev, "Unable to register clock notifier.\n");
#endif #endif
/* Look for a serialN alias */
id = of_alias_get_id(pdev->dev.of_node, "serial");
if (id < 0)
id = 0;
/* Initialize the port structure */ /* Initialize the port structure */
port = xuartps_get_port(); port = xuartps_get_port(id);
if (!port) { if (!port) {
dev_err(&pdev->dev, "Cannot get uart_port structure\n"); dev_err(&pdev->dev, "Cannot get uart_port structure\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment