staging: most: core: fix list traversing
authorAndrey Shvetsov <andrey.shvetsov@k2l.de>
Tue, 21 Nov 2017 14:05:22 +0000 (15:05 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 27 Nov 2017 08:20:37 +0000 (09:20 +0100)
This patch fixes the offset and data handling when traversing
the list of devices that are attached to the bus.

Signed-off-by: Christian Gromm <christian.gromm@microchip.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/most/core.c

index bfd1a028ccad8878ee76f42ad854bfcfbd581303..c1fba5ba7541ae89919ac96a63db2c44977c1a66 100644 (file)
@@ -529,10 +529,16 @@ static struct core_component *match_component(char *name)
        return NULL;
 }
 
+struct show_links_data {
+       int offs;
+       char *buf;
+};
+
 int print_links(struct device *dev, void *data)
 {
-       int offs = 0;
-       char *buf = data;
+       struct show_links_data *d = data;
+       int offs = d->offs;
+       char *buf = d->buf;
        struct most_channel *c;
        struct most_interface *iface = to_most_interface(dev);
 
@@ -554,13 +560,16 @@ int print_links(struct device *dev, void *data)
                                         dev_name(&c->dev));
                }
        }
+       d->offs = offs;
        return 0;
 }
 
 static ssize_t links_show(struct device_driver *drv, char *buf)
 {
-       bus_for_each_dev(&mc.bus, NULL, buf, print_links);
-       return strlen(buf);
+       struct show_links_data d = { .buf = buf };
+
+       bus_for_each_dev(&mc.bus, NULL, &d, print_links);
+       return d.offs;
 }
 
 static ssize_t components_show(struct device_driver *drv, char *buf)