[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.DEB.2.00.0908201542440.29906@chino.kir.corp.google.com>
Date: Thu, 20 Aug 2009 15:56:23 -0700 (PDT)
From: David Rientjes <rientjes@...gle.com>
To: Jonathan Corbet <corbet@....net>
cc: Andrew Morton <akpm@...ux-foundation.org>,
Paul Menage <menage@...gle.com>, bblum@...rew.cmu.edu,
lizf@...fujitsu.com, linux-kernel@...r.kernel.org,
containers@...ts.linux-foundation.org,
Dave Hansen <haveblue@...ibm.com>
Subject: Re: [PATCH 4/8] Use vmalloc for large cgroups pidlist allocations
On Thu, 20 Aug 2009, Jonathan Corbet wrote:
> On Thu, 20 Aug 2009 14:14:00 -0700
> Andrew Morton <akpm@...ux-foundation.org> wrote:
>
> > Hang on. Isn't this why Dave just wrote and I just rush-merged
> > lib/flex_array.c?
> >
> > Was that code evaluated for this application and judged unsuitable? If so,
> > for what reason?
>
> Should it be helpful: I wrote an overview of the flex_array API here:
>
> http://lwn.net/Articles/345273/
>
> I could format it up for addition to Documentation/ if people want.
>
It's definitely helpful for this use case, flex array can store 261,632
pid_t's on 64 bit.
Instead of reallocating new memory when the pidlist becomes smaller, it
would then be sufficient to simply shrink the flex array by freeing parts
members that are newly unused (which also avoids the oom possibility in
pidlist_resize()).
flex_array_shrink(struct flex_array *) would require element poisoning
when an element is cleared, but that's probably not far off anyways
because it has additional advantages such as preventing flex_array_get()
on an element that has not been put.
--
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