On Fri, Aug 1, 2008 at 12:19 PM, David Woodhouse <dwmw2@xxxxxxxxxxxxx> wrote: > On Fri, 2008-08-01 at 12:05 -0400, Chuck Lever wrote: >> Some NFSv3 clients don't support READDIRPLUS at all, while some can >> disable it (like Linux, Mac OS, and FreeBSD), and others use it only >> in certain cases (Linux). I wouldn't describe any of these as saner >> or more commonly encountered than another. > > Readdirplus is easy enough to fix with a lookup_fh() method and some way > to check if a given entry is a mountpoint. I'm not worried about that. > >> > Or maybe we could just mask the offending attrs out of ->rd_bmval for >> > readdir calls, and say we don't support them? Would anyone scream if we >> > did that? >> >> I'm not an NFSv4 expert (hence my initial incorrect assertion about >> NFSv4 not supporting readdirplus at all). I defer to those who are >> actually working on the standard and Linux implementation (Bruce?) >> But typically masking out these features could potentially cause >> severe interoperability problems for certain client implementations. >> We can only know for sure after a lot of testing at multivendor events >> like Connectathon; it's not something I would disable cavalierly. > > It's not readdirplus (FATTR4_WORD0_FILEHANDLE?) I was talking about > masking out -- as I said, we can cope with that. It's things that would > _really_ require the inode, like FATTR4_WORD0_ACL, FATTR4_WORD0_CHANGE, > etc. AFAIK WORD0_CHANGE is a required value for NFSv4 clients to detect data changes on the server. That's one I think needs to remain enabled in the server capabilities bitmask. In fact most local file systems on Linux don't handle that one correctly yet anyway, but "saner" clients do depend on that one to manage their page caches. I don't think there's a way to indicate to a client that a server supports WORD0_CHANGE for a normal NFSv4 GETATTR, but not during a NFSv4 READDIR. > But still, if masking them out would be a problem, we could use the > existing trick of doing readdir into a buffer and then going back and > doing the actual lookup later. But _only_ for that relatively rare case, > rather than for _all_ users of readdirplus, as we do at the moment. Personally I don't have an immediate problem with the double-buffering here. The extra data copy wouldn't add significant overhead to an already expensive and not terribly frequent operation. There may be a caching opportunity to saving the buffered result, but I would bet either the contents of a directory or the attributes of objects residing in it would change too often for there to be much benefit. I think we have an opportunity for a little better concurrency here, though. Doing all the lookups and the directory read asynchronously and concurrently, if that's possible, might be a performance enhancement in most normal cases. This would allow the requests to be passed all at once to the local file system, which could then organize any necessary disk accesses in a more optimal way. That would be a reason to continue to do a double-buffered readdir in every case. -- Chuck Lever -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html