projects
/
openwrt
/
staging
/
blogic.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
a811dc6
)
Yama: Check for pid death before checking ancestry
author
Kees Cook
<
[email protected]
>
Wed, 16 Jan 2019 18:31:09 +0000
(10:31 -0800)
committer
James Morris
<
[email protected]
>
Wed, 16 Jan 2019 20:00:56 +0000
(12:00 -0800)
It's possible that a pid has died before we take the rcu lock, in which
case we can't walk the ancestry list as it may be detached. Instead, check
for death first before doing the walk.
Reported-by:
[email protected]
Fixes: 2d514487faf1 ("security: Yama LSM")
Cc:
[email protected]
Suggested-by: Oleg Nesterov <
[email protected]
>
Signed-off-by: Kees Cook <
[email protected]
>
Signed-off-by: James Morris <
[email protected]
>
security/yama/yama_lsm.c
patch
|
blob
|
history
diff --git
a/security/yama/yama_lsm.c
b/security/yama/yama_lsm.c
index ffda91a4a1aaf3f32b0f72b22ebd4ab068acc6b3..02514fe558b416be1fd2bc407b01a6fb1e0b59b8 100644
(file)
--- a/
security/yama/yama_lsm.c
+++ b/
security/yama/yama_lsm.c
@@
-368,7
+368,9
@@
static int yama_ptrace_access_check(struct task_struct *child,
break;
case YAMA_SCOPE_RELATIONAL:
rcu_read_lock();
- if (!task_is_descendant(current, child) &&
+ if (!pid_alive(child))
+ rc = -EPERM;
+ if (!rc && !task_is_descendant(current, child) &&
!ptracer_exception_found(current, child) &&
!ns_capable(__task_cred(child)->user_ns, CAP_SYS_PTRACE))
rc = -EPERM;