Commit 55a8e355 authored by Phong Tran's avatar Phong Tran Committed by Greg Kroah-Hartman

greybus: uart: fix the clean up while uart initiates connection unsucessfully

There is lack of unregister and free the tty driver.
This patch fixes it.
Signed-off-by: default avatarPhong Tran <tranmanphong@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent 3d0421e0
......@@ -586,20 +586,22 @@ static int gb_uart_connection_init(struct gb_connection *connection)
}
gb_tty = kzalloc(sizeof(*gb_tty), GFP_KERNEL);
if (!gb_tty)
return -ENOMEM;
if (!gb_tty) {
retval = -ENOMEM;
goto error_alloc;
}
gb_tty->buffer_payload_max =
gb_operation_get_payload_size_max(connection);
if (!gb_tty->buffer_payload_max) {
kfree(gb_tty);
return -EINVAL;
retval = -EINVAL;
goto error_payload;
}
gb_tty->buffer = kzalloc(gb_tty->buffer_payload_max, GFP_KERNEL);
if (!gb_tty->buffer) {
kfree(gb_tty);
return -ENOMEM;
retval = -ENOMEM;
goto error_payload;
}
gb_tty->connection = connection;
......@@ -654,7 +656,11 @@ static int gb_uart_connection_init(struct gb_connection *connection)
error_version:
connection->private = NULL;
kfree(gb_tty->buffer);
error_payload:
kfree(gb_tty);
error_alloc:
if (atomic_dec_return(&reference_count) == 0)
gb_tty_exit();
return retval;
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment