From 63e4a8ee8fdd9d86e7d2f16a99d82ee03fa0a785 Mon Sep 17 00:00:00 2001 From: Greg Kroah-Hartman Date: Wed, 22 Oct 2014 16:38:07 +0800 Subject: [PATCH] greybus: module: fix double free of module Also properly clean up all modules when you remove a host driver Signed-off-by: Greg Kroah-Hartman --- drivers/staging/greybus/core.c | 19 +++++++++++++++---- drivers/staging/greybus/greybus.h | 2 -- 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/drivers/staging/greybus/core.c b/drivers/staging/greybus/core.c index bc27ad68cc85..480e12bac84a 100644 --- a/drivers/staging/greybus/core.c +++ b/drivers/staging/greybus/core.c @@ -190,6 +190,13 @@ err_module: greybus_module_release(&gmod->dev); } +static void gb_delete_module(struct gb_module *gmod) +{ + /* FIXME - tear down interfaces first */ + + device_del(&gmod->dev); +} + void gb_remove_module(struct greybus_host_device *hd, u8 module_id) { struct gb_module *gmod; @@ -202,15 +209,18 @@ void gb_remove_module(struct greybus_host_device *hd, u8 module_id) } if (found) - greybus_remove_device(gmod); + gb_delete_module(gmod); else dev_err(hd->parent, "module id %d remove error\n", module_id); } -void greybus_remove_device(struct gb_module *gmod) +static void gb_remove_modules(struct greybus_host_device *hd) { - device_del(&gmod->dev); - put_device(&gmod->dev); + struct gb_module *gmod, *temp; + + list_for_each_entry_safe(gmod, temp, &hd->modules, links) { + gb_delete_module(gmod); + } } static DEFINE_MUTEX(hd_mutex); @@ -248,6 +258,7 @@ EXPORT_SYMBOL_GPL(greybus_create_hd); void greybus_remove_hd(struct greybus_host_device *hd) { + gb_remove_modules(hd); kref_put_mutex(&hd->kref, free_hd, &hd_mutex); } EXPORT_SYMBOL_GPL(greybus_remove_hd); diff --git a/drivers/staging/greybus/greybus.h b/drivers/staging/greybus/greybus.h index a4e1f4b2b18e..4baa37289334 100644 --- a/drivers/staging/greybus/greybus.h +++ b/drivers/staging/greybus/greybus.h @@ -242,8 +242,6 @@ void greybus_deregister(struct greybus_driver *driver); int greybus_disabled(void); -void greybus_remove_device(struct gb_module *gmod); - /* Internal functions to gb module, move to internal .h file eventually. */ void gb_add_module(struct greybus_host_device *hd, u8 module_id, -- 2.20.1