diff options
author | Jeff Layton <jlayton@redhat.com> | 2016-07-11 16:10:06 +0300 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2016-07-11 20:48:02 +0300 |
commit | 6d4e56ce977864b0fcd28c61555060e6010aa89b (patch) | |
tree | 8b73f1e73b4461597b4d951c7f49c92b3bb000a0 /include/linux/wait.h | |
parent | c94c09535c4debcc439f55b5b6d9ebe57bd4665a (diff) | |
download | linux-6d4e56ce977864b0fcd28c61555060e6010aa89b.tar.xz |
posix_acl: de-union a_refcount and a_rcu
Currently the two are unioned together, but I don't think that's safe.
It looks like get_cached_acl could race with the last put in
posix_acl_release. get_cached_acl calls atomic_inc_not_zero on
a_refcount, but that field could have already been clobbered by
call_rcu, and may no longer be zero. Fix this by de-unioning the two
fields.
Fixes: b8a7a3a66747 (posix_acl: Inode acl caching fixes)
Signed-off-by: Jeff Layton <jlayton@redhat.com>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'include/linux/wait.h')
0 files changed, 0 insertions, 0 deletions