提交 d35abdb2 编写于 作者: A Al Viro

hold task_lock around checks in keyctl

Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 6120d3db
...@@ -1486,6 +1486,7 @@ long keyctl_session_to_parent(void) ...@@ -1486,6 +1486,7 @@ long keyctl_session_to_parent(void)
oldwork = NULL; oldwork = NULL;
parent = me->real_parent; parent = me->real_parent;
task_lock(parent);
/* the parent mustn't be init and mustn't be a kernel thread */ /* the parent mustn't be init and mustn't be a kernel thread */
if (parent->pid <= 1 || !parent->mm) if (parent->pid <= 1 || !parent->mm)
goto unlock; goto unlock;
...@@ -1529,6 +1530,7 @@ long keyctl_session_to_parent(void) ...@@ -1529,6 +1530,7 @@ long keyctl_session_to_parent(void)
if (!ret) if (!ret)
newwork = NULL; newwork = NULL;
unlock: unlock:
task_unlock(parent);
write_unlock_irq(&tasklist_lock); write_unlock_irq(&tasklist_lock);
rcu_read_unlock(); rcu_read_unlock();
if (oldwork) if (oldwork)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册