From: Richard Hansen <rhansen-A08e6c8yq/Q@public.gmane.org>
To: Steven Whitehouse
<swhiteho-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>,
Christoph Hellwig <hch-wEGCiKHe2LqWVfeAwA7xHQ@public.gmane.org>,
mtk.manpages-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org
Cc: linux-mm-Bw31MaZKKs3YtjvyW6yDsg@public.gmane.org,
linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
linux-api-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
Greg Troxel <gdt-2FjktZCtrC/QT0dZR+AlfA@public.gmane.org>
Subject: Re: [PATCH] mm: msync: require either MS_ASYNC or MS_SYNC
Date: Wed, 02 Apr 2014 19:44:54 -0400 [thread overview]
Message-ID: <533CA0F6.2070100@bbn.com> (raw)
In-Reply-To: <1396439119.2726.29.camel@menhir>
On 2014-04-02 07:45, Steven Whitehouse wrote:
> Hi,
>
> On Wed, 2014-04-02 at 04:10 -0700, Christoph Hellwig wrote:
>> On Tue, Apr 01, 2014 at 02:25:45PM -0400, Richard Hansen wrote:
>>> For the flags parameter, POSIX says "Either MS_ASYNC or MS_SYNC shall
>>> be specified, but not both." [1] There was already a test for the
>>> "both" condition. Add a test to ensure that the caller specified one
>>> of the flags; fail with EINVAL if neither are specified.
>>
>> This breaks various (sloppy) existing userspace
Agreed, but this shouldn't be a strong consideration. The kernel should
let userspace apps worry about their own bugs, not provide crutches.
>> for no gain.
I disagree. Here is what we gain from this patch (expanded from my
previous email):
* Clearer intentions. Looking at the existing code and the code
history, the fact that flags=0 behaves like flags=MS_ASYNC appears
to be a coincidence, not the result of an intentional choice.
* Clearer semantics. What does it mean for msync() to be neither
synchronous nor asynchronous?
* Met expectations. An average reader of the POSIX spec or the
Linux man page would expect msync() to fail if neither flag is
specified.
* Defense against potential future security vulnerabilities. By
explicitly requiring one of the flags, a future change to msync()
is less likely to expose an unintended code path to userspace.
* flags=0 is reserved. By making it illegal to omit both flags
we have the option of making it legal in the future for some
expanded purpose. (Unlikely, but still.)
* Forced app portability. Other operating systems (e.g., NetBSD)
enforce POSIX, so an app developer using Linux might not notice the
non-conformance. This is really the app developer's problem, not
the kernel's, but it's worth considering given msync()'s behavior
is currently unspecified.
Here is a link to a discussion on the bup mailing list about
msync() portability. This is the conversation that motivated this
patch.
http://article.gmane.org/gmane.comp.sysutils.backup.bup/3005
Alternatives:
* Do nothing. Leave the behavior of flags=0 unspecified and let
sloppy userspace continue to be sloppy. Easiest, but the intended
behavior remains unclear and it risks unintended behavior changes
the next time msync() is overhauled.
* Leave msync()'s current behavior alone, but document that MS_ASYNC
is the default if neither is specified. This is backward-
compatible with sloppy userspace, but encourages non-portable uses
of msync() and would preclude using flags=0 for some other future
purpose.
* Change the default to MS_SYNC and document this. This is perhaps
the most conservative option, but it alters the behavior of existing
sloppy userspace and also has the disadvantages of the previous
alternative.
Overall, I believe the advantages of this patch outweigh the
disadvantages, given the alternatives.
Perhaps I should include the above bullets in the commit message.
>>
>> NAK.
>>
> Agreed. It might be better to have something like:
>
> if (flags == 0)
> flags = MS_SYNC;
>
> That way applications which don't set the flags (and possibly also don't
> check the return value, so will not notice an error return) will get the
> sync they desire. Not that either of those things is desirable, but at
> least we can make the best of the situation. Probably better to be slow
> than to potentially lose someone's data in this case,
This is a conservative alternative, but I'd rather not condone flags=0.
Other than compatibility with broken apps, there is little value in
supporting flags=0. Portable apps will have to specify one of the flags
anyway, and the behavior of flags=0 is already accessible via other means.
Thanks,
Richard
>
> Steve.
WARNING: multiple messages have this Message-ID (diff)
From: Richard Hansen <rhansen@bbn.com>
To: Steven Whitehouse <swhiteho@redhat.com>,
Christoph Hellwig <hch@infradead.org>,
mtk.manpages@gmail.com
Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org,
linux-api@vger.kernel.org, Greg Troxel <gdt@ir.bbn.com>
Subject: Re: [PATCH] mm: msync: require either MS_ASYNC or MS_SYNC
Date: Wed, 02 Apr 2014 19:44:54 -0400 [thread overview]
Message-ID: <533CA0F6.2070100@bbn.com> (raw)
In-Reply-To: <1396439119.2726.29.camel@menhir>
On 2014-04-02 07:45, Steven Whitehouse wrote:
> Hi,
>
> On Wed, 2014-04-02 at 04:10 -0700, Christoph Hellwig wrote:
>> On Tue, Apr 01, 2014 at 02:25:45PM -0400, Richard Hansen wrote:
>>> For the flags parameter, POSIX says "Either MS_ASYNC or MS_SYNC shall
>>> be specified, but not both." [1] There was already a test for the
>>> "both" condition. Add a test to ensure that the caller specified one
>>> of the flags; fail with EINVAL if neither are specified.
>>
>> This breaks various (sloppy) existing userspace
Agreed, but this shouldn't be a strong consideration. The kernel should
let userspace apps worry about their own bugs, not provide crutches.
>> for no gain.
I disagree. Here is what we gain from this patch (expanded from my
previous email):
* Clearer intentions. Looking at the existing code and the code
history, the fact that flags=0 behaves like flags=MS_ASYNC appears
to be a coincidence, not the result of an intentional choice.
* Clearer semantics. What does it mean for msync() to be neither
synchronous nor asynchronous?
* Met expectations. An average reader of the POSIX spec or the
Linux man page would expect msync() to fail if neither flag is
specified.
* Defense against potential future security vulnerabilities. By
explicitly requiring one of the flags, a future change to msync()
is less likely to expose an unintended code path to userspace.
* flags=0 is reserved. By making it illegal to omit both flags
we have the option of making it legal in the future for some
expanded purpose. (Unlikely, but still.)
* Forced app portability. Other operating systems (e.g., NetBSD)
enforce POSIX, so an app developer using Linux might not notice the
non-conformance. This is really the app developer's problem, not
the kernel's, but it's worth considering given msync()'s behavior
is currently unspecified.
Here is a link to a discussion on the bup mailing list about
msync() portability. This is the conversation that motivated this
patch.
http://article.gmane.org/gmane.comp.sysutils.backup.bup/3005
Alternatives:
* Do nothing. Leave the behavior of flags=0 unspecified and let
sloppy userspace continue to be sloppy. Easiest, but the intended
behavior remains unclear and it risks unintended behavior changes
the next time msync() is overhauled.
* Leave msync()'s current behavior alone, but document that MS_ASYNC
is the default if neither is specified. This is backward-
compatible with sloppy userspace, but encourages non-portable uses
of msync() and would preclude using flags=0 for some other future
purpose.
* Change the default to MS_SYNC and document this. This is perhaps
the most conservative option, but it alters the behavior of existing
sloppy userspace and also has the disadvantages of the previous
alternative.
Overall, I believe the advantages of this patch outweigh the
disadvantages, given the alternatives.
Perhaps I should include the above bullets in the commit message.
>>
>> NAK.
>>
> Agreed. It might be better to have something like:
>
> if (flags == 0)
> flags = MS_SYNC;
>
> That way applications which don't set the flags (and possibly also don't
> check the return value, so will not notice an error return) will get the
> sync they desire. Not that either of those things is desirable, but at
> least we can make the best of the situation. Probably better to be slow
> than to potentially lose someone's data in this case,
This is a conservative alternative, but I'd rather not condone flags=0.
Other than compatibility with broken apps, there is little value in
supporting flags=0. Portable apps will have to specify one of the flags
anyway, and the behavior of flags=0 is already accessible via other means.
Thanks,
Richard
>
> Steve.
--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org. For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>
WARNING: multiple messages have this Message-ID (diff)
From: Richard Hansen <rhansen@bbn.com>
To: Steven Whitehouse <swhiteho@redhat.com>,
Christoph Hellwig <hch@infradead.org>,
mtk.manpages@gmail.com
Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org,
linux-api@vger.kernel.org, Greg Troxel <gdt@ir.bbn.com>
Subject: Re: [PATCH] mm: msync: require either MS_ASYNC or MS_SYNC
Date: Wed, 02 Apr 2014 19:44:54 -0400 [thread overview]
Message-ID: <533CA0F6.2070100@bbn.com> (raw)
In-Reply-To: <1396439119.2726.29.camel@menhir>
On 2014-04-02 07:45, Steven Whitehouse wrote:
> Hi,
>
> On Wed, 2014-04-02 at 04:10 -0700, Christoph Hellwig wrote:
>> On Tue, Apr 01, 2014 at 02:25:45PM -0400, Richard Hansen wrote:
>>> For the flags parameter, POSIX says "Either MS_ASYNC or MS_SYNC shall
>>> be specified, but not both." [1] There was already a test for the
>>> "both" condition. Add a test to ensure that the caller specified one
>>> of the flags; fail with EINVAL if neither are specified.
>>
>> This breaks various (sloppy) existing userspace
Agreed, but this shouldn't be a strong consideration. The kernel should
let userspace apps worry about their own bugs, not provide crutches.
>> for no gain.
I disagree. Here is what we gain from this patch (expanded from my
previous email):
* Clearer intentions. Looking at the existing code and the code
history, the fact that flags=0 behaves like flags=MS_ASYNC appears
to be a coincidence, not the result of an intentional choice.
* Clearer semantics. What does it mean for msync() to be neither
synchronous nor asynchronous?
* Met expectations. An average reader of the POSIX spec or the
Linux man page would expect msync() to fail if neither flag is
specified.
* Defense against potential future security vulnerabilities. By
explicitly requiring one of the flags, a future change to msync()
is less likely to expose an unintended code path to userspace.
* flags=0 is reserved. By making it illegal to omit both flags
we have the option of making it legal in the future for some
expanded purpose. (Unlikely, but still.)
* Forced app portability. Other operating systems (e.g., NetBSD)
enforce POSIX, so an app developer using Linux might not notice the
non-conformance. This is really the app developer's problem, not
the kernel's, but it's worth considering given msync()'s behavior
is currently unspecified.
Here is a link to a discussion on the bup mailing list about
msync() portability. This is the conversation that motivated this
patch.
http://article.gmane.org/gmane.comp.sysutils.backup.bup/3005
Alternatives:
* Do nothing. Leave the behavior of flags=0 unspecified and let
sloppy userspace continue to be sloppy. Easiest, but the intended
behavior remains unclear and it risks unintended behavior changes
the next time msync() is overhauled.
* Leave msync()'s current behavior alone, but document that MS_ASYNC
is the default if neither is specified. This is backward-
compatible with sloppy userspace, but encourages non-portable uses
of msync() and would preclude using flags=0 for some other future
purpose.
* Change the default to MS_SYNC and document this. This is perhaps
the most conservative option, but it alters the behavior of existing
sloppy userspace and also has the disadvantages of the previous
alternative.
Overall, I believe the advantages of this patch outweigh the
disadvantages, given the alternatives.
Perhaps I should include the above bullets in the commit message.
>>
>> NAK.
>>
> Agreed. It might be better to have something like:
>
> if (flags == 0)
> flags = MS_SYNC;
>
> That way applications which don't set the flags (and possibly also don't
> check the return value, so will not notice an error return) will get the
> sync they desire. Not that either of those things is desirable, but at
> least we can make the best of the situation. Probably better to be slow
> than to potentially lose someone's data in this case,
This is a conservative alternative, but I'd rather not condone flags=0.
Other than compatibility with broken apps, there is little value in
supporting flags=0. Portable apps will have to specify one of the flags
anyway, and the behavior of flags=0 is already accessible via other means.
Thanks,
Richard
>
> Steve.
next prev parent reply other threads:[~2014-04-02 23:44 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-04-01 18:25 [PATCH] mm: msync: require either MS_ASYNC or MS_SYNC Richard Hansen
2014-04-01 18:25 ` Richard Hansen
[not found] ` <533B04A9.6090405-A08e6c8yq/Q@public.gmane.org>
2014-04-01 19:32 ` Michael Kerrisk (man-pages)
2014-04-01 19:32 ` Michael Kerrisk (man-pages)
2014-04-01 19:32 ` Michael Kerrisk (man-pages)
2014-04-02 0:53 ` Richard Hansen
2014-04-02 0:53 ` Richard Hansen
[not found] ` <533B1439.3010403-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2014-04-02 10:45 ` chrubis-AlSwsSmVLrQ
2014-04-02 10:45 ` chrubis
2014-04-02 10:45 ` chrubis
2014-04-02 11:10 ` Christoph Hellwig
2014-04-02 11:10 ` Christoph Hellwig
2014-04-02 11:10 ` Christoph Hellwig
[not found] ` <20140402111032.GA27551-wEGCiKHe2LqWVfeAwA7xHQ@public.gmane.org>
2014-04-02 11:45 ` Steven Whitehouse
2014-04-02 11:45 ` Steven Whitehouse
2014-04-02 11:45 ` Steven Whitehouse
2014-04-02 23:44 ` Richard Hansen [this message]
2014-04-02 23:44 ` Richard Hansen
2014-04-02 23:44 ` Richard Hansen
2014-04-03 8:25 ` Michael Kerrisk (man-pages)
2014-04-03 8:25 ` Michael Kerrisk (man-pages)
2014-04-03 11:51 ` Christopher Covington
2014-04-03 11:51 ` Christopher Covington
2014-04-04 6:54 ` Michael Kerrisk (man-pages)
2014-04-04 6:54 ` Michael Kerrisk (man-pages)
2014-04-04 6:54 ` Michael Kerrisk (man-pages)
2014-04-03 12:57 ` Greg Troxel
2014-04-03 12:57 ` Greg Troxel
2014-04-04 7:11 ` Michael Kerrisk (man-pages)
2014-04-04 7:11 ` Michael Kerrisk (man-pages)
2014-04-04 7:11 ` Michael Kerrisk (man-pages)
2014-04-03 20:23 ` Richard Hansen
2014-04-03 20:23 ` Richard Hansen
2014-04-04 6:53 ` Christoph Hellwig
2014-04-04 6:53 ` Christoph Hellwig
2014-04-04 7:12 ` [PATCH] mm: msync: require either MS_ASYNC or MS_SYNC [resend] Michael Kerrisk (man-pages)
2014-04-04 7:12 ` Michael Kerrisk (man-pages)
2014-04-04 7:12 ` Michael Kerrisk (man-pages)
2014-04-04 14:07 ` Peter Zijlstra
2014-04-04 14:07 ` Peter Zijlstra
-- strict thread matches above, loose matches on Subject: below --
2013-09-01 19:58 [PATCH] mm: msync: require either MS_ASYNC or MS_SYNC Richard Hansen
2013-09-01 19:58 ` Richard Hansen
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=533CA0F6.2070100@bbn.com \
--to=rhansen-a08e6c8yq/q@public.gmane.org \
--cc=gdt-2FjktZCtrC/QT0dZR+AlfA@public.gmane.org \
--cc=hch-wEGCiKHe2LqWVfeAwA7xHQ@public.gmane.org \
--cc=linux-api-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=linux-mm-Bw31MaZKKs3YtjvyW6yDsg@public.gmane.org \
--cc=mtk.manpages-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
--cc=swhiteho-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.