Re: [PATCH v10 13/35] vmscan: per-node deferred work

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, 6 Jun 2013 14:59:07 +1000 Dave Chinner <david@xxxxxxxxxxxxx> wrote:

> On Thu, Jun 06, 2013 at 01:37:42PM +1000, Dave Chinner wrote:
> > On Wed, Jun 05, 2013 at 04:08:15PM -0700, Andrew Morton wrote:
> > > On Mon,  3 Jun 2013 23:29:42 +0400 Glauber Costa <glommer@xxxxxxxxxx> wrote:
> > > 
> > > > We already keep per-node LRU lists for objects being shrunk, but the
> > > > work that is deferred from one run to another is kept global. This
> > > > creates an impedance problem, where upon node pressure, work deferred
> > > > will accumulate and end up being flushed in other nodes.
> > > 
> > > This changelog would be more useful if it had more specificity.  Where
> > > do we keep these per-node LRU lists (names of variables?).
> > 
> > In the per-node LRU lists the shrinker walks ;)
> > 
> > > Where do we
> > > keep the global data? 
> > 
> > In the struct shrinker
> > 
> > > In what function does this other-node flushing
> > > happen?
> > 
> > Any shrinker that is run on a different node.
> > 
> > > Generally so that readers can go and look at the data structures and
> > > functions which you're talking about.
> > > 
> > > > In large machines, many nodes can accumulate at the same time, all
> > > > adding to the global counter.
> > > 
> > > What global counter?
> > 
> > shrinker->nr
> > 
> > > >  As we accumulate more and more, we start
> > > > to ask for the caches to flush even bigger numbers.
> > > 
> > > Where does this happen?
> > 
> > The shrinker scan loop ;)
> 
> Answers which doesn't really tell you more than you already knew :/
> 
> To give you more background, Andrew, here's a pointer to the
> discussion where we analysed the problem that lead to this patch:
> 
> http://marc.info/?l=linux-fsdevel&m=136852512724091&w=4

Thanks, I'll read that later.  But that only helps me!  And I'll forget
it all in six hours.

Please understand where I'm coming from here: I review code from the
point of view (amongst others) "how understandable and maintainable is
this".  And I hope that reviewees understand that "if this reader asked
that question then others will wonder the same thing, so I need to fix
that up".

And I do think that about 2% of readers look in Documentation/, 1% of
readers go back to look at changelogs and 0% of readers go back and
look at the mailing list discussion.  It's most effective if it's right
there in the .c file.

Obviously there are tradeoffs here, but code which overdoes the
explain-thyself thing is rare to non-existent.

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@xxxxxxxxx.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@xxxxxxxxx";> email@xxxxxxxxx </a>




[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]