greybus: define struct greybus_manifest
authorAlex Elder <elder@linaro.org>
Tue, 9 Sep 2014 18:55:04 +0000 (13:55 -0500)
committerGreg Kroah-Hartman <greg@kroah.com>
Tue, 9 Sep 2014 22:07:42 +0000 (15:07 -0700)
Define a structure that describes the entire greybus manifest.
Adjust greybus_new_module() to use that, making it explicit that
it's not just a header that's being provided to that function.

Signed-off-by: Alex Elder <elder@linaro.org>
Signed-off-by: Greg Kroah-Hartman <greg@kroah.com>
drivers/staging/greybus/core.c
drivers/staging/greybus/greybus_manifest.h

index 107e1fb75b8d6ee51c6ef4a8e1ee0e9b15d2b02d..95655e258e84c6c0b54e31abf12618510e362568 100644 (file)
@@ -353,7 +353,7 @@ struct greybus_device *greybus_new_module(struct device *parent,
                                          int module_number, u8 *data, int size)
 {
        struct greybus_device *gdev;
-       struct greybus_manifest_header *header;
+       struct greybus_manifest *manifest;
        struct greybus_descriptor *desc;
        int retval;
        int overall_size;
@@ -362,7 +362,7 @@ struct greybus_device *greybus_new_module(struct device *parent,
        u8 version_minor;
 
        /* we have to have at _least_ the manifest header */
-       if (size <= sizeof(struct greybus_manifest_header))
+       if (size <= sizeof(manifest->header))
                return NULL;
 
        gdev = kzalloc(sizeof(*gdev), GFP_KERNEL);
@@ -379,21 +379,21 @@ struct greybus_device *greybus_new_module(struct device *parent,
        device_initialize(&gdev->dev);
        dev_set_name(&gdev->dev, "%d", module_number);
 
-       header = (struct greybus_manifest_header *)data;
-       overall_size = le16_to_cpu(header->size);
+       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",
                        size, overall_size);
                goto error;
        }
 
-       version_major = header->version_major;
-       version_minor = header->version_minor;
+       version_major = manifest->header.version_major;
+       version_minor = manifest->header.version_minor;
 
        // FIXME - check version major/minor here!
 
-       size -= sizeof(struct greybus_manifest_header);
-       data += sizeof(struct greybus_manifest_header);
+       size -= sizeof(manifest->header);
+       data += sizeof(manifest->header);
        while (size > 0) {
                desc = (struct greybus_descriptor *)data;
                desc_size = le16_to_cpu(desc->header.size);
index 293451eee4d9f11bb084bfa4d9bc787f26ecae51..8b4acd3c2fc13c6266774c25dcaf3a2a7334ee98 100644 (file)
@@ -94,6 +94,11 @@ struct greybus_descriptor {
        };
 };
 
+struct greybus_manifest {
+       struct greybus_manifest_header          header;
+       struct greybus_descriptor               descriptors[0];
+};
+
 #pragma pack(pop)
 
 #endif /* __GREYBUS_DESC_H */