2011/10/1 Jeff Layton <jlayton@xxxxxxxxxx>: > I'm not sure I understand what you're saying here. IIUC, windows does > not allow the merging of lock ranges. Yes, in CIFS we allow to unlock all locks that appears in unlock region for mandatory locks (by unlocking each one in an order), but Windows doesn't. > > While I'd agree that the situation with locking is far from ideal, I'm > not sure that the above really adequately describes the situation... > > With cifs.ko, our goal is generally do attempt to map POSIX behavior on > top of what the CIFS/SMB protocol allows. Locking is one of those > unfortunate places where this mapping really falls short. > > Windows locks are always mandatory -- full stop. POSIX locks are > usually advisory (it is possible to do mandatory locking too, but > applications rarely do). POSIX allows the merging of lock ranges. > Windows does not. There are other differences too... > > Now, most of our users don't care about the intricacies of what the > protocol allows. They just want their applications to work. So, we > attempt to accomodate that by mapping POSIX advisory locking on top of > windows locks. It's imperfect, but we do the best we can. > > Your email above is rather vague -- I get that you want to change > *something*, but I'm not sure specifically what it is. Perhaps you can > clarify? What changes will users see with your proposal? Ok, sorry for wasn't clear. I suggest to follow Windows semantic fluently for Windows locks - to unlock exactly the lock (one lock) that is requested and no others. So, the end users will need to unlock every lock they set before. On close, Windows remove locks itself - so, we don't need to unlock them explicitly. As we can't follow POSIX semantic Windows locks fluently, I don't think we need to support it partly. So, as the results, we end up with two opposite mode for brlocks: Windows and POSIX. If someone needs such sort mixing as we have now, we can add extra mount option for this further (or vice versa - a mount option for the new mode). Thoughts? -- Best regards, Pavel Shilovsky. -- To unsubscribe from this list: send the line "unsubscribe linux-cifs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html