Skip to content

Commit

Permalink
switch jfs to ->s_d_op, close exportfs races
Browse files Browse the repository at this point in the history
Signed-off-by: Al Viro <[email protected]>
  • Loading branch information
Al Viro committed Jan 13, 2011
1 parent 3d23985 commit 94b77bd
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 12 deletions.
10 changes: 1 addition & 9 deletions fs/jfs/namei.c
Original file line number Diff line number Diff line change
Expand Up @@ -1465,9 +1465,6 @@ static struct dentry *jfs_lookup(struct inode *dip, struct dentry *dentry, struc

jfs_info("jfs_lookup: name = %s", name);

if (JFS_SBI(dip->i_sb)->mntflag & JFS_OS2)
d_set_d_op(dentry, &jfs_ci_dentry_operations);

if ((name[0] == '.') && (len == 1))
inum = dip->i_ino;
else if (strcmp(name, "..") == 0)
Expand All @@ -1492,12 +1489,7 @@ static struct dentry *jfs_lookup(struct inode *dip, struct dentry *dentry, struc
return ERR_CAST(ip);
}

dentry = d_splice_alias(ip, dentry);

if (dentry && (JFS_SBI(dip->i_sb)->mntflag & JFS_OS2))
d_set_d_op(dentry, &jfs_ci_dentry_operations);

return dentry;
return d_splice_alias(ip, dentry);
}

static struct inode *jfs_nfs_get_inode(struct super_block *sb,
Expand Down
6 changes: 3 additions & 3 deletions fs/jfs/super.c
Original file line number Diff line number Diff line change
Expand Up @@ -515,6 +515,9 @@ static int jfs_fill_super(struct super_block *sb, void *data, int silent)

sb->s_magic = JFS_SUPER_MAGIC;

if (sbi->mntflag & JFS_OS2)
sb->s_d_op = &jfs_ci_dentry_operations;

inode = jfs_iget(sb, ROOT_I);
if (IS_ERR(inode)) {
ret = PTR_ERR(inode);
Expand All @@ -524,9 +527,6 @@ static int jfs_fill_super(struct super_block *sb, void *data, int silent)
if (!sb->s_root)
goto out_no_root;

if (sbi->mntflag & JFS_OS2)
d_set_d_op(sb->s_root, &jfs_ci_dentry_operations);

/* logical blocks are represented by 40 bits in pxd_t, etc. */
sb->s_maxbytes = ((u64) sb->s_blocksize) << 40;
#if BITS_PER_LONG == 32
Expand Down

0 comments on commit 94b77bd

Please sign in to comment.