aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/tty
diff options
context:
space:
mode:
authorStephen Boyd <sboyd@codeaurora.org>2014-11-14 13:39:21 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2014-11-24 14:28:23 -0500
commit7920408b0c8292831f064ea33f56aa307b221a2c (patch)
tree7254a6378aae80e1366d3cd5f4524a00809e5660 /drivers/tty
parent52c40fca1a80abaffd9f7315de568d89a2064734 (diff)
tty: serial: msm_serial: Don't require DT aliases
If there isn't a DT alias then of_alias_get_id() will return -ENODEV. This will cause the msm_serial driver to fail probe, when we want to keep the previous behavior where we generated a dynamic line number at probe time. Restore this behavior by generating a dynamic id if the line number is still negative after checking for an alias or in the non-DT case looking at the .id field of the platform device. Reported-by: Kevin Hilman <khilman@kernel.org> Tested-by: Kevin Hilman <khilman@linaro.org> Signed-off-by: Stephen Boyd <sboyd@codeaurora.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/tty')
-rw-r--r--drivers/tty/serial/msm_serial.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/tty/serial/msm_serial.c b/drivers/tty/serial/msm_serial.c
index 09364dd8cf3a..d1bc6b6cbc70 100644
--- a/drivers/tty/serial/msm_serial.c
+++ b/drivers/tty/serial/msm_serial.c
@@ -1046,14 +1046,14 @@ static int msm_serial_probe(struct platform_device *pdev)
1046 const struct of_device_id *id; 1046 const struct of_device_id *id;
1047 int irq, line; 1047 int irq, line;
1048 1048
1049 if (pdev->id == -1)
1050 pdev->id = atomic_inc_return(&msm_uart_next_id) - 1;
1051
1052 if (pdev->dev.of_node) 1049 if (pdev->dev.of_node)
1053 line = of_alias_get_id(pdev->dev.of_node, "serial"); 1050 line = of_alias_get_id(pdev->dev.of_node, "serial");
1054 else 1051 else
1055 line = pdev->id; 1052 line = pdev->id;
1056 1053
1054 if (line < 0)
1055 line = atomic_inc_return(&msm_uart_next_id) - 1;
1056
1057 if (unlikely(line < 0 || line >= UART_NR)) 1057 if (unlikely(line < 0 || line >= UART_NR))
1058 return -ENXIO; 1058 return -ENXIO;
1059 1059