net: ethernet: cpsw: fix erroneous condition in error check
authorLothar Waßmann <LW@KARO-electronics.de>
Thu, 21 Mar 2013 02:20:11 +0000 (02:20 +0000)
committerDavid S. Miller <davem@davemloft.net>
Thu, 21 Mar 2013 15:57:42 +0000 (11:57 -0400)
The error check in cpsw_probe_dt() has an '&&' where an '||' is
meant to be. This causes a NULL pointer dereference when incomplet DT
data is passed to the driver ('phy_id' property for cpsw_emac1
missing).

Signed-off-by: Lothar Waßmann <LW@KARO-electronics.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/ti/cpsw.c

index 75c48558e6fd9b8afe355cbe41d95ab9dd842206..df32a090d08e0c96841a9958b1c1319eb6cbbc19 100644 (file)
@@ -1364,7 +1364,7 @@ static int cpsw_probe_dt(struct cpsw_platform_data *data,
                struct platform_device *mdio;
 
                parp = of_get_property(slave_node, "phy_id", &lenp);
-               if ((parp == NULL) && (lenp != (sizeof(void *) * 2))) {
+               if ((parp == NULL) || (lenp != (sizeof(void *) * 2))) {
                        pr_err("Missing slave[%d] phy_id property\n", i);
                        ret = -EINVAL;
                        goto error_ret;