Commit 86cad666 authored by Greg Kroah-Hartman's avatar Greg Kroah-Hartman

greybus: interface: remove global manifest_descs list

The list was global and had no locking.  It's not like we were ever
parsing more than one manifest at the same time right now, but we might
in the future.  And we really want this to be local to the interface
itself, for future work redoing how to bind protocols to bundles, so
move the list to the interface structure.
Reviewed-by: default avatarAlex Elder <elder@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <greg@kroah.com>
parent df671553
...@@ -137,6 +137,7 @@ static struct gb_interface *gb_interface_create(struct greybus_host_device *hd, ...@@ -137,6 +137,7 @@ static struct gb_interface *gb_interface_create(struct greybus_host_device *hd,
intf->hd = hd; /* XXX refcount? */ intf->hd = hd; /* XXX refcount? */
intf->module = module; intf->module = module;
INIT_LIST_HEAD(&intf->bundles); INIT_LIST_HEAD(&intf->bundles);
INIT_LIST_HEAD(&intf->manifest_descs);
intf->dev.parent = &module->dev; intf->dev.parent = &module->dev;
intf->dev.bus = &greybus_bus_type; intf->dev.bus = &greybus_bus_type;
......
...@@ -16,6 +16,7 @@ struct gb_interface { ...@@ -16,6 +16,7 @@ struct gb_interface {
struct list_head bundles; struct list_head bundles;
struct list_head links; /* greybus_host_device->interfaces */ struct list_head links; /* greybus_host_device->interfaces */
struct list_head manifest_descs;
u8 interface_id; /* Physical location within the Endo */ u8 interface_id; /* Physical location within the Endo */
/* Information taken from the manifest module descriptor */ /* Information taken from the manifest module descriptor */
......
...@@ -28,20 +28,18 @@ struct manifest_desc { ...@@ -28,20 +28,18 @@ struct manifest_desc {
enum greybus_descriptor_type type; enum greybus_descriptor_type type;
}; };
static LIST_HEAD(manifest_descs);
static void release_manifest_descriptor(struct manifest_desc *descriptor) static void release_manifest_descriptor(struct manifest_desc *descriptor)
{ {
list_del(&descriptor->links); list_del(&descriptor->links);
kfree(descriptor); kfree(descriptor);
} }
static void release_manifest_descriptors(void) static void release_manifest_descriptors(struct gb_interface *intf)
{ {
struct manifest_desc *descriptor; struct manifest_desc *descriptor;
struct manifest_desc *next; struct manifest_desc *next;
list_for_each_entry_safe(descriptor, next, &manifest_descs, links) list_for_each_entry_safe(descriptor, next, &intf->manifest_descs, links)
release_manifest_descriptor(descriptor); release_manifest_descriptor(descriptor);
} }
...@@ -55,7 +53,8 @@ static void release_manifest_descriptors(void) ...@@ -55,7 +53,8 @@ static void release_manifest_descriptors(void)
* Returns the number of bytes consumed by the descriptor, or a * Returns the number of bytes consumed by the descriptor, or a
* negative errno. * negative errno.
*/ */
static int identify_descriptor(struct greybus_descriptor *desc, size_t size) static int identify_descriptor(struct gb_interface *intf,
struct greybus_descriptor *desc, size_t size)
{ {
struct greybus_descriptor_header *desc_header = &desc->header; struct greybus_descriptor_header *desc_header = &desc->header;
struct manifest_desc *descriptor; struct manifest_desc *descriptor;
...@@ -116,7 +115,7 @@ static int identify_descriptor(struct greybus_descriptor *desc, size_t size) ...@@ -116,7 +115,7 @@ static int identify_descriptor(struct greybus_descriptor *desc, size_t size)
descriptor->size = desc_size; descriptor->size = desc_size;
descriptor->data = (u8 *)desc + sizeof(*desc_header); descriptor->data = (u8 *)desc + sizeof(*desc_header);
descriptor->type = desc_header->type; descriptor->type = desc_header->type;
list_add_tail(&descriptor->links, &manifest_descs); list_add_tail(&descriptor->links, &intf->manifest_descs);
return desc_size; return desc_size;
} }
...@@ -132,7 +131,7 @@ static int identify_descriptor(struct greybus_descriptor *desc, size_t size) ...@@ -132,7 +131,7 @@ static int identify_descriptor(struct greybus_descriptor *desc, size_t size)
* Otherwise returns a pointer to a newly-allocated copy of the * Otherwise returns a pointer to a newly-allocated copy of the
* descriptor string, or an error-coded pointer on failure. * descriptor string, or an error-coded pointer on failure.
*/ */
static char *gb_string_get(u8 string_id) static char *gb_string_get(struct gb_interface *intf, u8 string_id)
{ {
struct greybus_descriptor_string *desc_string; struct greybus_descriptor_string *desc_string;
struct manifest_desc *descriptor; struct manifest_desc *descriptor;
...@@ -143,7 +142,7 @@ static char *gb_string_get(u8 string_id) ...@@ -143,7 +142,7 @@ static char *gb_string_get(u8 string_id)
if (!string_id) if (!string_id)
return NULL; return NULL;
list_for_each_entry(descriptor, &manifest_descs, links) { list_for_each_entry(descriptor, &intf->manifest_descs, links) {
if (descriptor->type != GREYBUS_TYPE_STRING) if (descriptor->type != GREYBUS_TYPE_STRING)
continue; continue;
...@@ -175,7 +174,8 @@ static char *gb_string_get(u8 string_id) ...@@ -175,7 +174,8 @@ static char *gb_string_get(u8 string_id)
* for the functions that use them. Returns the number of bundles * for the functions that use them. Returns the number of bundles
* set up for the given interface, or 0 if there is an error. * set up for the given interface, or 0 if there is an error.
*/ */
static u32 gb_manifest_parse_cports(struct gb_bundle *bundle) static u32 gb_manifest_parse_cports(struct gb_interface *intf,
struct gb_bundle *bundle)
{ {
u32 count = 0; u32 count = 0;
...@@ -187,7 +187,7 @@ static u32 gb_manifest_parse_cports(struct gb_bundle *bundle) ...@@ -187,7 +187,7 @@ static u32 gb_manifest_parse_cports(struct gb_bundle *bundle)
bool found = false; bool found = false;
/* Find a cport descriptor */ /* Find a cport descriptor */
list_for_each_entry(descriptor, &manifest_descs, links) { list_for_each_entry(descriptor, &intf->manifest_descs, links) {
if (descriptor->type == GREYBUS_TYPE_CPORT) { if (descriptor->type == GREYBUS_TYPE_CPORT) {
desc_cport = descriptor->data; desc_cport = descriptor->data;
if (desc_cport->bundle == bundle->id) { if (desc_cport->bundle == bundle->id) {
...@@ -229,7 +229,7 @@ static u32 gb_manifest_parse_bundles(struct gb_interface *intf) ...@@ -229,7 +229,7 @@ static u32 gb_manifest_parse_bundles(struct gb_interface *intf)
bool found = false; bool found = false;
/* Find an bundle descriptor */ /* Find an bundle descriptor */
list_for_each_entry(descriptor, &manifest_descs, links) { list_for_each_entry(descriptor, &intf->manifest_descs, links) {
if (descriptor->type == GREYBUS_TYPE_INTERFACE) { if (descriptor->type == GREYBUS_TYPE_INTERFACE) {
found = true; found = true;
break; break;
...@@ -245,7 +245,7 @@ static u32 gb_manifest_parse_bundles(struct gb_interface *intf) ...@@ -245,7 +245,7 @@ static u32 gb_manifest_parse_bundles(struct gb_interface *intf)
return 0; /* Error */ return 0; /* Error */
/* Now go set up this bundle's functions and cports */ /* Now go set up this bundle's functions and cports */
if (!gb_manifest_parse_cports(bundle)) if (!gb_manifest_parse_cports(intf, bundle))
return 0; /* Error parsing cports */ return 0; /* Error parsing cports */
count++; count++;
...@@ -263,11 +263,12 @@ static bool gb_manifest_parse_module(struct gb_interface *intf, ...@@ -263,11 +263,12 @@ static bool gb_manifest_parse_module(struct gb_interface *intf,
struct greybus_descriptor_module *desc_module = module_desc->data; struct greybus_descriptor_module *desc_module = module_desc->data;
/* Handle the strings first--they can fail */ /* Handle the strings first--they can fail */
intf->vendor_string = gb_string_get(desc_module->vendor_stringid); intf->vendor_string = gb_string_get(intf, desc_module->vendor_stringid);
if (IS_ERR(intf->vendor_string)) if (IS_ERR(intf->vendor_string))
return false; return false;
intf->product_string = gb_string_get(desc_module->product_stringid); intf->product_string = gb_string_get(intf,
desc_module->product_stringid);
if (IS_ERR(intf->product_string)) { if (IS_ERR(intf->product_string)) {
goto out_free_vendor_string; goto out_free_vendor_string;
} }
...@@ -331,7 +332,7 @@ bool gb_manifest_parse(struct gb_interface *intf, void *data, size_t size) ...@@ -331,7 +332,7 @@ bool gb_manifest_parse(struct gb_interface *intf, void *data, size_t size)
bool result; bool result;
/* Manifest descriptor list should be empty here */ /* Manifest descriptor list should be empty here */
if (WARN_ON(!list_empty(&manifest_descs))) if (WARN_ON(!list_empty(&intf->manifest_descs)))
return false; return false;
/* we have to have at _least_ the manifest header */ /* we have to have at _least_ the manifest header */
...@@ -364,7 +365,7 @@ bool gb_manifest_parse(struct gb_interface *intf, void *data, size_t size) ...@@ -364,7 +365,7 @@ bool gb_manifest_parse(struct gb_interface *intf, void *data, size_t size)
while (size) { while (size) {
int desc_size; int desc_size;
desc_size = identify_descriptor(desc, size); desc_size = identify_descriptor(intf, desc, size);
if (desc_size <= 0) { if (desc_size <= 0) {
if (!desc_size) if (!desc_size)
pr_err("zero-sized manifest descriptor\n"); pr_err("zero-sized manifest descriptor\n");
...@@ -376,7 +377,7 @@ bool gb_manifest_parse(struct gb_interface *intf, void *data, size_t size) ...@@ -376,7 +377,7 @@ bool gb_manifest_parse(struct gb_interface *intf, void *data, size_t size)
} }
/* There must be a single module descriptor */ /* There must be a single module descriptor */
list_for_each_entry(descriptor, &manifest_descs, links) { list_for_each_entry(descriptor, &intf->manifest_descs, links) {
if (descriptor->type == GREYBUS_TYPE_MODULE) if (descriptor->type == GREYBUS_TYPE_MODULE)
if (!found++) if (!found++)
module_desc = descriptor; module_desc = descriptor;
...@@ -395,10 +396,10 @@ bool gb_manifest_parse(struct gb_interface *intf, void *data, size_t size) ...@@ -395,10 +396,10 @@ bool gb_manifest_parse(struct gb_interface *intf, void *data, size_t size)
* We really should have no remaining descriptors, but we * We really should have no remaining descriptors, but we
* don't know what newer format manifests might leave. * don't know what newer format manifests might leave.
*/ */
if (result && !list_empty(&manifest_descs)) if (result && !list_empty(&intf->manifest_descs))
pr_info("excess descriptors in module manifest\n"); pr_info("excess descriptors in module manifest\n");
out: out:
release_manifest_descriptors(); release_manifest_descriptors(intf);
return result; return result;
} }
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