"Steven J. Magnani" <st...@digidescorp.com> writes: >> > >> > Interesting idea. I think this, and reformulating the FAT NFS file >> > >> > handle to include the parent's i_ino, will greatly simplify (and speed >> > >> > up) the code. >> > >> >> > >> Does it work even if the inode was rename()'ed? >> > > >> > > AFAICT. I don't see why it wouldn't; on a rename, the inode's i_pos >> > > changes but its i_ino stays the same, right? >> > >> > If the inode is not on cache anymore, is there the possibility that >> > selects the wrong parent? IIRC, NFS Server can be rebooted at any time >> > while the client using the same file handle. >> >> True, but it's looking like we can just use the default handle >> constructed by export_encode_fh(), namely (i_ino, i_generation, >> parent->i_ino, parent->i_generation). None of those components should >> change in a server reboot. > > I think I misunderstood you when I wrote this. I assumed we were talking > about a restart of nfsd, not the entire machine it was running on. If > there is a danger of mismapping on a reboot isn't that present in the > existing mainline code, i.e. fat_fh_to_dentry()? Ideally, the (i_ino, > i_generation) signature would be different on a reboot, although with > only 2-second granularity in i_generation I suppose that's less likely > than we would prefer. Also I would think that many inodes simply > wouldn't exist in the cache, in which case we would fail the operation > with ESTALE.
Ah, i_ino. I was talking about i_pos. Well, so, what happens if the child was renamed to other parent on NFS server machine (not via nfs client)? The file handle would be including the old i_ino, and the old i_ino on file handle is still vaild as old parent. So, it returns the wrong parent? -- OGAWA Hirofumi <hirof...@mail.parknet.co.jp> -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/