[ofa-general] Re: Demand paging for memory regions
Kanoj Sarcar
kanojsarcar at yahoo.com
Wed Feb 13 14:44:34 PST 2008
--- Christoph Lameter <clameter at sgi.com> wrote:
> On Wed, 13 Feb 2008, Christian Bell wrote:
>
> > not always be in the thousands but you're still
> claiming scalability
> > for a mechanism that essentially logs who accesses
> the regions. Then
> > there's the fact that reclaim becomes a collective
> communication
> > operation over all region accessors. Makes me
> nervous.
>
> Well reclaim is not a very fast process (and we
> usually try to avoid it
> as much as possible for our HPC). Essentially its
> only there to allow
> shifts of processing loads and to allow efficient
> caching of application
> data.
>
> > However, short of providing user-level
> notifications for pinned pages
> > that are inadvertently released to the O/S, I
> don't believe that the
> > patchset provides any significant added value for
> the HPC community
> > that can't optimistically do RDMA demand paging.
>
> We currently also run XPmem with pinning. Its great
> as long as you just
> run one load on the system. No reclaim ever iccurs.
>
> However, if you do things that require lots of
> allocations etc etc then
> the page pinning can easily lead to livelock if
> reclaim is finally
> triggerd and also strange OOM situations since the
> VM cannot free any
> pages. So the main issue that is addressed here is
> reliability of pinned
> page operations. Better VM integration avoids these
> issues because we can
> unpin on request to deal with memory shortages.
>
>
I have a question on the basic need for the mmu
notifier stuff wrt rdma hardware and pinning memory.
It seems that the need is to solve potential memory
shortage and overcommit issues by being able to
reclaim pages pinned by rdma driver/hardware. Is my
understanding correct?
If I do understand correctly, then why is rdma page
pinning any different than eg mlock pinning? I imagine
Oracle pins lots of memory (using mlock), how come
they do not run into vm overcommit issues?
Are we up against some kind of breaking c-o-w issue
here that is different between mlock and rdma pinning?
Asked another way, why should effort be spent on a
notifier scheme, and rather not on fixing any memory
accounting problems and unifying how pin pages are
accounted for that get pinned via mlock() or rdma
drivers?
Startup benefits are well understood with the notifier
scheme (ie, not all pages need to be faulted in at
memory region creation time), specially when most of
the memory region is not accessed at all. I would
imagine most of HPC does not work this way though.
Then again, as rdma hardware is applied
(increasingly?) towards apps with short lived
connections, the notifier scheme will help with
startup times.
Kanoj
____________________________________________________________________________________
Be a better friend, newshound, and
know-it-all with Yahoo! Mobile. Try it now. http://mobile.yahoo.com/;_ylt=Ahu06i62sR8HDtDypao8Wcj9tAcJ
More information about the general
mailing list