On Mon, Mar 22, 2010 at 04:33:40PM -0400, Jeff Layton wrote: > It looks like nfs_inode_return_delegation always calls nfs_msync_inode > on any valid delegation before returning it, regardless of the > delegation type. > > RFC 3530 says this: > > If the client is granted a read delegation, it is assured that no > other client has the ability to write to the file for the duration of > the delegation. If the client is granted a write delegation, the > client is assured that no other client has read or write access to > the file. > > That doesn't seem to imply that we must flush writes before returning > either type of delegation. OTOH, maybe it makes sense to treat those as > cache consistency points since a delegreturn sort of implies that > another client wants to use the file. > > I'm not quite sure how to interpret the spec here... If there's that call could cause the client to wait for an actual write to succeed before returning the delegation, then something's wrong. Waiting for a commit also seems strange, but probably not incorrect: it seems fair for the client to expect the server not to treat a commit as conflicting with a delegation. --b. -- To unsubscribe from this list: send the line "unsubscribe linux-nfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html