On Thu, Apr 27, 2017 at 9:48 AM, Miklos Szeredi <miklos@xxxxxxxxxx> wrote: > On Thu, Apr 27, 2017 at 8:27 AM, Amir Goldstein <amir73il@xxxxxxxxx> wrote: > >> Let me try to explain the problem with a worse case, but not >> improbable example: >> >> Suppose I have an overlay with deep file at /a/b/c/.../z >> Suppose the layers are at /old/{lower,upper} I copy them >> over to /new/{lower,upper} and mount the overlay at new path. >> >> Suppose that dcache is fully populated under /new and fully >> evicted under /old. >> >> When trying to decode the file handle for z, exportfs_decode_fh() >> will call the file system to actually read all directories a..z from disk >> in order to reconnect the dentry of old z all the way up to /old >> and it will do that *before* calling the acceptable() callback. >> >> Alternatively, if we first try to decode the file handle for /old/lower, >> decoding will be very fast (most likely already in cache) and we will >> not have to continue to decoding z and reading all directories a..z >> from disk. > > To answer my own question in the prev mail: we need to decode the fh > and not just blindly use the inum to prevent issues with > copied/mutilited/etc lower layers. Hmm, this is absurd. Why are we going to all this trouble to find the origin inode though decoding the file handle when this thing was meant to be an *optimization*? Without redirect, we can look up origin just like we do for merge dirs. Way faster than decoding a connected dentry, which is going to result in a readdir of the parent directory and whatnot. The only thing we need is a bool "was this copied" flag. For moved files, decoding the fh might be an optimization over walking the redirect, but that depends on a various factors, and it might also be a lot slower... But it's needed for the snapshot case, right? Am I missing something? Thanks, Miklos