Commit b6ae84d6 authored by Seung-Woo Kim's avatar Seung-Woo Kim Committed by Greg Kroah-Hartman

staging: mmal-vchiq: Fix memory leak for vchiq_instance

The vchiq_instance is allocated with vchiq_initialise() but never
freed properly. Fix memory leak for the vchiq_instance.
Reported-by: default avatarJaehoon Chung <jh80.chung@samsung.com>
Signed-off-by: default avatarSeung-Woo Kim <sw0312.kim@samsung.com>
Link: https://lore.kernel.org/r/1603706150-10806-1-git-send-email-sw0312.kim@samsung.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 647a6002
...@@ -179,6 +179,9 @@ struct vchiq_mmal_instance { ...@@ -179,6 +179,9 @@ struct vchiq_mmal_instance {
/* ordered workqueue to process all bulk operations */ /* ordered workqueue to process all bulk operations */
struct workqueue_struct *bulk_wq; struct workqueue_struct *bulk_wq;
/* handle for a vchiq instance */
struct vchiq_instance *vchiq_instance;
}; };
static struct mmal_msg_context * static struct mmal_msg_context *
...@@ -1840,6 +1843,7 @@ int vchiq_mmal_finalise(struct vchiq_mmal_instance *instance) ...@@ -1840,6 +1843,7 @@ int vchiq_mmal_finalise(struct vchiq_mmal_instance *instance)
mutex_unlock(&instance->vchiq_mutex); mutex_unlock(&instance->vchiq_mutex);
vchiq_shutdown(instance->vchiq_instance);
flush_workqueue(instance->bulk_wq); flush_workqueue(instance->bulk_wq);
destroy_workqueue(instance->bulk_wq); destroy_workqueue(instance->bulk_wq);
...@@ -1856,6 +1860,7 @@ EXPORT_SYMBOL_GPL(vchiq_mmal_finalise); ...@@ -1856,6 +1860,7 @@ EXPORT_SYMBOL_GPL(vchiq_mmal_finalise);
int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance) int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance)
{ {
int status; int status;
int err = -ENODEV;
struct vchiq_mmal_instance *instance; struct vchiq_mmal_instance *instance;
static struct vchiq_instance *vchiq_instance; static struct vchiq_instance *vchiq_instance;
struct vchiq_service_params_kernel params = { struct vchiq_service_params_kernel params = {
...@@ -1890,17 +1895,21 @@ int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance) ...@@ -1890,17 +1895,21 @@ int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance)
status = vchiq_connect(vchiq_instance); status = vchiq_connect(vchiq_instance);
if (status) { if (status) {
pr_err("Failed to connect VCHI instance (status=%d)\n", status); pr_err("Failed to connect VCHI instance (status=%d)\n", status);
return -EIO; err = -EIO;
goto err_shutdown_vchiq;
} }
instance = kzalloc(sizeof(*instance), GFP_KERNEL); instance = kzalloc(sizeof(*instance), GFP_KERNEL);
if (!instance) if (!instance) {
return -ENOMEM; err = -ENOMEM;
goto err_shutdown_vchiq;
}
mutex_init(&instance->vchiq_mutex); mutex_init(&instance->vchiq_mutex);
instance->bulk_scratch = vmalloc(PAGE_SIZE); instance->bulk_scratch = vmalloc(PAGE_SIZE);
instance->vchiq_instance = vchiq_instance;
mutex_init(&instance->context_map_lock); mutex_init(&instance->context_map_lock);
idr_init_base(&instance->context_map, 1); idr_init_base(&instance->context_map, 1);
...@@ -1932,7 +1941,9 @@ int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance) ...@@ -1932,7 +1941,9 @@ int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance)
err_free: err_free:
vfree(instance->bulk_scratch); vfree(instance->bulk_scratch);
kfree(instance); kfree(instance);
return -ENODEV; err_shutdown_vchiq:
vchiq_shutdown(vchiq_instance);
return err;
} }
EXPORT_SYMBOL_GPL(vchiq_mmal_init); EXPORT_SYMBOL_GPL(vchiq_mmal_init);
......
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