Commit badad68e authored by Alex Elder's avatar Alex Elder Committed by Greg Kroah-Hartman

greybus: define struct greybus_manifest

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: default avatarAlex Elder <elder@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <greg@kroah.com>
parent 05ad189c
...@@ -353,7 +353,7 @@ struct greybus_device *greybus_new_module(struct device *parent, ...@@ -353,7 +353,7 @@ struct greybus_device *greybus_new_module(struct device *parent,
int module_number, u8 *data, int size) int module_number, u8 *data, int size)
{ {
struct greybus_device *gdev; struct greybus_device *gdev;
struct greybus_manifest_header *header; struct greybus_manifest *manifest;
struct greybus_descriptor *desc; struct greybus_descriptor *desc;
int retval; int retval;
int overall_size; int overall_size;
...@@ -362,7 +362,7 @@ struct greybus_device *greybus_new_module(struct device *parent, ...@@ -362,7 +362,7 @@ struct greybus_device *greybus_new_module(struct device *parent,
u8 version_minor; u8 version_minor;
/* we have to have at _least_ the manifest header */ /* we have to have at _least_ the manifest header */
if (size <= sizeof(struct greybus_manifest_header)) if (size <= sizeof(manifest->header))
return NULL; return NULL;
gdev = kzalloc(sizeof(*gdev), GFP_KERNEL); gdev = kzalloc(sizeof(*gdev), GFP_KERNEL);
...@@ -379,21 +379,21 @@ struct greybus_device *greybus_new_module(struct device *parent, ...@@ -379,21 +379,21 @@ struct greybus_device *greybus_new_module(struct device *parent,
device_initialize(&gdev->dev); device_initialize(&gdev->dev);
dev_set_name(&gdev->dev, "%d", module_number); dev_set_name(&gdev->dev, "%d", module_number);
header = (struct greybus_manifest_header *)data; manifest = (struct greybus_manifest *)data;
overall_size = le16_to_cpu(header->size); overall_size = le16_to_cpu(manifest->header.size);
if (overall_size != size) { if (overall_size != size) {
dev_err(parent, "size != manifest header size, %d != %d\n", dev_err(parent, "size != manifest header size, %d != %d\n",
size, overall_size); size, overall_size);
goto error; goto error;
} }
version_major = header->version_major; version_major = manifest->header.version_major;
version_minor = header->version_minor; version_minor = manifest->header.version_minor;
// FIXME - check version major/minor here! // FIXME - check version major/minor here!
size -= sizeof(struct greybus_manifest_header); size -= sizeof(manifest->header);
data += sizeof(struct greybus_manifest_header); data += sizeof(manifest->header);
while (size > 0) { while (size > 0) {
desc = (struct greybus_descriptor *)data; desc = (struct greybus_descriptor *)data;
desc_size = le16_to_cpu(desc->header.size); desc_size = le16_to_cpu(desc->header.size);
......
...@@ -94,6 +94,11 @@ struct greybus_descriptor { ...@@ -94,6 +94,11 @@ struct greybus_descriptor {
}; };
}; };
struct greybus_manifest {
struct greybus_manifest_header header;
struct greybus_descriptor descriptors[0];
};
#pragma pack(pop) #pragma pack(pop)
#endif /* __GREYBUS_DESC_H */ #endif /* __GREYBUS_DESC_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment