binder: use group leader instead of open thread
commit c4ea41ba195d01c9af66fb28711a16cc97caa9c5 upstream. The binder allocator assumes that the thread that called binder_open will never die for the lifetime of that proc. That thread is normally the group_leader, however it may not be. Use the group_leader instead of current. Signed-off-by: Todd Kjos <tkjos@google.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
e1c7a44788
commit
596b97ec2e
1 changed files with 2 additions and 2 deletions
|
@ -2966,8 +2966,8 @@ static int binder_open(struct inode *nodp, struct file *filp)
|
||||||
proc = kzalloc(sizeof(*proc), GFP_KERNEL);
|
proc = kzalloc(sizeof(*proc), GFP_KERNEL);
|
||||||
if (proc == NULL)
|
if (proc == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
get_task_struct(current);
|
get_task_struct(current->group_leader);
|
||||||
proc->tsk = current;
|
proc->tsk = current->group_leader;
|
||||||
INIT_LIST_HEAD(&proc->todo);
|
INIT_LIST_HEAD(&proc->todo);
|
||||||
init_waitqueue_head(&proc->wait);
|
init_waitqueue_head(&proc->wait);
|
||||||
proc->default_priority = task_nice(current);
|
proc->default_priority = task_nice(current);
|
||||||
|
|
Loading…
Add table
Reference in a new issue