diff options
author | Arvind Yadav <arvind.yadav.cs@gmail.com> | 2018-03-06 15:40:37 +0530 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2018-05-30 07:47:36 +0200 |
commit | 7f4ac642d59dcdc169f560361301f65ff888233d (patch) | |
tree | c00146a957411c58560a68f629d5b0ac1cffdf18 | |
parent | db57535b77b8de5646291f368f50f9494800bff5 (diff) | |
download | linux-stable-7f4ac642d59dcdc169f560361301f65ff888233d.tar.gz linux-stable-7f4ac642d59dcdc169f560361301f65ff888233d.tar.bz2 linux-stable-7f4ac642d59dcdc169f560361301f65ff888233d.zip |
xen: xenbus: use put_device() instead of kfree()
[ Upstream commit 351b2bccede1cb673ec7957b35ea997ea24c8884 ]
Never directly free @dev after calling device_register(), even
if it returned an error! Always use put_device() to give up the
reference initialized.
Signed-off-by: Arvind Yadav <arvind.yadav.cs@gmail.com>
Reviewed-by: Juergen Gross <jgross@suse.com>
Signed-off-by: Juergen Gross <jgross@suse.com>
Signed-off-by: Sasha Levin <alexander.levin@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r-- | drivers/xen/xenbus/xenbus_probe.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/xen/xenbus/xenbus_probe.c b/drivers/xen/xenbus/xenbus_probe.c index 5390a674b5e3..5e23fcd45b6a 100644 --- a/drivers/xen/xenbus/xenbus_probe.c +++ b/drivers/xen/xenbus/xenbus_probe.c @@ -470,8 +470,11 @@ int xenbus_probe_node(struct xen_bus_type *bus, /* Register with generic device framework. */ err = device_register(&xendev->dev); - if (err) + if (err) { + put_device(&xendev->dev); + xendev = NULL; goto fail; + } return 0; fail: |