提交 68d35c7b 编写于 作者: S Sudip Mukherjee 提交者: Greg Kroah-Hartman

parport: fix freeing freed memory

After the reference count becomes 0 when put_device() is called, it will
execute the release callback where we are freeing all the allocated
memory associated with the device. So if we just continue on the error
path then we are again freeing devname and trying to dereference par_dev
which has already been free-ed in the release callback.
Signed-off-by: NSudip Mukherjee <sudip@vectorindia.org>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 23c40591
...@@ -892,8 +892,10 @@ parport_register_dev_model(struct parport *port, const char *name, ...@@ -892,8 +892,10 @@ parport_register_dev_model(struct parport *port, const char *name,
par_dev->dev.release = free_pardevice; par_dev->dev.release = free_pardevice;
par_dev->devmodel = true; par_dev->devmodel = true;
ret = device_register(&par_dev->dev); ret = device_register(&par_dev->dev);
if (ret) if (ret) {
goto err_put_dev; put_device(&par_dev->dev);
goto err_put_port;
}
/* Chain this onto the list */ /* Chain this onto the list */
par_dev->prev = NULL; par_dev->prev = NULL;
...@@ -940,8 +942,6 @@ parport_register_dev_model(struct parport *port, const char *name, ...@@ -940,8 +942,6 @@ parport_register_dev_model(struct parport *port, const char *name,
return par_dev; return par_dev;
err_put_dev:
put_device(&par_dev->dev);
err_free_devname: err_free_devname:
kfree(devname); kfree(devname);
err_free_par_dev: err_free_par_dev:
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册