[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <87a5b0800803101153n614b044btfe02be2c77d11b84@mail.gmail.com>
Date: Mon, 10 Mar 2008 18:53:38 +0000
From: "Will Newton" <will.newton@...il.com>
To: "Hugh Dickins" <hugh@...itas.com>
Cc: LKML <linux-kernel@...r.kernel.org>
Subject: Re: copy_page_range() with VM_LOCKED
On Mon, Mar 10, 2008 at 5:40 PM, Hugh Dickins <hugh@...itas.com> wrote:
> > mmap with MAP_LOCKED only promises the page will not be paged out, not
> > that the page will never fault but I would like to get that behaviour.
> >
> > Would it be possible to add VM_LOCKED to the above conditional so
> > copy_page_range would always copy VM_LOCKED vma page tables or would
> > that be considered insane and broken?
>
> It would be possible, but I don't think it would be justified - for
> everybody who wants your behaviour, there'll be others who want the
> current behaviour (and that condition reflects those cases on which
> correctness demands we do the copy).
>
> If you really want that, I think you'll have to patch your own kernel.
>
> But much much better, mlock that area in your child after the fork,
> since it isn't actually locked at present: that mlock will bring in
> the pages - not quite as efficiently as copy_page_range would have done,
> but as or more efficiently than the original mlock in the parent.
The reason I want to do this is to work around a silicon bug so I'd
rather keep the whole workaround in the kernel rather than hacking the
C library etc. I wasn't aware that the VM_LOCKED flag would be lost in
the child, it looks like I'll have to come up with a more creative
solution...
Thanks for taking the time to explain how this stuff fits together,
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists