On Tue, 12 Aug 2008, Al Viro wrote: > On Tue, Aug 12, 2008 at 02:24:04PM -0700, Linus Torvalds wrote: > > > > You'd truncate the inode number. What's the big deal? Inode numbers aren't > > that important - they're just about the _least_ important part of the data > > returned for a readdir. > > Tell that to tar(1) ;-) The thing is, you still have the low 32 (or 16) bits, so even tar is better off most of the time. Let's face it, we actually always truncate things as-is. What are inode numbers on NFS but truncated file handles? And the other side of the coin is that legacy binaries are almost never _system_ binaries. You upgrade those with your system They are some odd special-purpose thing. > Anyway, the point for getdents() is simply that we *do* return an error; it's > just that it ends up with -EINVAL instead of -EOVERFLOW, and that's simply > bogus - we should either truncate silently or return the right value. The > code definitely intends to do the latter and fucks up. I agree. However, the reason it f*cks up is exactly the fact that we have two different error numbers, which was why I suggested that if we really want to fix this problem and are talking about cleaning things up, then _that_ should be our primary place to look at. Yes, it implies fixing and checking a lot of low-level filesystems. I agree. It's easier to just leave it be. Linus -- 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