linux-serial.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] tty/serial: digicolor: Fix bad usage of IS_ERR_VALUE
@ 2016-02-09 15:08 Guenter Roeck
       [not found] ` <1455030539-10798-1-git-send-email-linux-0h96xk9xTtrk1uMJSBkQmQ@public.gmane.org>
  2016-02-11  6:50 ` Baruch Siach
  0 siblings, 2 replies; 11+ messages in thread
From: Guenter Roeck @ 2016-02-09 15:08 UTC (permalink / raw)
  To: Greg Kroah-Hartman
  Cc: Jiri Slaby, Baruch Siach, linux-serial, linux-arm-kernel,
	linux-kernel, kernel-testers, Guenter Roeck

IS_ERR_VALUE() assumes that its parameter is an unsigned long.
It can not be used to check if an unsigned int reflects an error.
Doing so can result in the following build warning.

drivers/tty/serial/digicolor-usart.c: In function ‘digicolor_uart_probe’:
include/linux/err.h:21:38: warning:
	comparison is always false due to limited range of data type
drivers/tty/serial/digicolor-usart.c:485:6: note:
	in expansion of macro ‘IS_ERR_VALUE’

If that warning is seen, an error return from platform_get_irq() is missed.

Signed-off-by: Guenter Roeck <linux@roeck-us.net>
---
 drivers/tty/serial/digicolor-usart.c | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/drivers/tty/serial/digicolor-usart.c b/drivers/tty/serial/digicolor-usart.c
index a80cdad114f3..02ad6953b167 100644
--- a/drivers/tty/serial/digicolor-usart.c
+++ b/drivers/tty/serial/digicolor-usart.c
@@ -453,7 +453,7 @@ static struct uart_driver digicolor_uart = {
 static int digicolor_uart_probe(struct platform_device *pdev)
 {
 	struct device_node *np = pdev->dev.of_node;
-	int ret, index;
+	int irq, ret, index;
 	struct digicolor_port *dp;
 	struct resource *res;
 	struct clk *uart_clk;
@@ -481,9 +481,10 @@ static int digicolor_uart_probe(struct platform_device *pdev)
 	if (IS_ERR(dp->port.membase))
 		return PTR_ERR(dp->port.membase);
 
-	dp->port.irq = platform_get_irq(pdev, 0);
-	if (IS_ERR_VALUE(dp->port.irq))
-		return dp->port.irq;
+	irq = platform_get_irq(pdev, 0);
+	if (irq < 0)
+		return irq;
+	dp->port.irq = irq;
 
 	dp->port.iotype = UPIO_MEM;
 	dp->port.uartclk = clk_get_rate(uart_clk);
-- 
2.5.0

^ permalink raw reply related	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2016-02-12  6:38 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-02-09 15:08 [PATCH] tty/serial: digicolor: Fix bad usage of IS_ERR_VALUE Guenter Roeck
     [not found] ` <1455030539-10798-1-git-send-email-linux-0h96xk9xTtrk1uMJSBkQmQ@public.gmane.org>
2016-02-09 15:26   ` Arnd Bergmann
2016-02-10  2:37     ` Guenter Roeck
     [not found]       ` <56BAA27A.9050605-0h96xk9xTtrk1uMJSBkQmQ@public.gmane.org>
2016-02-10 15:21         ` Arnd Bergmann
2016-02-11  3:38           ` Guenter Roeck
     [not found]             ` <56BC022B.7030004-0h96xk9xTtrk1uMJSBkQmQ@public.gmane.org>
2016-02-11  6:45               ` Andrzej Hajda
     [not found]                 ` <56BC2DF7.20803-Sze3O3UU22JBDgjK7y7TUQ@public.gmane.org>
2016-02-11 15:32                   ` Guenter Roeck
2016-02-12  6:38                     ` Andrzej Hajda
2016-02-11 10:46         ` Russell King - ARM Linux
2016-02-11 15:13           ` Guenter Roeck
2016-02-11  6:50 ` Baruch Siach

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).