From: YueHaibing Date: Sat, 31 Oct 2020 03:10:53 +0000 (+0800) Subject: sfp: Fix error handing in sfp_probe() X-Git-Tag: v5.9.7~98 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=a3b186c962a6db00b1b0567bbb38f3dd6cd3800b;p=users%2Fdwmw2%2Flinux.git sfp: Fix error handing in sfp_probe() [ Upstream commit 9621618130bf7e83635367c13b9a6ee53935bb37 ] gpiod_to_irq() never return 0, but returns negative in case of error, check it and set gpio_irq to 0. Fixes: 73970055450e ("sfp: add SFP module support") Signed-off-by: YueHaibing Reviewed-by: Andrew Lunn Link: https://lore.kernel.org/r/20201031031053.25264-1-yuehaibing@huawei.com Signed-off-by: Jakub Kicinski Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/net/phy/sfp.c b/drivers/net/phy/sfp.c index cf83314c8591e..60b934482dbba 100644 --- a/drivers/net/phy/sfp.c +++ b/drivers/net/phy/sfp.c @@ -2389,7 +2389,8 @@ static int sfp_probe(struct platform_device *pdev) continue; sfp->gpio_irq[i] = gpiod_to_irq(sfp->gpio[i]); - if (!sfp->gpio_irq[i]) { + if (sfp->gpio_irq[i] < 0) { + sfp->gpio_irq[i] = 0; sfp->need_poll = true; continue; }