greybus: connection: clean up creation error paths
authorJohan Hovold <johan@hovoldconsulting.com>
Thu, 23 Jul 2015 08:50:01 +0000 (10:50 +0200)
committerGreg Kroah-Hartman <gregkh@google.com>
Thu, 23 Jul 2015 19:55:25 +0000 (12:55 -0700)
Clean up connection-creation error paths.

Tested-by: Rui Miguel Silva <rui.silva@linaro.org>
Signed-off-by: Johan Hovold <johan@hovoldconsulting.com>
Reviewed-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
drivers/staging/greybus/connection.c

index 1820676343de4b734dbe30846e6fc1d8ae6a94da..555625c3fcef269d5b855aba61027bb5256ebf81 100644 (file)
@@ -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,