remoteproc: fix memory leak of remoteproc ida cache layers

The remoteproc core uses a static ida named rproc_dev_index for
assigning an automatic index number to a registered remoteproc.
The ida core may allocate some internal idr cache layers and ida
bitmap upon any ida allocation, and all these layers are truely
freed only upon the ida destruction. The rproc_dev_index ida is
not destroyed at present, leading to a memory leak when using the
remoteproc core as a module and atleast one rproc device is
registered and unregistered.

Fix this by invoking ida_destroy() in the remoteproc core module
exit.

Signed-off-by: Suman Anna <s-anna@ti.com>
Signed-off-by: Ohad Ben-Cohen <ohad@wizery.com>
This commit is contained in:
Suman Anna 2015-09-16 19:29:18 -05:00 committed by Ohad Ben-Cohen
parent 92792e48e2
commit f42f79af16
1 changed files with 2 additions and 0 deletions

View File

@ -1478,6 +1478,8 @@ module_init(remoteproc_init);
static void __exit remoteproc_exit(void) static void __exit remoteproc_exit(void)
{ {
ida_destroy(&rproc_dev_index);
rproc_exit_debugfs(); rproc_exit_debugfs();
} }
module_exit(remoteproc_exit); module_exit(remoteproc_exit);