summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAllen Hung <allen_hung@dell.com>2016-07-15 17:42:22 +0800
committerJean Delvare <jdelvare@suse.de>2016-09-08 10:35:50 +0200
commit9b41b92bbae6a4d3e1f3adde87864fd481037814 (patch)
tree4d433b5ae15b28eea2fa6dd81fe9fe360c7391f2
parentd71f058617564750261b673ea9b3352382b9cde4 (diff)
downloadlinux-9b41b92bbae6a4d3e1f3adde87864fd481037814.tar.gz
linux-9b41b92bbae6a4d3e1f3adde87864fd481037814.tar.bz2
linux-9b41b92bbae6a4d3e1f3adde87864fd481037814.zip
dmi-id: don't free dev structure after calling device_register
dmi_dev is freed in error exit code but, according to the document of device_register, it should never directly free device structure after calling this function, even if it returned an error! Use put_device() instead. Signed-off-by: Allen Hung <allen_hung@dell.com> Signed-off-by: Jean Delvare <jdelvare@suse.de>
-rw-r--r--drivers/firmware/dmi-id.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/drivers/firmware/dmi-id.c b/drivers/firmware/dmi-id.c
index 94a58a082b99..44c01390d035 100644
--- a/drivers/firmware/dmi-id.c
+++ b/drivers/firmware/dmi-id.c
@@ -229,14 +229,14 @@ static int __init dmi_id_init(void)
ret = device_register(dmi_dev);
if (ret)
- goto fail_free_dmi_dev;
+ goto fail_put_dmi_dev;
return 0;
-fail_free_dmi_dev:
- kfree(dmi_dev);
-fail_class_unregister:
+fail_put_dmi_dev:
+ put_device(dmi_dev);
+fail_class_unregister:
class_unregister(&dmi_class);
return ret;