Commit 17fbaa6e authored by Rafał Miłecki's avatar Rafał Miłecki Committed by Kalle Valo

bcma: simplify freeing cores (internal devices structs)

Signed-off-by: default avatarRafał Miłecki <zajec5@gmail.com>
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
parent 68fcd245
...@@ -368,12 +368,19 @@ static void bcma_unregister_cores(struct bcma_bus *bus) ...@@ -368,12 +368,19 @@ static void bcma_unregister_cores(struct bcma_bus *bus)
struct bcma_device *core, *tmp; struct bcma_device *core, *tmp;
list_for_each_entry_safe(core, tmp, &bus->cores, list) { list_for_each_entry_safe(core, tmp, &bus->cores, list) {
if (!core->dev_registered)
continue;
list_del(&core->list); list_del(&core->list);
if (core->dev_registered)
device_unregister(&core->dev); device_unregister(&core->dev);
} }
if (bus->hosttype == BCMA_HOSTTYPE_SOC) if (bus->hosttype == BCMA_HOSTTYPE_SOC)
platform_device_unregister(bus->drv_cc.watchdog); platform_device_unregister(bus->drv_cc.watchdog);
/* Now noone uses internally-handled cores, we can free them */
list_for_each_entry_safe(core, tmp, &bus->cores, list) {
list_del(&core->list);
kfree(core);
}
} }
int bcma_bus_register(struct bcma_bus *bus) int bcma_bus_register(struct bcma_bus *bus)
...@@ -467,7 +474,6 @@ int bcma_bus_register(struct bcma_bus *bus) ...@@ -467,7 +474,6 @@ int bcma_bus_register(struct bcma_bus *bus)
void bcma_bus_unregister(struct bcma_bus *bus) void bcma_bus_unregister(struct bcma_bus *bus)
{ {
struct bcma_device *cores[3];
int err; int err;
err = bcma_gpio_unregister(&bus->drv_cc); err = bcma_gpio_unregister(&bus->drv_cc);
...@@ -478,15 +484,7 @@ void bcma_bus_unregister(struct bcma_bus *bus) ...@@ -478,15 +484,7 @@ void bcma_bus_unregister(struct bcma_bus *bus)
bcma_core_chipcommon_b_free(&bus->drv_cc_b); bcma_core_chipcommon_b_free(&bus->drv_cc_b);
cores[0] = bcma_find_core(bus, BCMA_CORE_MIPS_74K);
cores[1] = bcma_find_core(bus, BCMA_CORE_PCIE);
cores[2] = bcma_find_core(bus, BCMA_CORE_4706_MAC_GBIT_COMMON);
bcma_unregister_cores(bus); bcma_unregister_cores(bus);
kfree(cores[2]);
kfree(cores[1]);
kfree(cores[0]);
} }
/* /*
......
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