linux-nfs-owner@vger.kernel.org wrote on 04/10/2013 06:24:39 AM:
2013/4/10 Jeff Layton jlayton@poochiereds.net:
On Tue, 9 Apr 2013 16:40:21 +0400 Pavel Shilovsky piastry@etersoft.ru wrote:
This patch adds 3 flags:
- O_DENYREAD that doesn't permit read access,
- O_DENYWRITE that doesn't permit write access,
- O_DENYDELETE that doesn't permit delete or rename,
Network filesystems CIFS, SMB2.0, SMB3.0 and NFSv4 have such flags - this change can benefit cifs and nfs modules as well as Samba and NFS file servers that export the same directory for Windows clients, or Wine applications that access the same files simultaneously.
These flags are only take affect for opens on mounts with 'sharelock' mount option. They are translated to flock's flags:
!O_DENYREAD -> LOCK_READ | LOCK_MAND !O_DENYWRITE -> LOCK_WRITE | LOCK_MAND
and set through flock_lock_file on a file. If the file can't be locked due conflicts with another open with O_DENY* flags, the -EBUSY error code is returned.
Create codepath is slightly changed to prevent data races on newely created files: when open with O_CREAT can return with -EBUSY error for successfully created files due to a deny lock set by another task.
It's good that this is consistent with the new patchset. I'm still not 100% sure that -EBUSY is the right error return here, but it should at least help distinguish between "mode bits don't allow me to open" and "file has share reservation set".
Heck, since we're departing from POSIX here, maybe we should consider a new error code altogether? ESHAREDENIED or something?
That can make sense. I don't mind to change this part.
I like this return code, it will help user space file servers return the correct error to their clients when they depend on the kernel to resolve share reservations. Internal to the kernel, having ESHAREDENIED will also be helpful to the NFS v4 and NLM code.
Frank