Re: [PATCH] Fix WARN_ON / WARN_ON_ONCE regression

From: Andrew Morton
Date: Wed Oct 04 2006 - 13:34:37 EST


On Wed, 04 Oct 2006 09:22:09 -0700
Tim Chen <tim.c.chen@xxxxxxxxxxxxxxx> wrote:

> On Wed, 2006-10-04 at 09:30 -0700, Andrew Morton wrote:
>
> > > I have measured the cache miss with tool. So it is not just my theory.
> > >
> >
> > And what did that tool tell you?
>
> I am using emon. Measuring a 20 second stretch of tbench run saw the L2
> cache miss go from 14 million to 25 million on each of the cpu core.
> >
> > Please don't just ignore my questions. *why* are we getting a cache miss
> > rate on that integer which is causing measurable performance changes? If
> > we're reading it that frequently then the variable should be in cache(!).
> >
>
> The point is valid, __warn_once should be in cache, unless something
> evicts it. What I have found so far is with patch by Andrew and Leonid
> that avoid looking up the __warn_once integer, the cache miss rate is
> reduced to the level before.
>
> > Again: do you know which callsite is causing the problem? I assume one of
> > the ones in softirq.c? Do you know what the cache miss frequency is? etc.
> >
> Unfortunately emon does not directly give the callsite. Oprofile data
> shows a marked increase in time spent in do_softirq and local_bh_enable.
> What I could do is to individually turn off WARN_ON_ONCE at these sites
> and see if they are responsible for the cache miss. Will let you know
> what I found.

I see, thanks. How very peculiar.

I wonder if we just got unlucky and that particular benchmark with that
particular kernel build just happens to reach the cache system's
associativity threshold, and this one extra cacheline took it over the
edge. Or something.

But if that was the case, one would expect even a small change to the
kernel (say, a different compiler version, or different config) would
improve things a lot, or would worsen things a lot.

I think the change is right. But, again, I worry that any teeny change we
make in there in the future will bring the problem back.

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/