diff options
author | Kees Cook <[email protected]> | 2012-03-19 16:12:53 -0700 |
---|---|---|
committer | Thomas Gleixner <[email protected]> | 2012-03-29 11:37:17 +0200 |
commit | bdbb776f882f5ad431aa1e694c69c1c3d6a4a5b8 (patch) | |
tree | 854b6b5869857d40a02d21bb51b375812bdb2ed0 /lib/string_helpers.c | |
parent | b5174fa3a7f4f8f150bfa3b917c92608953dfa0f (diff) |
futex: Do not leak robust list to unprivileged process
It was possible to extract the robust list head address from a setuid
process if it had used set_robust_list(), allowing an ASLR info leak. This
changes the permission checks to be the same as those used for similar
info that comes out of /proc.
Running a setuid program that uses robust futexes would have had:
cred->euid != pcred->euid
cred->euid == pcred->uid
so the old permissions check would allow it. I'm not aware of any setuid
programs that use robust futexes, so this is just a preventative measure.
(This patch is based on changes from grsecurity.)
Signed-off-by: Kees Cook <[email protected]>
Cc: Darren Hart <[email protected]>
Cc: Peter Zijlstra <[email protected]>
Cc: Jiri Kosina <[email protected]>
Cc: Eric W. Biederman <[email protected]>
Cc: David Howells <[email protected]>
Cc: Serge E. Hallyn <[email protected]>
Cc: [email protected]
Cc: [email protected]
Link: http://lkml.kernel.org/r/[email protected]
Signed-off-by: Thomas Gleixner <[email protected]>
Diffstat (limited to 'lib/string_helpers.c')
0 files changed, 0 insertions, 0 deletions