Commit 10f9fa13 authored by Johan Hovold's avatar Johan Hovold Committed by Greg Kroah-Hartman

greybus: connection: clean up creation error paths

Clean up connection-creation error paths.
Tested-by: default avatarRui Miguel Silva <rui.silva@linaro.org>
Signed-off-by: default avatarJohan Hovold <johan@hovoldconsulting.com>
Reviewed-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent 7c63a827
......@@ -167,15 +167,14 @@ gb_connection_create_range(struct greybus_host_device *hd,
return NULL;
}
hd_cport_id = ida_simple_get(id_map, ida_start, ida_end, GFP_KERNEL);
if (hd_cport_id < 0)
return NULL;
connection = kzalloc(sizeof(*connection), GFP_KERNEL);
if (!connection)
return NULL;
goto err_remove_ida;
hd_cport_id = ida_simple_get(id_map, ida_start, ida_end, GFP_KERNEL);
if (hd_cport_id < 0) {
kfree(connection);
return NULL;
}
connection->hd_cport_id = hd_cport_id;
connection->intf_cport_id = cport_id;
connection->hd = hd;
......@@ -201,14 +200,13 @@ gb_connection_create_range(struct greybus_host_device *hd,
retval = device_add(&connection->dev);
if (retval) {
ida_simple_remove(id_map, connection->hd_cport_id);
connection->hd_cport_id = CPORT_ID_BAD;
put_device(&connection->dev);
pr_err("failed to add connection device for cport 0x%04hx\n",
cport_id);
return NULL;
goto err_remove_ida;
}
spin_lock_irq(&gb_connections_lock);
......@@ -228,6 +226,11 @@ gb_connection_create_range(struct greybus_host_device *hd,
"protocol 0x%02hhx handler not found\n", protocol_id);
return connection;
err_remove_ida:
ida_simple_remove(id_map, hd_cport_id);
return NULL;
}
struct gb_connection *gb_connection_create(struct gb_bundle *bundle,
......
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