greybus: bundle: Initialize all bundles on link-up
authorViresh Kumar <viresh.kumar@linaro.org>
Wed, 1 Apr 2015 15:02:01 +0000 (20:32 +0530)
committerGreg Kroah-Hartman <gregkh@google.com>
Mon, 6 Apr 2015 09:34:39 +0000 (11:34 +0200)
An interface can have 1 or more bundles. On link-up event, we must initialize
all the bundles associated with the interface.

Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
drivers/staging/greybus/ap.c
drivers/staging/greybus/bundle.c
drivers/staging/greybus/bundle.h

index 132ecb4a7974d9dc17d41cb7e53313be62c59a26..1dc13396a567fe9b5b28aefbbc3d6869ed921bf9 100644 (file)
@@ -146,9 +146,7 @@ static void svc_management(struct svc_function_unipro_management *management,
                                management->link_up.interface_id);
                        return;
                }
-               ret = gb_bundle_init(intf,
-                               management->link_up.interface_id,
-                               management->link_up.device_id);
+               ret = gb_bundles_init(intf, management->link_up.device_id);
                if (ret) {
                        dev_err(hd->parent,
                                "error %d initializing bundles for interface %hhu\n",
index 47a3413b6f211450956e19438e23ea3765948029..9691978724849e1046c6aeca42a84bed7b693f3d 100644 (file)
@@ -146,16 +146,11 @@ void gb_bundle_destroy(struct gb_interface *intf)
        }
 }
 
-int gb_bundle_init(struct gb_interface *intf, u8 bundle_id, u8 device_id)
+int gb_bundle_init(struct gb_bundle *bundle, u8 device_id)
 {
-       struct gb_bundle *bundle;
+       struct gb_interface *intf = bundle->intf;
        int ret;
 
-       bundle = gb_bundle_find(intf, bundle_id);
-       if (!bundle) {
-               dev_err(intf->hd->parent, "bundle %hhu not found\n", bundle_id);
-               return -ENOENT;
-       }
        bundle->device_id = device_id;
 
        ret = svc_set_route_send(bundle, intf->hd);
@@ -175,6 +170,24 @@ int gb_bundle_init(struct gb_interface *intf, u8 bundle_id, u8 device_id)
        return 0;
 }
 
+int gb_bundles_init(struct gb_interface *intf, u8 device_id)
+{
+       struct gb_bundle *bundle;
+       int ret = 0;
+
+       list_for_each_entry(bundle, &intf->bundles, links) {
+               ret = gb_bundle_init(bundle, device_id);
+               if (ret) {
+                       dev_err(intf->hd->parent,
+                               "Failed to initialize bundle %hhu\n",
+                               bundle->id);
+                       break;
+               }
+       }
+
+       return ret;
+}
+
 struct gb_bundle *gb_bundle_find(struct gb_interface *intf, u8 bundle_id)
 {
        struct gb_bundle *bundle;
index 385c90a5e9f8f3ca118b981fddaa820b8227e7a0..2948098070c44e03998b298fbf1995003d607efc 100644 (file)
@@ -31,7 +31,8 @@ struct gb_bundle {
 struct gb_bundle *gb_bundle_create(struct gb_interface *intf, u8 bundle_id,
                                   u8 class_type);
 void gb_bundle_destroy(struct gb_interface *intf);
-int gb_bundle_init(struct gb_interface *intf, u8 module_id, u8 device_id);
+int gb_bundle_init(struct gb_bundle *bundle, u8 device_id);
+int gb_bundles_init(struct gb_interface *intf, u8 device_id);
 
 struct gb_bundle *gb_bundle_find(struct gb_interface *intf, u8 bundle_id);
 void gb_bundle_bind_protocols(void);