Re: [PATCH 2/2] locks: make locks_mandatory_area check for file-private locks

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Mar 10, 2014 at 10:31 AM, Jeffrey Layton <jlayton@xxxxxxxxxx> wrote:
> On Mon, 10 Mar 2014 10:07:10 -0700
> Andy Lutomirski <luto@xxxxxxxxxxxxxx> wrote:
>
>> On Mon, Mar 10, 2014 at 6:36 AM, Jeff Layton <jlayton@xxxxxxxxxx>
>> wrote:
>> > Allow locks_mandatory_area() to handle file-private locks correctly.
>> > If there is a file-private lock set on an open file and we're doing
>> > I/O via the same, then that should not cause anything to block.
>> >
>> > Handle this by first doing a non-blocking FL_ACCESS check for a
>> > file-private lock, and then fall back to checking for a classic
>> > POSIX lock (and possibly blocking).
>>
>> This is ugly, but it doesn't seem much worse than the existing
>> code. :)
>>
>> --Andy
>
>
> My sentiments exactly. The alternative would to add some mechanism to
> check for locks that are owned by more than one owner without dropping
> the i_lock in between. That's doable but it'd be pretty ugly too, and
> you'd still have the existing races to contend with.
>
> FWIW, now that I've looked at this code it seems possible to make
> mandatory locking more or less race-free by having reads and writes
> both implicitly set a special sort of lock on the file:
>
> - a read lock (for both the read and write cases)
>
> - one that wouldn't conflict with existing locks held by same process
>   or with file-private locks set on the same fd
>
> - but...the same lock could not be merged with either of the above (and
>   would therefore need a different sort of ownership model).
>
> Have rw_verify_area set such a blocking lock on the file and then
> remove it once the read or write was done. It doesn't sound too hard
> to do, but performance would likely suck.
>
> That said, I don't feel terribly motivated to fix mandatory locking
> aside from doing my best to avoid the problem that Trond pointed out.

I think the current patch is fine.  It'll hurt performance for -omand
users a little, but this is the least of their problems.  Let someone
who actually needs the feature fix it :)

--Andy
--
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




[Index of Archives]     [Linux Ext4 Filesystem]     [Union Filesystem]     [Filesystem Testing]     [Ceph Users]     [Ecryptfs]     [AutoFS]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux Cachefs]     [Reiser Filesystem]     [Linux RAID]     [Samba]     [Device Mapper]     [CEPH Development]
  Powered by Linux