Re: [ltt-dev] [PATCH] Fix dirty page accounting inredirty_page_for_writepage()
From: Mathieu Desnoyers
Date: Fri May 01 2009 - 15:21:57 EST
* Christoph Lameter (cl@xxxxxxxxx) wrote:
> On Thu, 30 Apr 2009, Mathieu Desnoyers wrote:
>
> > By ZVC update, you mean Zone ... Counter update ? (which code exactly ?)
>
> The code that you were modifying in vmstat.c.
>
> > Hrm, I must admit I'm not sure I follow how your reasoning applies to my
> > code. I am using a percpu_add_return_irq() exactly for this reason : it
> > only ever touches the percpu variable once and atomically. The test for
> > overflow is done on the value returned by percpu_add_return_irq().
>
> If the percpu differential goes over a certain boundary then the
> differential would be updated twice.
>
Not with my approach which tests for == 0, as you point out below,
> > Therefore, an interrupt scenario that would be close to what I
> > understand from your concerns would be :
> >
> > * Thread A
> >
> > inc_zone_page_state()
> > p_ret = percpu_add_return(p, 1); (let's suppose this increment
> > overflows the threshold, therefore
> > (p_ret & mask) == 0)
> >
> > ----> interrupt comes in, preempts the current thread, execution in a
> > different thread context (* Thread B) :
> >
> > inc_zone_page_state()
> > p_ret = percpu_add_return(p, 1); ((p_ret & mask) == 1)
> > if (!(p_ret & mask))
> > increment global zone count. (not executed)
> >
> > ----> interrupt comes in, preempts the current thread, execution back to
> > the original thread context (Thread A), on the same or on a
> > different CPU :
> >
> > if (!(p_ret & mask))
> > increment global zone count. -----> will therefore increment the
> > global zone count only after
> > scheduling back the original
> > thread.
> >
> > So I guess what you say here is that if Thread B is preempted for too
> > long, we will have to wait until it gets scheduled back before the
> > global count is incremented. Do we really need such degree of precision
> > for those counters ?
> >
> > (I fear I'm not understanding your concern fully though)
>
> Inc_zone_page_state modifies the differential which is u8 and can easily
> overflow.
>
> Hmmm. But if you check for overflow to zero this way it may work without
> the need for cmpxchg. But if you rely on overflow then we only update the
> global count after 256 counts on the percpu differential. The tuning of
> the accuracy of the counter wont work anymore. The global counter could
> become wildly inaccurate with a lot of processors.
>
I see that we are getting on the same page here. Good :) About the
overflow :
What I do here is to let those u8 counters increment as free-running
counters. Yes, they will periodically overflow the 8 bits. But I don't
rely on this for counting the number of increments we need between
global counter updates : I use the bitmask taken from the threshold
value (which is now required to be a power of two) to detect 0, 1, 2, 3,
4, 5, 6 or 7-bit counter overflow. Therefore we can still have the kind
of granularity currently provided. The only limitation is that we have
to use powers of two for the threshold, so we end up counting in power
of two modulo, which will be unaffected by the u8 overflow.
Mathieu
--
Mathieu Desnoyers
OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68
--
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/