linux-api.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Gleb Natapov <gleb@redhat.com>
To: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>
Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org,
	linux-api@vger.kernel.org, akpm@linux-foundation.org
Subject: Re: [PATCH v5] add MAP_UNLOCKED mmap flag
Date: Thu, 14 Jan 2010 10:01:17 +0200	[thread overview]
Message-ID: <20100114080117.GL18808@redhat.com> (raw)
In-Reply-To: <20100114162327.673E.A69D9226@jp.fujitsu.com>

On Thu, Jan 14, 2010 at 04:30:51PM +0900, KOSAKI Motohiro wrote:
> > On Thu, Jan 14, 2010 at 04:02:42PM +0900, KOSAKI Motohiro wrote:
> > > > On Thu, Jan 14, 2010 at 09:31:03AM +0900, KOSAKI Motohiro wrote:
> > > > > > If application does mlockall(MCL_FUTURE) it is no longer possible to mmap
> > > > > > file bigger than main memory or allocate big area of anonymous memory
> > > > > > in a thread safe manner. Sometimes it is desirable to lock everything
> > > > > > related to program execution into memory, but still be able to mmap
> > > > > > big file or allocate huge amount of memory and allow OS to swap them on
> > > > > > demand. MAP_UNLOCKED allows to do that.
> > > > > >  
> > > > > > Signed-off-by: Gleb Natapov <gleb@redhat.com>
> > > > > > ---
> > > > > > 
> > > > > > I get reports that people find this useful, so resending.
> > > > > 
> > > > > This description is still wrong. It doesn't describe why this patch is useful.
> > > > > 
> > > > I think the text above describes the feature it adds and its use
> > > > case quite well. Can you elaborate what is missing in your opinion,
> > > > or suggest alternative text please?
> > > 
> > > My point is, introducing mmap new flags need strong and clearly use-case.
> > > All patch should have good benefit/cost balance. the code can describe the cost,
> > > but the benefit can be only explained by the patch description.
> > > 
> > > I don't think this poor description explained bit benefit rather than cost.
> > > you should explain why this patch is useful and not just pretty toy.
> > > 
> > The benefit is that with this patch I can lock all of my application in
> > memory except some very big memory areas. My use case is that I want to
> > run virtual machine in such a way that everything related to machine
> > emulator is locked into the memory, but guest address space can be
> > swapped out at will. Guest address space is so huge that it is not
> > possible to allocated it locked and then unlock. I was very surprised
> > that current Linux API has no way to do it hence this patch. It may look
> > like a pretty toy to you until some day you need this and has no way to
> > do it.
> 
> Hmm..
> Your answer didn't match I wanted.
Then I don't get what you want.

> few additional questions.
> 
> - Why don't you change your application? It seems natural way than kernel change.
There is no way to change my application and achieve what I've described
in a multithreaded app.

> - Why do you want your virtual machine have mlockall? AFAIK, current majority
>   virtual machine doesn't.
It is absolutely irrelevant for that patch, but just because you ask I
want to measure the cost of swapping out of a guest memory.

> - If this feature added, average distro user can get any benefit?
> 
?! Is this some kind of new measure? There are plenty of much more
invasive features that don't bring benefits to an average distro user.
This feature can bring benefit to embedded/RT developers.

> I mean, many application developrs want to add their specific feature
> into kernel. but if we allow it unlimitedly, major syscall become
> the trushbox of pretty toy feature soon.
> 
And if application developer wants to extend kernel in a way that it
will be possible to do something that was not possible before why is
this a bad thing? I would agree with you if for my problem was userspace
solution, but there is none. The mmap interface is asymmetric in regards
to mlock currently. There is MAP_LOCKED, but no MAP_UNLOCKED. Why
MAP_LOCKED is useful then?


--
			Gleb.

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

  reply	other threads:[~2010-01-14  8:01 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-01-13  9:31 [PATCH v5] add MAP_UNLOCKED mmap flag Gleb Natapov
     [not found] ` <20100113093119.GT7549-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-01-13 14:36   ` Américo Wang
2010-01-13 17:31 ` Chris Wright
2010-01-14  0:31 ` KOSAKI Motohiro
2010-01-14  6:50   ` Gleb Natapov
     [not found]     ` <20100114065008.GC18808-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-01-14  7:02       ` KOSAKI Motohiro
2010-01-14  7:22         ` Gleb Natapov
     [not found]           ` <20100114072210.GK18808-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-01-14  7:30             ` KOSAKI Motohiro
2010-01-14  8:01               ` Gleb Natapov [this message]
     [not found]                 ` <20100114080117.GL18808-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-01-14  8:17                   ` KOSAKI Motohiro
2010-01-14 10:22                     ` Gleb Natapov
     [not found]                     ` <20100114170247.6747.A69D9226-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-01-14 19:30                       ` Andrew C. Morrow
2010-01-18  3:23                         ` KOSAKI Motohiro
2010-01-18 13:40                           ` Gleb Natapov

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=20100114080117.GL18808@redhat.com \
    --to=gleb@redhat.com \
    --cc=akpm@linux-foundation.org \
    --cc=kosaki.motohiro@jp.fujitsu.com \
    --cc=linux-api@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mm@kvack.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).