mcb: Correctly initialize the bus's device
authorJohannes Thumshirn <jthumshirn@suse.de>
Tue, 3 May 2016 07:46:22 +0000 (09:46 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 3 May 2016 22:07:35 +0000 (15:07 -0700)
The mcb bus' device member wasn't correctly initialized and thus wasn't placed
correctly into the driver model.

Signed-off-by: Johannes Thumshirn <jthumshirn@suse.de>
Reviewed-by: Andreas Werner <andreas.werner@men.de>
Tested-by: Andreas Werner <andreas.werner@men.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/mcb/mcb-core.c
include/linux/mcb.h

index a4be451074e5caae0ebceff1236b3348ede5951b..1e336cc56751a28323ea4a081426de09a50283e5 100644 (file)
@@ -187,6 +187,7 @@ struct mcb_bus *mcb_alloc_bus(struct device *carrier)
 {
        struct mcb_bus *bus;
        int bus_nr;
+       int rc;
 
        bus = kzalloc(sizeof(struct mcb_bus), GFP_KERNEL);
        if (!bus)
@@ -194,14 +195,26 @@ struct mcb_bus *mcb_alloc_bus(struct device *carrier)
 
        bus_nr = ida_simple_get(&mcb_ida, 0, 0, GFP_KERNEL);
        if (bus_nr < 0) {
-               kfree(bus);
-               return ERR_PTR(bus_nr);
+               rc = bus_nr;
+               goto err_free;
        }
 
-       INIT_LIST_HEAD(&bus->children);
        bus->bus_nr = bus_nr;
        bus->carrier = carrier;
+
+       device_initialize(&bus->dev);
+       bus->dev.parent = carrier;
+       bus->dev.bus = &mcb_bus_type;
+
+       dev_set_name(&bus->dev, "mcb:%d", bus_nr);
+       rc = device_add(&bus->dev);
+       if (rc)
+               goto err_free;
+
        return bus;
+err_free:
+       kfree(bus);
+       return ERR_PTR(rc);
 }
 EXPORT_SYMBOL_GPL(mcb_alloc_bus);
 
index ed06e15a36aa299c6110dc27870aadbc5987d650..3efafbca166df1dbe170c4a67557ea08071d11f9 100644 (file)
@@ -21,13 +21,12 @@ struct mcb_device;
 /**
  * struct mcb_bus - MEN Chameleon Bus
  *
- * @dev: pointer to carrier device
- * @children: the child busses
+ * @dev: bus device
+ * @carrier: pointer to carrier device
  * @bus_nr: mcb bus number
  * @get_irq: callback to get IRQ number
  */
 struct mcb_bus {
-       struct list_head children;
        struct device dev;
        struct device *carrier;
        int bus_nr;