diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2015-05-07 20:32:22 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2015-05-11 08:13:13 -0400 |
commit | 6548fae2eca6b66c7257af6663fdbdf5a50745fd (patch) | |
tree | 9bd27e6603841fa48feca5a053b8c8b1ecd5129c /fs | |
parent | ecc087ff14352aed52b8e775b4511e7f9cfc64ec (diff) | |
download | op-kernel-dev-6548fae2eca6b66c7257af6663fdbdf5a50745fd.zip op-kernel-dev-6548fae2eca6b66c7257af6663fdbdf5a50745fd.tar.gz |
namei: make put_link() RCU-safe
very simple - just make path_put() conditional on !RCU.
Note that right now it doesn't get called in RCU mode -
we leave it before getting anything into stack.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/namei.c | 3 |
1 files changed, 2 insertions, 1 deletions
@@ -750,7 +750,8 @@ static inline void put_link(struct nameidata *nd) struct inode *inode = last->inode; if (last->cookie && inode->i_op->put_link) inode->i_op->put_link(inode, last->cookie); - path_put(&last->link); + if (!(nd->flags & LOOKUP_RCU)) + path_put(&last->link); } int sysctl_protected_symlinks __read_mostly = 0; |