From: Greg Kroah-Hartman Date: Mon, 22 Sep 2014 02:17:55 +0000 (-0700) Subject: greybus: core: hook up the hotplug message X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=4a833fdb7fc73039b06c1d879d896ebab0df7bd9;p=GitHub%2Fmoto-9609%2Fandroid_kernel_motorola_exynos9610.git greybus: core: hook up the hotplug message We should now try to parse the manifest and create a device based on the manifest. Not hooked up to the driver core yet, so removing it isn't going to do anything except cause problems... --- diff --git a/drivers/staging/greybus/core.c b/drivers/staging/greybus/core.c index b4e3093e3899..e4a78b4f9bd3 100644 --- a/drivers/staging/greybus/core.c +++ b/drivers/staging/greybus/core.c @@ -341,19 +341,13 @@ static int create_cport(struct greybus_device *gdev, } /** - * greybus_new_module: + * gb_add_module * * Pass in a buffer that _should_ contain a Greybus module manifest - * and spit out a greybus device structure. + * and register a greybus device structure with the kernel core. */ void gb_add_module(struct greybus_host_device *hd, u8 module_id, u8 *data, int size) -{ - // FIXME - should be the new module call... -} - -struct greybus_device *greybus_new_module(struct device *parent, - int module_number, u8 *data, int size) { struct greybus_device *gdev; struct greybus_manifest *manifest; @@ -364,26 +358,26 @@ struct greybus_device *greybus_new_module(struct device *parent, /* we have to have at _least_ the manifest header */ if (size <= sizeof(manifest->header)) - return NULL; + return; gdev = kzalloc(sizeof(*gdev), GFP_KERNEL); if (!gdev) - return NULL; + return; - gdev->module_number = module_number; - gdev->dev.parent = parent; + gdev->module_number = module_id; + gdev->dev.parent = hd->parent; gdev->dev.driver = NULL; gdev->dev.bus = &greybus_bus_type; gdev->dev.type = &greybus_module_type; gdev->dev.groups = greybus_module_groups; - gdev->dev.dma_mask = parent->dma_mask; + gdev->dev.dma_mask = hd->parent->dma_mask; device_initialize(&gdev->dev); - dev_set_name(&gdev->dev, "%d", module_number); + dev_set_name(&gdev->dev, "%d", module_id); manifest = (struct greybus_manifest *)data; overall_size = le16_to_cpu(manifest->header.size); if (overall_size != size) { - dev_err(parent, "size != manifest header size, %d != %d\n", + dev_err(hd->parent, "size != manifest header size, %d != %d\n", size, overall_size); goto error; } @@ -394,7 +388,7 @@ struct greybus_device *greybus_new_module(struct device *parent, /* Validate major/minor number */ if ((version_major != GREYBUS_VERSION_MAJOR) || (version_minor != GREYBUS_VERSION_MINOR)) { - dev_err(parent, + dev_err(hd->parent, "Invalid greybus versions, expected %d.%d, got %d.%d\n", GREYBUS_VERSION_MAJOR, GREYBUS_VERSION_MINOR, version_major, version_minor); @@ -409,13 +403,14 @@ struct greybus_device *greybus_new_module(struct device *parent, size_t data_size; if (size < sizeof(desc->header)) { - dev_err(parent, "remaining size %d too small\n", size); + dev_err(hd->parent, "remaining size %d too small\n", + size); goto error; } desc = (struct greybus_descriptor *)data; desc_size = le16_to_cpu(desc->header.size); if (size < desc_size) { - dev_err(parent, "descriptor size %d too big\n", + dev_err(hd->parent, "descriptor size %d too big\n", desc_size); goto error; } @@ -448,7 +443,7 @@ struct greybus_device *greybus_new_module(struct device *parent, case GREYBUS_TYPE_INVALID: default: - dev_err(parent, "invalid descriptor type %d\n", + dev_err(hd->parent, "invalid descriptor type %d\n", desc->header.type); goto error; } @@ -464,12 +459,11 @@ struct greybus_device *greybus_new_module(struct device *parent, // FIXME device_add(&gdev->dev); - - return gdev; + //return gdev; + return; error: put_device(&gdev->dev); greybus_module_release(&gdev->dev); - return NULL; } void gb_remove_module(struct greybus_host_device *hd, u8 module_id) diff --git a/drivers/staging/greybus/greybus.h b/drivers/staging/greybus/greybus.h index 855cb0e02bb7..1f996b97a072 100644 --- a/drivers/staging/greybus/greybus.h +++ b/drivers/staging/greybus/greybus.h @@ -279,9 +279,6 @@ void greybus_deregister(struct greybus_driver *driver); int greybus_disabled(void); -struct greybus_device *greybus_new_module(struct device *parent, - int module_number, u8 *data, - int size); void greybus_remove_device(struct greybus_device *gdev); const u8 *greybus_string(struct greybus_device *gdev, int id);