From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752984Ab2IXKIf (ORCPT ); Mon, 24 Sep 2012 06:08:35 -0400 Received: from mail.parknet.co.jp ([210.171.160.6]:42337 "EHLO mail.parknet.co.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751298Ab2IXKIe (ORCPT ); Mon, 24 Sep 2012 06:08:34 -0400 From: OGAWA Hirofumi To: Namjae Jeon Cc: akpm@linux-foundation.org, bfields@fieldses.org, viro@zeniv.linux.org.uk, linux-kernel@vger.kernel.org, Namjae Jeon , Ravishankar N , Amit Sahrawat Subject: Re: [PATCH v3 2/5] fat: allocate persistent inode numbers References: <1347798148-2660-1-git-send-email-linkinjeon@gmail.com> <87lig28fak.fsf@devron.myhome.or.jp> <87ipb45914.fsf@devron.myhome.or.jp> <87ehls53ug.fsf@devron.myhome.or.jp> <87a9wg53mc.fsf@devron.myhome.or.jp> Date: Mon, 24 Sep 2012 19:08:24 +0900 In-Reply-To: (Namjae Jeon's message of "Mon, 24 Sep 2012 16:02:39 +0900") Message-ID: <87392768dj.fsf@devron.myhome.or.jp> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/24.2.50 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Namjae Jeon writes: >> This means - which code returns error? > Sorry, My explanation may be insufficient. > > nfs_update_inode()-> on NFS client > if ((fattr->valid & NFS_ATTR_FATTR_FILEID) && nfsi->fileid != fattr->fileid) { > printk(KERN_ERR "NFS: server %s error: fileid changed\n" > "fsid %s: expected fileid 0x%Lx, got 0x%Lx\n", > NFS_SERVER(inode)->nfs_client->cl_hostname, > inode->i_sb->s_id, (long long)nfsi->fileid, > (long long)fattr->fileid); > goto out_err; > } > > that the problem in that case will occur with the file handle on NFS > Client because the file handle on NFS client is still referring the > old inode number even though the i-pos is same I see. fileid seems to be stat.ino on nfsd4. inode->i_ino is actually just a hash key of inode hash (exception is only in audit, iirc). So, what happens if we set "stat->ino = i_pos" on fat_getattr(). int fat_getattr(struct vfsmount *mnt, struct dentry *dentry, struct kstat *stat) { struct inode *inode = dentry->d_inode; generic_fillattr(inode, stat); stat->blksize = MSDOS_SB(inode->i_sb)->cluster_size; if (opts->nfs == FAT_NFS_LIMITED) { /* Use i_pos for ino. This is used as fileid of nfs. */ stat->ino = MSDOS_SB(inode->i_sb)->i_pos; } return 0; } -- OGAWA Hirofumi