diff --git a/fs/befs/befs.h b/fs/befs/befs.h index 11461abfda11d3cdf8a05cd6e4810faa5d956a1e..1fead8d56a98b751b74456f423fa5bacf6a3c6ba 100644 --- a/fs/befs/befs.h +++ b/fs/befs/befs.h @@ -56,7 +56,7 @@ struct befs_sb_info { struct nls_table *nls; }; -typedef struct befs_inode_info { +struct befs_inode_info { u32 i_flags; u32 i_type; @@ -70,8 +70,7 @@ typedef struct befs_inode_info { } i_data; struct inode vfs_inode; - -} befs_inode_info; +}; enum befs_err { BEFS_OK, @@ -110,7 +109,7 @@ BEFS_SB(const struct super_block *super) return (struct befs_sb_info *) super->s_fs_info; } -static inline befs_inode_info * +static inline struct befs_inode_info * BEFS_I(const struct inode *inode) { return list_entry(inode, struct befs_inode_info, vfs_inode); diff --git a/fs/befs/linuxvfs.c b/fs/befs/linuxvfs.c index 9978db4aeb8713c5c7ffba265b7d813934842f63..16e0a48bfccd41e904a8044beced4d84af1bdbe7 100644 --- a/fs/befs/linuxvfs.c +++ b/fs/befs/linuxvfs.c @@ -305,7 +305,7 @@ static struct inode *befs_iget(struct super_block *sb, unsigned long ino) struct buffer_head *bh = NULL; befs_inode *raw_inode = NULL; struct befs_sb_info *befs_sb = BEFS_SB(sb); - befs_inode_info *befs_ino = NULL; + struct befs_inode_info *befs_ino = NULL; struct inode *inode; long ret = -EIO; @@ -471,7 +471,7 @@ static void * befs_follow_link(struct dentry *dentry, struct nameidata *nd) { struct super_block *sb = dentry->d_sb; - befs_inode_info *befs_ino = BEFS_I(dentry->d_inode); + struct befs_inode_info *befs_ino = BEFS_I(dentry->d_inode); befs_data_stream *data = &befs_ino->i_data.ds; befs_off_t len = data->size; char *link; @@ -501,7 +501,8 @@ befs_follow_link(struct dentry *dentry, struct nameidata *nd) static void * befs_fast_follow_link(struct dentry *dentry, struct nameidata *nd) { - befs_inode_info *befs_ino = BEFS_I(dentry->d_inode); + struct befs_inode_info *befs_ino = BEFS_I(dentry->d_inode); + nd_set_link(nd, befs_ino->i_data.symlink); return NULL; }