Commit ab9c73cc authored by Jiri Pirko's avatar Jiri Pirko Committed by David S. Miller

net: check retval of dev_addr_init()

Add missed checking of dev_addr_init return value in alloc_netdev_mq.
Signed-off-by: default avatarJiri Pirko <jpirko@redhat.com>

 net/core/dev.c |   15 ++++++++++++---
 1 files changed, 12 insertions(+), 3 deletions(-)
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 9948bb6a
...@@ -5007,13 +5007,16 @@ struct net_device *alloc_netdev_mq(int sizeof_priv, const char *name, ...@@ -5007,13 +5007,16 @@ struct net_device *alloc_netdev_mq(int sizeof_priv, const char *name,
if (!tx) { if (!tx) {
printk(KERN_ERR "alloc_netdev: Unable to allocate " printk(KERN_ERR "alloc_netdev: Unable to allocate "
"tx qdiscs.\n"); "tx qdiscs.\n");
kfree(p); goto free_p;
return NULL;
} }
dev = (struct net_device *) dev = (struct net_device *)
(((long)p + NETDEV_ALIGN_CONST) & ~NETDEV_ALIGN_CONST); (((long)p + NETDEV_ALIGN_CONST) & ~NETDEV_ALIGN_CONST);
dev->padded = (char *)dev - (char *)p; dev->padded = (char *)dev - (char *)p;
if (dev_addr_init(dev))
goto free_tx;
dev_net_set(dev, &init_net); dev_net_set(dev, &init_net);
dev->_tx = tx; dev->_tx = tx;
...@@ -5022,13 +5025,19 @@ struct net_device *alloc_netdev_mq(int sizeof_priv, const char *name, ...@@ -5022,13 +5025,19 @@ struct net_device *alloc_netdev_mq(int sizeof_priv, const char *name,
dev->gso_max_size = GSO_MAX_SIZE; dev->gso_max_size = GSO_MAX_SIZE;
dev_addr_init(dev);
netdev_init_queues(dev); netdev_init_queues(dev);
INIT_LIST_HEAD(&dev->napi_list); INIT_LIST_HEAD(&dev->napi_list);
setup(dev); setup(dev);
strcpy(dev->name, name); strcpy(dev->name, name);
return dev; return dev;
free_tx:
kfree(tx);
free_p:
kfree(p);
return NULL;
} }
EXPORT_SYMBOL(alloc_netdev_mq); EXPORT_SYMBOL(alloc_netdev_mq);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment