Commit 12447c40 authored by Al Viro's avatar Al Viro

affs: unobfuscate affs_fix_dcache()

and add a comment on what it's doing
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 3084ee95
...@@ -122,15 +122,13 @@ affs_remove_hash(struct inode *dir, struct buffer_head *rem_bh) ...@@ -122,15 +122,13 @@ affs_remove_hash(struct inode *dir, struct buffer_head *rem_bh)
} }
static void static void
affs_fix_dcache(struct dentry *dentry, u32 entry_ino) affs_fix_dcache(struct inode *inode, u32 entry_ino)
{ {
struct inode *inode = dentry->d_inode; struct dentry *dentry;
void *data = dentry->d_fsdata;
spin_lock(&inode->i_lock); spin_lock(&inode->i_lock);
list_for_each_entry(dentry, &inode->i_dentry, d_alias) { list_for_each_entry(dentry, &inode->i_dentry, d_alias) {
if (entry_ino == (u32)(long)dentry->d_fsdata) { if (entry_ino == (u32)(long)dentry->d_fsdata) {
dentry->d_fsdata = data; dentry->d_fsdata = (void *)inode->i_ino;
break; break;
} }
} }
...@@ -172,7 +170,11 @@ affs_remove_link(struct dentry *dentry) ...@@ -172,7 +170,11 @@ affs_remove_link(struct dentry *dentry)
} }
affs_lock_dir(dir); affs_lock_dir(dir);
affs_fix_dcache(dentry, link_ino); /*
* if there's a dentry for that block, make it
* refer to inode itself.
*/
affs_fix_dcache(inode, link_ino);
retval = affs_remove_hash(dir, link_bh); retval = affs_remove_hash(dir, link_bh);
if (retval) { if (retval) {
affs_unlock_dir(dir); affs_unlock_dir(dir);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment