From: David Howells Date: Fri, 6 Apr 2018 13:17:24 +0000 (+0100) Subject: afs: Init inode before accessing cache X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=5800db810a2308544a9e42686a2fc7f8682418ba;p=openwrt%2Fstaging%2Fblogic.git afs: Init inode before accessing cache We no longer parse symlinks when we get the inode to determine if this symlink is actually a mountpoint as we detect that by examining the mode instead (symlinks are always 0777 and mountpoints 0644). Access the cache after mapping the status so that we don't have to manually set the inode size now. Note that this may need adjusting if the disconnected operation is implemented as the file metadata may have to be obtained from the cache. Signed-off-by: David Howells --- diff --git a/fs/afs/inode.c b/fs/afs/inode.c index f4e62964efcb..bcaff40b664d 100644 --- a/fs/afs/inode.c +++ b/fs/afs/inode.c @@ -331,15 +331,12 @@ struct inode *afs_iget(struct super_block *sb, struct key *key, vnode->cb_expires_at += ktime_get_real_seconds(); } - /* set up caching before mapping the status, as map-status reads the - * first page of symlinks to see if they're really mountpoints */ - inode->i_size = vnode->status.size; - afs_get_inode_cache(vnode); - ret = afs_inode_map_status(vnode, key); if (ret < 0) goto bad_inode; + afs_get_inode_cache(vnode); + /* success */ clear_bit(AFS_VNODE_UNSET, &vnode->flags); inode->i_flags |= S_NOATIME;