net: davinci_emac: fix error return code
authorJulia Lawall <julia.lawall@lip6.fr>
Sun, 23 Aug 2015 00:11:14 +0000 (02:11 +0200)
committerDavid S. Miller <davem@davemloft.net>
Tue, 25 Aug 2015 20:37:31 +0000 (13:37 -0700)
Propagate error code on failure.

A simplified version of the semantic match that finds this problem is as
follows: (http://coccinelle.lip6.fr/)

// <smpl>
@@
identifier ret; expression e1,e2;
@@
(
if (\(ret < 0\|ret != 0\))
 { ... return ret; }
|
ret = 0
)
... when != ret = e1
    when != &ret
*if(...)
{
  ... when != ret = e2
      when forall
 return ret;
}
// </smpl>

Signed-off-by: Julia Lawall <Julia.Lawall@lip6.fr>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/ti/davinci_emac.c

index aeebc0a7bf4769aa5b18fe03cec9f4a7a4cdd9d6..a21c77bc1b27c7678ad54a619de608b0d4a2e44e 100644 (file)
@@ -2004,8 +2004,10 @@ static int davinci_emac_probe(struct platform_device *pdev)
        if (res_ctrl) {
                priv->ctrl_base =
                        devm_ioremap_resource(&pdev->dev, res_ctrl);
-               if (IS_ERR(priv->ctrl_base))
+               if (IS_ERR(priv->ctrl_base)) {
+                       rc = PTR_ERR(priv->ctrl_base);
                        goto no_pdata;
+               }
        } else {
                priv->ctrl_base = priv->remap_addr + pdata->ctrl_mod_reg_offset;
        }