On Mon, Apr 13, 2015 at 02:25:16PM +0200, Michael Wang wrote:
>       dev_list = kmalloc(sizeof *dev_list, GFP_KERNEL);
>       if (!dev_list)
> @@ -1673,13 +1671,19 @@ static void ipoib_add_one(struct ib_device *device)
>       }
>  
>       for (p = s; p <= e; ++p) {
> -             if (rdma_port_get_link_layer(device, p) != 
> IB_LINK_LAYER_INFINIBAND)
> +             if (!rdma_tech_ib(device, p))
>                       continue;
>               dev = ipoib_add_port("ib%d", device, p);
>               if (!IS_ERR(dev)) {
>                       priv = netdev_priv(dev);
>                       list_add_tail(&priv->list, dev_list);
>               }
> +             count++;
> +     }
> +
> +     if (!count) {
> +             kfree(dev_list);
> +             return;
>       }

This doesn't quite look right, it should be 'goto error1'

But then I read 'goto error1' and it doesn't look like it can handle
cm_dev->port being NULL, so more fixing is needed.

Ditto for cm_remove_one

Should audit all uses of cm_dev->port[] to make sure they can all
handle NULL.

Jason
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to