mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-24 05:04:00 +08:00
Drivers: hv: vmbus: Use after free in __vmbus_open()
The "open_info" variable is added to the &vmbus_connection.chn_msg_list,
but the error handling frees "open_info" without removing it from the
list. This will result in a use after free. First remove it from the
list, and then free it.
Fixes: 6f3d791f30
("Drivers: hv: vmbus: Fix rescind handling issues")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Reviewed-by: Andrea Parri <parri.andrea@gmail.com>
Link: https://lore.kernel.org/r/YHV3XLCot6xBS44r@mwanda
Signed-off-by: Wei Liu <wei.liu@kernel.org>
This commit is contained in:
parent
61d74d8e39
commit
3e9bf43f7f
@ -653,7 +653,7 @@ static int __vmbus_open(struct vmbus_channel *newchannel,
|
|||||||
|
|
||||||
if (newchannel->rescind) {
|
if (newchannel->rescind) {
|
||||||
err = -ENODEV;
|
err = -ENODEV;
|
||||||
goto error_free_info;
|
goto error_clean_msglist;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = vmbus_post_msg(open_msg,
|
err = vmbus_post_msg(open_msg,
|
||||||
|
Loading…
Reference in New Issue
Block a user