summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Boyd <sboyd@codeaurora.org>2014-11-14 10:39:21 -0800
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2014-11-24 11:28:23 -0800
commit7920408b0c8292831f064ea33f56aa307b221a2c (patch)
tree7254a6378aae80e1366d3cd5f4524a00809e5660
parent52c40fca1a80abaffd9f7315de568d89a2064734 (diff)
downloadlinux-7920408b0c8292831f064ea33f56aa307b221a2c.tar.gz
linux-7920408b0c8292831f064ea33f56aa307b221a2c.tar.bz2
linux-7920408b0c8292831f064ea33f56aa307b221a2c.zip
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>
-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)
const struct of_device_id *id;
int irq, line;
- if (pdev->id == -1)
- pdev->id = atomic_inc_return(&msm_uart_next_id) - 1;
-
if (pdev->dev.of_node)
line = of_alias_get_id(pdev->dev.of_node, "serial");
else
line = pdev->id;
+ if (line < 0)
+ line = atomic_inc_return(&msm_uart_next_id) - 1;
+
if (unlikely(line < 0 || line >= UART_NR))
return -ENXIO;