staging: ion: Store a copy of the client name on client creation

Currently, we copy the pointer passed in to ion_client_create without
making a copy of the string itself. This approach is problematic since
it relies on the client keeping the name string in working order.

Cc: Colin Cross <ccross@android.com>
Cc: Android Kernel Team <kernel-team@android.com>
Signed-off-by: Mitchel Humpherys <mitchelh@codeaurora.org>
[jstultz: Minor commit subject tweaks]
Signed-off-by: John Stultz <john.stultz@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Mitchel Humpherys 2014-02-17 13:58:36 -08:00 committed by Greg Kroah-Hartman
parent 483ed03f5e
commit ae5cbf4a5a
1 changed files with 13 additions and 6 deletions

View File

@ -735,19 +735,18 @@ struct ion_client *ion_client_create(struct ion_device *dev,
task_unlock(current->group_leader); task_unlock(current->group_leader);
client = kzalloc(sizeof(struct ion_client), GFP_KERNEL); client = kzalloc(sizeof(struct ion_client), GFP_KERNEL);
if (!client) { if (!client)
if (task) goto err_put_task_struct;
put_task_struct(current->group_leader);
return ERR_PTR(-ENOMEM);
}
client->dev = dev; client->dev = dev;
client->handles = RB_ROOT; client->handles = RB_ROOT;
idr_init(&client->idr); idr_init(&client->idr);
mutex_init(&client->lock); mutex_init(&client->lock);
client->name = name;
client->task = task; client->task = task;
client->pid = pid; client->pid = pid;
client->name = kstrdup(name, GFP_KERNEL);
if (!client->name)
goto err_free_client;
down_write(&dev->lock); down_write(&dev->lock);
p = &dev->clients.rb_node; p = &dev->clients.rb_node;
@ -776,6 +775,13 @@ struct ion_client *ion_client_create(struct ion_device *dev,
up_write(&dev->lock); up_write(&dev->lock);
return client; return client;
err_free_client:
kfree(client);
err_put_task_struct:
if (task)
put_task_struct(current->group_leader);
return ERR_PTR(-ENOMEM);
} }
EXPORT_SYMBOL(ion_client_create); EXPORT_SYMBOL(ion_client_create);
@ -800,6 +806,7 @@ void ion_client_destroy(struct ion_client *client)
debugfs_remove_recursive(client->debug_root); debugfs_remove_recursive(client->debug_root);
up_write(&dev->lock); up_write(&dev->lock);
kfree(client->name);
kfree(client); kfree(client);
} }
EXPORT_SYMBOL(ion_client_destroy); EXPORT_SYMBOL(ion_client_destroy);