mirror of
https://github.com/torvalds/linux.git
synced 2024-11-23 20:51:44 +00:00
net: hns: fix device reference leaks
Make sure to drop the reference taken by class_find_device() in
hnae_get_handle() on errors and when later releasing the handle.
Fixes: 6fe6611ff2
("net: add Hisilicon Network Subsystem...")
Cc: Yisen Zhuang <yisen.zhuang@huawei.com>
Cc: Salil Mehta <salil.mehta@huawei.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
6bed011801
commit
2271150bfb
@ -332,8 +332,10 @@ struct hnae_handle *hnae_get_handle(struct device *owner_dev,
|
||||
return ERR_PTR(-ENODEV);
|
||||
|
||||
handle = dev->ops->get_handle(dev, port_id);
|
||||
if (IS_ERR(handle))
|
||||
if (IS_ERR(handle)) {
|
||||
put_device(&dev->cls_dev);
|
||||
return handle;
|
||||
}
|
||||
|
||||
handle->dev = dev;
|
||||
handle->owner_dev = owner_dev;
|
||||
@ -356,6 +358,8 @@ out_when_init_queue:
|
||||
for (j = i - 1; j >= 0; j--)
|
||||
hnae_fini_queue(handle->qs[j]);
|
||||
|
||||
put_device(&dev->cls_dev);
|
||||
|
||||
return ERR_PTR(-ENOMEM);
|
||||
}
|
||||
EXPORT_SYMBOL(hnae_get_handle);
|
||||
@ -377,6 +381,8 @@ void hnae_put_handle(struct hnae_handle *h)
|
||||
dev->ops->put_handle(h);
|
||||
|
||||
module_put(dev->owner);
|
||||
|
||||
put_device(&dev->cls_dev);
|
||||
}
|
||||
EXPORT_SYMBOL(hnae_put_handle);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user