diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2014-10-23 13:26:21 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2014-10-23 22:30:18 -0400 |
commit | 51486b900ee92856b977eacfc5bfbe6565028070 (patch) | |
tree | 7212a9d040a00c87bf8480d6ad4195658c4eca52 /fs/drop_caches.c | |
parent | f114040e3ea6e07372334ade75d1ee0775c355e1 (diff) | |
download | blackbird-op-linux-51486b900ee92856b977eacfc5bfbe6565028070.tar.gz blackbird-op-linux-51486b900ee92856b977eacfc5bfbe6565028070.zip |
fix inode leaks on d_splice_alias() failure exits
d_splice_alias() callers expect it to either stash the inode reference
into a new alias, or drop the inode reference. That makes it possible
to just return d_splice_alias() result from ->lookup() instance, without
any extra housekeeping required.
Unfortunately, that should include the failure exits. If d_splice_alias()
returns an error, it leaves the dentry it has been given negative and
thus it *must* drop the inode reference. Easily fixed, but it goes way
back and will need backporting.
Cc: stable@vger.kernel.org
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/drop_caches.c')
0 files changed, 0 insertions, 0 deletions