Commit 066cd1c4 authored by Karthikeyan Ramasubramanian's avatar Karthikeyan Ramasubramanian Committed by Greg Kroah-Hartman

tty: serial: qcom_geni_serial: Use signed variable to get IRQ

The platform_get_irq can return error. Assigning the return value to an
unsigned variable and checking it for negative value will always return
false.

Use an intermediate signed variable to get IRQ information, check for any
error and then assign it to 'irq' variable inside uart_port structure.
Signed-off-by: default avatarKarthikeyan Ramasubramanian <kramasub@codeaurora.org>
Reported-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Reviewed-by: default avatarStephen Boyd <swboyd@chromium.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent dd709e72
...@@ -1022,6 +1022,7 @@ static int qcom_geni_serial_probe(struct platform_device *pdev) ...@@ -1022,6 +1022,7 @@ static int qcom_geni_serial_probe(struct platform_device *pdev)
struct qcom_geni_serial_port *port; struct qcom_geni_serial_port *port;
struct uart_port *uport; struct uart_port *uport;
struct resource *res; struct resource *res;
int irq;
if (pdev->dev.of_node) if (pdev->dev.of_node)
line = of_alias_get_id(pdev->dev.of_node, "serial"); line = of_alias_get_id(pdev->dev.of_node, "serial");
...@@ -1061,11 +1062,12 @@ static int qcom_geni_serial_probe(struct platform_device *pdev) ...@@ -1061,11 +1062,12 @@ static int qcom_geni_serial_probe(struct platform_device *pdev)
port->rx_fifo_depth = DEF_FIFO_DEPTH_WORDS; port->rx_fifo_depth = DEF_FIFO_DEPTH_WORDS;
port->tx_fifo_width = DEF_FIFO_WIDTH_BITS; port->tx_fifo_width = DEF_FIFO_WIDTH_BITS;
uport->irq = platform_get_irq(pdev, 0); irq = platform_get_irq(pdev, 0);
if (uport->irq < 0) { if (irq < 0) {
dev_err(&pdev->dev, "Failed to get IRQ %d\n", uport->irq); dev_err(&pdev->dev, "Failed to get IRQ %d\n", irq);
return uport->irq; return irq;
} }
uport->irq = irq;
uport->private_data = &qcom_geni_console_driver; uport->private_data = &qcom_geni_console_driver;
platform_set_drvdata(pdev, port); platform_set_drvdata(pdev, port);
......
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