IB/ipoib: Warn when one port fails to initialize
authorYuval Shaia <yuval.shaia@oracle.com>
Wed, 29 Nov 2017 06:34:02 +0000 (08:34 +0200)
committerJason Gunthorpe <jgg@mellanox.com>
Wed, 13 Dec 2017 17:55:49 +0000 (10:55 -0700)
If one port fails to initialize an error message should indicate the
reason and driver should continue serving the working port(s) and other
HCA(s).

Fixes: e4b2d06892c7 ("IB/ipoib: Remove device when one port fails to init").
Signed-off-by: Yuval Shaia <yuval.shaia@oracle.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/ulp/ipoib/ipoib_main.c

index 6930ee0..567dbd4 100644 (file)
@@ -2196,8 +2196,10 @@ static struct net_device *ipoib_add_port(const char *format,
        int result = -ENOMEM;
 
        priv = ipoib_intf_alloc(hca, port, format);
-       if (!priv)
+       if (!priv) {
+               pr_warn("%s, %d: ipoib_intf_alloc failed\n", hca->name, port);
                goto alloc_mem_failed;
+       }
 
        SET_NETDEV_DEV(priv->dev, hca->dev.parent);
        priv->dev->dev_id = port - 1;
@@ -2325,8 +2327,7 @@ static void ipoib_add_one(struct ib_device *device)
        }
 
        if (!count) {
-               pr_err("Failed to init port, removing it\n");
-               ipoib_remove_one(device, dev_list);
+               kfree(dev_list);
                return;
        }