> > Say you have NFS mount on /mnt and a bind mount over the regular file
> > /mnt/foo. You do open("/mnt/foo", O_RDWR | O_CREAT, 0644). How do
> > you solve the atomic open case.
>
> > If you open in ->lookup("foo") you will be opening the wrong file,
> > unless you want to follow mounts inside ->lookup.
>
> Firstly, if that is the case, then you will have dentries for both the
> covered and the covering copies of /mnt/foo. A simple test of
> have_submounts() on the dentry will suffice to tell the filesystem.
> whether or not it should open the file.
And if the bind is umounted after NFS determined not to open the file,
and at the same time it changes to a symlink on the server (not very
likely I agree, but possible nonetheless), then shit happens.
> Secondly, Linux doesn't actually allow bind mounts on top of regular
> files.
It does. Try it.
Miklos
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]